Small proof of concept of a software that evaluates distance of the subjects it captures from the camera and the relative distance between them. The distance of the subjects is calculated using triangle similarity (further info in the triangular similarity section)
Before starting, be sure to have python 3
and pip
installed, then run
pip3 install -r requirements.txt
First you need to do the calibration phase
python3 social_distancing.py calibrate --help
usage: social_distancing.py calibrate [-h] --distance DISTANCE [--videocameraindex VIDEOCAMERAINDEX]
optional arguments:
-h, --help show this help message and exit
--distance DISTANCE, -d DISTANCE
Distance of the calibration face from camera
--videocameraindex VIDEOCAMERAINDEX, -v VIDEOCAMERAINDEX
Video camera index
Get the distance between the subject's face and the camera (ie 30 cm) and run
python3 social_distancing.py calibrate -d 30
Don't move the subject until the percentage is 100% then take the number printed ad the end as your calibration value
python3 social_distancing.py calibrate -d 30
100.0%
10385
Now you have all the data you need, we can now run the actual software.
python3 social_distancing.py run --help
usage: social_distancing.py run [-h] --calibrationresult CALIBRATIONRESULT [--threshold THRESHOLD] [--inches] [--videocameraindex VIDEOCAMERAINDEX]
optional arguments:
-h, --help show this help message and exit
--calibrationresult CALIBRATIONRESULT, -c CALIBRATIONRESULT
Result from the calibration operation.
--threshold THRESHOLD, -t THRESHOLD
Threshold value to trigger alarm
--inches
--videocameraindex VIDEOCAMERAINDEX, -v VIDEOCAMERAINDEX
Video camera index
Example
python3 social_distancing.py run -c 10385
Enjoy.
The triangle similarity () is calculated using the detected subject width in pixel (), the known width of the subject () and the known distance from the camera () as:
We can use this data to calculate any later distance () using the new subject width in pixel () as:
If we replace S from the previous formula
If we approximate the width of any subject as similar
So our Calibration number could be defined as
Often OpenCV hangs in the closing phase, so the process must be manually killed.
I'm almost sure it is a dumb problem in my code, but I cannot find the cause.
Assuming that every possible face have the same width is a very bold assumption. We should find something that OpenCV can reliably detect and, at the same time, is more universally constant that face width (ie pupil distance). Until we found something like that, this software can not be considered 100% reliable.