DeepSORT basically is an improvement based on SORT which integrated a CNN feature extractor that helps reduce ID-switch problem in SORT. This CNN model acts as a ReID model which extracts features for each object that has been detected by an object detection model, then those features are used for assignment problems. This indeed helps reduce ID-switch problems a lot!
For each object detected in the previous frame, Kalman Filter will predict its new position in the adjacent frame. Then for each object that has been detected by the Object Detection Model, it will be assigned to its prediction by the similarity between its CNN feature.
For occlusion objects, DeepSORT counts the number of frames it disappears. If it is less than 30 frames, the trajectory is still keeping, otherwise delete that trajectory.
This repository contains an implementation of DeepSORT for Pedestrian Tracking in surveillance camera. Use Yolov5 to detect pedestrian and OpenCV to process video. The input is a video or webcam(by default), the output is the video which has the detected objects and its relative ID.
- Clone this repository
git clone https://github.com/tien02/TrackingwYolov5DeepSORT.git
- Create virtual environment (venv), then activate it.
python -m venv your_venv
- Install dependencies
pip install -r requirements.txt
- Run demo, run --help for more details
python tracking.py [-h]
[--config]
[--weight]
[--source]
[--display]
[--save]
Use --display
to enable display.
Use --save
to save video. Video will be saved to result/your_video_name.avi
.
- Paper: Simple Online and Realtime Tracking with a Deep Association Metric
- DeepSORT code: ZQPei/deep_sort_pytorch
- Yolov5 code: ultralytics/yolov5