Object segmentation engine using TensorRT for optimized inference.
- Export YOLO model to ONNX:
python3 -m venv venv
./venv/bin/pip3 install ultralytics onnx onnxsimmkdir data
./venv/bin/yolo export --model=data/yolo11n-seg.pt --format=onnx --opset=12- Convert to TensorRT engine:
trtexec --onnx=data/yolo11n-seg.onnx --saveEngine=data/yolo11n-seg.engine --fp16In data folder, add your config.json:
YOLOv8
{
"segmenter": {
"architecture": "yolo",
"name": "yolov8",
"confidence_threshold": 0.25,
"nms_threshold": 0.45,
"engine": {
"model_path": "./data/yolov8n-seg.engine",
"batch_size": 1,
"precision": 16
},
"class_names": [
// fill in the class names
]
}
}YOLOv11
{
"segmenter": {
"architecture": "yolo",
"name": "yolov11",
"confidence_threshold": 0.25,
"nms_threshold": 0.45,
"engine": {
"model_path": "./data/yolo11n-seg.engine",
"batch_size": 1,
"precision": 16
},
"class_names": [
// fill in the class names
]
}
}# in root directory
meson setup build -Dbuild_apps=segmenter
meson compile -C build# in root directory
cd build/app/segmenter
./segment -i 0 -o data/webcam.mp4 -c data/config.json -d