Click here to Skip to main content
15,990,972 members
Articles / Artificial Intelligence / Neural Networks

Real-time AI Person Detection on Edge Devices: Getting Started

Rate me:
Please Sign up or sign in to vote.
5.00/5 (6 votes)
5 Oct 2020CPOL4 min read 10.5K   1.6K   8   1
This is the first in an article series where we’ll show you how to detect people in real time (or near-real time) on Raspberry Pi.
Here we discuss a simple way of creating a DL person detector for edge devices, which is finding an appropriate DNN model and writing the code for launching it on a device.

Real-time detection of humans in live video streams has been a solved problem for several years now, thanks to Deep Learning (DL). But it’s not as easy on edge and IoT devices that don’t always have a lot of computing power.

In this article series, we’ll show you how to detect people in real time (or near-real time) on Raspberry Pi. This series assumes...

Historically, the first methods of object detection in images, such as Haar or LBP cascades, and Histogram of Oriented Gradients (HOG) classifier, have been designed to focus on finding objects of a specific class. In one way or another, all of these were based on extracting geometric features and deciding whether the detected feature set belonged to an object of the specified class.

When Deep Neural Networks (DNN) entered the scene, they were immediately recognized as very efficient feature extractors. This motivated Artificial Intelligence (AI) researchers to develop object detection-oriented DNNs and efficient algorithms to train them. Today, almost all modern computer vision systems use DL algorithms for object detection. Typically, object detection systems run on high-performance CPUs, GPUs, or even TPUs – processors specially designed for DNNs.

To carry out person detection on devices with low computing power, we must use a device-appropriate AI approach. First, let’s analyze the advantages and drawbacks of the existing DL methods and select the one that will suit us best. As person detection is a special case of object detection, we’ll look at the general-purpose DL object detectors, and then see how to adapt them to our special case.

The following are the most established modern DL methods of object detection: Faster-RCNN, Single-Shot Object Detector, and You Only Look Once (YOLO). All of the above techniques use Convolutional Neural Networks (CNN), and the differences between them are in the details of the internal network structures and algorithms for network training.

Faster-RCNN was the first DL technique successfully used for real-time object detection in video streams. Faster-RCNN is a DNN featuring two major parts. The first part works as a feature extractor. The second part is a specially designed neural network that uses the extracted features to locate object positions and classify them – for example, as the picture below shows:

Image 1

Single-Shot Detector (SSD) is very similar to Faster-RCNN. It includes a convolutional network for feature extraction and a mechanism for object location and classification. The only difference is that the above mechanism allows the network to localize and classify objects in a single forward pass. This makes SSD faster and simpler to train.

YOLO can also be considered a single-shot detector. It divides an image into a grid of cells and then predicts the score for each cell belonging to a certain class.

We’ll review the advantages and drawbacks of the DL technologies in the next article of the series. Meanwhile, let’s consider how we can apply the DL methods to our specific goal - person detection on edge devices.

We have two main goals:

  • Detect only humans
  • Use limited computational resources

There are two ways to meet both of the above requirements using DL methods:

  1. Design and train a new CNN for detecting only humans and optimize it for the size  and speed the edge devices can provide
  2. Find an existing CNN model for object detection that can be used on the edge devices and apply it for detecting humans

Professional software developers would probably prefer the first way. For example, to produce a video surveillance system that requires human detection. This would allow us to create real-life software optimized for running on Raspberry Pi devices. At the same time, it would require a lot of time and effort to design the CNN architecture from scratch, acquire a dataset of humans, and train the network.

The second way is much simpler. We just need to find an existing DNN that could be used on a device with low computing resources. It requires neither much effort nor comprehensive immersion in the DL technologies. Our goal being just showcasing person detection on edge devices – not creating the best CNN in the world – we’ll take the easy way.

However, even our "easy" way requires the use of specialized computer vision and DL software, as well as writing bespoke computer code. We’ll use Python along with OpenCV as a computer vision system. First, we’ll write the Python code using CNNs and OpenCV and testing them for detection of humans in images.

Then, we’ll write more code – for launching person detection on a Raspberry Pi 3 Model B device. We hope you’ll follow along; if you do, you’ll need to install OpenCV for Python on your computer.

This article is part of the series 'Realtime AI Person Detection on Edge Devices View All

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Team Leader VIPAKS
Russian Federation Russian Federation
EDUCATION:

Master’s degree in Mechanics.

PhD degree in Mathematics and Physics.



PROFESSIONAL EXPERIENCE:

15 years’ experience in developing scientific programs
(C#, C++, Delphi, Java, Fortran).



SCIENTIFIC INTERESTS:

Mathematical modeling, symbolic computer algebra, numerical methods, 3D geometry modeling, artificial intelligence, differential equations, boundary value problems.

Comments and Discussions

 
QuestionBespoke Pin
TheDadman6-Oct-20 10:07
TheDadman6-Oct-20 10:07 
I am terrible with names, but I swear by words, pun of sorts. Anyway, you used the word "bespoke" in this article on ML and AI. I have something like one hundred and fifty or so emails a week on software, and I don't read anywhere near all of them, but, I am told that I know a lot of words, and some of even are the the good ones. I had to look up Bespoke.

However, I didn't look it up in this article. I looked it up in another article but an author whose name totally escapes me. Honestly though, what are the odds that there are two men in the world running around writing C++ articles on machine learning for The Daily Build. The earlier article was on Neural Nets, it was a fascinating read and it actually got me to copy code, which is not something I do very often.

I await the following article in this series.

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.