前言
深度學習模型部署有OpenVINO、ONNXRUNTIME、TensorRT三個主流框架,均支持Python與C++的SDK使用。對YOLOv5~YOLOv8的系列模型,均可以通過C++推理實現(xiàn)模型部署。這里以YOLOv8為例,演示了YOLOv8對象檢測模型在OpenVINO、ONNXRUNTIME、TensorRT三個主流框架上C++推理演示效果。所有測試均基于我筆記本電腦,相關(guān)的硬件配置如下:
CPU i7 GPU3050ti Win10 64
代碼演示
OpenVINO + CPU部署、ONNXRUNTIME + GPU部署、TensorRT + GPU部署YOLOv8對象檢測代碼已經(jīng)封裝成C++類,通過客戶端三行代碼即可調(diào)用,演示效果分別如下:
OpenVINO + CPU YOLOv8對象檢測推理
ONNXRUNTIME + GPU YOLOv8對象檢測推理
TensorRT + GPU YOLOv8對象檢測推理
客戶端初始化代碼如下: 初始化OpenVINO+YOLOv8封裝類實例
std::shared_ptrdetector(new YOLOv8OpenVINODetector());初始化ONNXRUNTIEM+YOLOv8封裝類實例
std::shared_ptrdetector(new YOLOv8ORTDetector());初始化TensorRT+YOLOv8封裝類實例
std::shared_ptrdetector(new YOLOv8TRTDetector());客戶端推理代碼如下:
detector->initConfig("D:/python/my_yolov8_train_demo/yolov8n.engine", 0.4, 0.25f); cv::VideoCapture capture("D:/bird_test/Pexels_Videos_2670.mp4"); cv::Mat frame; std::vectorresults; while (true) { bool ret = capture.read(frame); if (frame.empty()) { break; } detector->detect(frame, results); for (DetectResult dr : results) { cv::Rect box = dr.box; cv::putText(frame, classNames[dr.classId], cv::Point(box.tl().x, box.tl().y - 10), cv::FONT_HERSHEY_SIMPLEX, .5, cv::Scalar(0, 0, 0)); } cv::imshow("YOLOv8 + TensorRT - by gloomyfish", frame); char c = cv::waitKey(1); if (c == 27) { // ESC 退出 break; } // reset for next frame results.clear(); } return 0; }
審核編輯:湯梓紅
-
封裝
+關(guān)注
關(guān)注
126文章
7873瀏覽量
142893 -
gpu
+關(guān)注
關(guān)注
28文章
4729瀏覽量
128890 -
C++
+關(guān)注
關(guān)注
22文章
2108瀏覽量
73618 -
模型
+關(guān)注
關(guān)注
1文章
3226瀏覽量
48807 -
代碼
+關(guān)注
關(guān)注
30文章
4779瀏覽量
68521
原文標題:三種主流模型部署框架YOLOv8推理演示
文章出處:【微信號:CVSCHOOL,微信公眾號:OpenCV學堂】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論