Using OpenCV to capture video from camera or video file, then use YOLOv8 TensorRT to detect objects and DeepSORT TensorRT or BYTETrack to track objects.
Support for both NVIDIA dGPU and Jetson devices.
Using OpenCV to capture video from camera or video file, then use YOLOv8 TensorRT to detect objects and DeepSORT TensorRT to track objects.
| Model | Device | FPS | 
|---|---|---|
| OpenCV + YOLOv8n + DeepSORT | NVIDIA dGPU GTX 1660Ti 6Gb | ~ | 
| OpenCV + YOLOv8n + DeepSORT | NVIDIA Jetson Xavier NX 8Gb | ~ | 
| OpenCV + YOLOv8n + DeepSORT | NVIDIA Jetson Orin Nano 8Gb | ~34 | 
Test speed of YOLOv8 TensorRT model using trtexec from TensorRT
/usr/src/tensorrt/bin/trtexec on NVIDIA Jetson
batch size = 1
| Model | Device | Throughput (qps) | Latency(ms) | 
|---|---|---|---|
| yolov8n.engine | NVIDIA dGPU GTX 1660Ti 6Gb | ~419.742 | ~2.91736 | 
| yolov8n.engine | NVIDIA Jetson Xavier NX 8Gb | ~ | ~ | 
| yolov8n.engine | NVIDIA Jetson Orin Nano 8Gb | ~137.469 | ~137.469 | 
Test speed of DeepSORT TensorRT model using trtexec from TensorRT
/usr/src/tensorrt/bin/trtexec on NVIDIA Jetson
batch size = 1
| Model | Device | Throughput (qps) | Latency(ms) | 
|---|---|---|---|
| deepsort.engine | NVIDIA dGPU GTX 1660Ti 6Gb | ~614.738 | ~1.52197 | 
| deepsort.engine | NVIDIA Jetson Xavier NX 8Gb | ~ | ~ | 
| deepsort.engine | NVIDIA Jetson Orin Nano 8Gb | ~546.135 | ~1.82227 | 
- NVIDIA CUDA: 11.4
- NVIDIA TensorRT: 8.5.2
Clone repository and submodules
git clone --recurse-submodules https://github.com/nabang1010/YOLOv8_DeepSORT_TensorRT.git
Create new enviroment
conda create -n yolov8_ds python=3.8
Activate enviroment
conda activate yolov8_ds
Go to refs/YOLOv8-TensorRT and install requirements for exporting models
cd refs/YOLOv8-TensorRT
pip3 install -r requirements.txt
pip3 install tensorrt easydict pycuda lap cython_bboxInstall python3-libnvinfer
sudo apt-get install python3-libnvinfer
Download YOLOv8 weights from ultralytics here: yolov8n.pt and save in folder models/to_export
Export YOLOv8 ONNX model
In refs/YOLOv8-TensorRT run the following command to export YOLOv8 ONNX model
python3 export-det.py \ --weights ../../models/to_export/yolov8n.pt \ --iou-thres 0.65 \ --conf-thres 0.25 \ --topk 100 \ --opset 11 \ --sim \ --input-shape 1 3 640 640 \ --device cuda:0
The output .onnx model will be saved in models/to_export folder, move the model to models/onnx folder
mv ../../models/to_export/yolov8n.onnx ../../models/onnx/yolov8n.onnx
Export YOLOv8 TensorRT model
In refs/YOLOv8-TensorRT run the following command to export YOLOv8 TensorRT model
python3 build.py \ --weights ../../models/onnx/yolov8n.onnx \ --iou-thres 0.65 \ --conf-thres 0.25 \ --topk 100 \ --fp16 \ --device cuda:0
The output .engine model will be saved in models/onnx folder, move the model to models/trt folder
mv ../../models/onnx/yolov8n.engine ../../models/engine/yolov8n.engine
Build OpenCV
bash build_opencv.sh
Export DeepSORT TensorRT model (if use BYTETrack, ignore this step)
Install libeigen3-dev
apt-get install libeigen3-dev
Go to refs/deepsort_tensorrt and run the following command to build onnx2engine
cd refs/deepsort_tensorrt mkdir build cd build cmake .. make -j$(nproc)
If catch error
fatal error: Eigen/Core: No such file or directory, replace#include <Eigen/*>with#include <eigen3/Eigen/*>in all files of this repo (datatype.h,kalmanfilter.cpp) and rebuild again.
If catch error
error: looser exception specification on overriding virtual function 'virtual void Logger::log(nvinfer1::ILogger::Severityaddnoexceptbeforeoverrideinlogger.hline 239 and rebuild again.
Run following command to export DeepSORT TensorRT model
./build/onnx2engine ../../models/onnx/deepsort.onnx ../../models/engine/deepsort.engine
Go to src folder
cd srcRun YOLOv8 + DeepSORT
python3 yolov8_deepsort_trt.py --show
Run YOLOv8 + BYTETrack
python3 yolov8_bytetrack_trt.py --show
Coming soon