The purpose of this little project is to add object tracking to yolov2 and achieve real-time multiple object tracking.
The current architecture is set to only track one type of objects, but it should be easy to generalise over all objects.
Currently support people tracking (as the provided weights for deep_sort were trained on people tracking)
python
numpy
opencv 3
tensorflow 1.0
Cython.
sklean.
for using sort :
1 - Clone this repository : git clone https://github.com/bendidi/Tracking-with-darkflow.git
2 - Initialize all submodules: git submodule update --init --recursive
3 - Go to darkflow directory and do in place build: python3 setup.py build_ext --inplace
Download the weights :
Read more about YOLO (in darknet) and download weight files here,In case the weight file cannot be found, thtrieu has uploaded some of his here, which include yolo-full
and yolo-tiny
of v1.0, tiny-yolo-v1.1
of v1.1 and yolo
, tiny-yolo-voc
of v2.
The artchitecture I used/tested in this project is cfg/yolo.cfg
with the weights bin/yolo.weights
.
Next you need to download the deep_sort weights here (networks folder), provided by nwojke
extract the folder and copy it to deep_sort/resources
Edit Flags in run.py
following your configuration :
-
demo
: path to video file to use, set to "camera" if you wish to use your camera -
model
: what model configuration to use for YOLO, you can get more information and .cfg files in here(put them in darkflow/cfg/ folder) -
load
: The corresponding weights to use with the chosen model (put them in darkflow/bin/) more info in here -
threshold
: the confidance threshold of the YOLO detections -
gpu
: How much GPU to use, 0 means use cpu -
track
: to activate tracking or Not -
trackObj
: which object to track (notice that deep_sort's encoder was only trained on people , so you need train your own encoder, more information in here) -
saveVideo
: whether to save video or not -
BK_MOG
: add opencv's MOG background subtraction module, only useful when YOLO can't detect people in a video (low quality, ...) use it to detect boxes around moving objects -
tracker
: which tracker to use : "deep_sort" or "sort"**NOTE** : "deep_sort" only supports people tracking as it was only trained to track people(the code for training is not yet published) **TODO** : add support for GOTURN tracker(tensorflow implementation) **TODO** : add support for opencv trackers (MIL,KCF,TLD,MEDIANFLOW)
-
skip
: skip frames to increase fps, might decrease accuracy ! -
csv
: save csv file of detections in the format (frame_id,object_id,x,y,w,h) -
display
: display video while processing or Not
Next you just have to run python run.py
, and enjoy !
`speed using yolo.cfg:
YOLO with track Flag set to False : 30fps
YOLO with track Flag set to True (deep_sort) : 14 fps
YOLO with track and background subtraction Flags set to Ture : 10.5 fps
Tests done on (1024, 1280, 3) resolution video on Nvidia GTX 1080
skipping up to 3 frames allows for more speed up while keeping accuracy of tracking`
this project is using code forked from:
thtrieu/darkflow: for the real-time object detections and classifications.
nwojke/deep_sort: for Simple Online Realtime Tracking with a Deep Association Metric.
Please follow the links to get an understanding of all the features of each project.
@article{redmon2016yolo9000,
title={YOLO9000: Better, Faster, Stronger},
author={Redmon, Joseph and Farhadi, Ali},
journal={arXiv preprint arXiv:1612.08242},
year={2016}
}
@article{Wojke2017simple,
title={Simple Online and Realtime Tracking with a Deep Association Metric},
author={Wojke, Nicolai and Bewley, Alex and Paulus, Dietrich},
journal={arXiv preprint arXiv:1703.07402},
year={2017}
}
@inproceedings{Bewley2016_sort,
author={Bewley, Alex and Ge, Zongyuan and Ott, Lionel and Ramos, Fabio and Upcroft, Ben},
booktitle={2016 IEEE International Conference on Image Processing (ICIP)},
title={Simple online and realtime tracking},
year={2016},
pages={3464-3468},
keywords={Benchmark testing;Complexity theory;Detectors;Kalman filters;Target tracking;Visualization;Computer Vision;Data Association;Detection;Multiple Object Tracking},
doi={10.1109/ICIP.2016.7533003}
}