前言
深度學習模型部署有OpenVINO、ONNXRUNTIME、TensorRT三個主流框架,均支持Python與C++的SDK使用。對YOLOv5~YOLOv8的系列模型,均可以通過C++推理實現模型部署。這里以YOLOv8為例,演示了YOLOv8對象檢測模型在OpenVINO、ONNXRUNTIME、TensorRT三個主流框架上C++推理演示效果。所有測試均基于我筆記本電腦,相關的硬件配置如下:
CPU i7 GPU3050ti Win10 64
代碼演示
OpenVINO + CPU部署、ONNXRUNTIME + GPU部署、TensorRT + GPU部署YOLOv8對象檢測代碼已經封裝成C++類,通過客戶端三行代碼即可調用,演示效果分別如下:
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; }
審核編輯:湯梓紅
-
封裝
+關注
關注
127文章
7991瀏覽量
143395 -
gpu
+關注
關注
28文章
4772瀏覽量
129349 -
C++
+關注
關注
22文章
2114瀏覽量
73854 -
模型
+關注
關注
1文章
3304瀏覽量
49216 -
代碼
+關注
關注
30文章
4825瀏覽量
69035
原文標題:三種主流模型部署框架YOLOv8推理演示
文章出處:【微信號:CVSCHOOL,微信公眾號:OpenCV學堂】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
【愛芯派 Pro 開發板試用體驗】yolov8模型轉換
在AI愛克斯開發板上用OpenVINO?加速YOLOv8分類模型
![在AI愛克斯開發板上用OpenVINO?加速<b class='flag-5'>YOLOv8</b>分類<b class='flag-5'>模型</b>](https://file1.elecfans.com/web2/M00/82/79/wKgZomRUfNiABd-qAAAT5AAjKtc607.png)
在AI愛克斯開發板上用OpenVINO?加速YOLOv8目標檢測模型
![在AI愛克斯開發板上用OpenVINO?加速<b class='flag-5'>YOLOv8</b>目標檢測<b class='flag-5'>模型</b>](https://file1.elecfans.com/web2/M00/82/B1/wKgZomRdkeGAd8S2AAAm8DCq3H4572.png)
AI愛克斯開發板上使用OpenVINO加速YOLOv8目標檢測模型
![AI愛克斯開發板上使用OpenVINO加速<b class='flag-5'>YOLOv8</b>目標檢測<b class='flag-5'>模型</b>](https://file1.elecfans.com/web2/M00/88/B7/wKgaomRwIXSAVKmcAAAm8DCq3H4143.png)
OpenCV4.8+YOLOv8對象檢測C++推理演示
![OpenCV4.8+<b class='flag-5'>YOLOv8</b>對象檢測C++<b class='flag-5'>推理</b><b class='flag-5'>演示</b>](https://file1.elecfans.com/web2/M00/A6/4A/wKgaomUTnKaAcPtnAAAnAPpreBA561.png)
基于OpenCV DNN實現YOLOv8的模型部署與推理演示
![基于OpenCV DNN實現<b class='flag-5'>YOLOv8</b>的<b class='flag-5'>模型</b><b class='flag-5'>部署</b>與<b class='flag-5'>推理</b><b class='flag-5'>演示</b>](https://file1.elecfans.com/web2/M00/C2/4A/wKgZomXhidOAS5bgAAA85lM3BAY512.png)
評論