前言
深度學(xué)習(xí)模型部署有OpenVINO、ONNXRUNTIME、TensorRT三個(gè)主流框架,均支持Python與C++的SDK使用。對(duì)YOLOv5~YOLOv8的系列模型,均可以通過(guò)C++推理實(shí)現(xiàn)模型部署。這里以YOLOv8為例,演示了YOLOv8對(duì)象檢測(cè)模型在OpenVINO、ONNXRUNTIME、TensorRT三個(gè)主流框架上C++推理演示效果。所有測(cè)試均基于我筆記本電腦,相關(guān)的硬件配置如下:
CPU i7 GPU3050ti Win10 64
代碼演示
OpenVINO + CPU部署、ONNXRUNTIME + GPU部署、TensorRT + GPU部署YOLOv8對(duì)象檢測(cè)代碼已經(jīng)封裝成C++類,通過(guò)客戶端三行代碼即可調(diào)用,演示效果分別如下:
OpenVINO + CPU YOLOv8對(duì)象檢測(cè)推理
ONNXRUNTIME + GPU YOLOv8對(duì)象檢測(cè)推理
TensorRT + GPU YOLOv8對(duì)象檢測(cè)推理
客戶端初始化代碼如下: 初始化OpenVINO+YOLOv8封裝類實(shí)例
std::shared_ptrdetector(new YOLOv8OpenVINODetector());初始化ONNXRUNTIEM+YOLOv8封裝類實(shí)例
std::shared_ptrdetector(new YOLOv8ORTDetector());初始化TensorRT+YOLOv8封裝類實(shí)例
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)注
128文章
8626瀏覽量
145199 -
gpu
+關(guān)注
關(guān)注
28文章
4930瀏覽量
130991 -
C++
+關(guān)注
關(guān)注
22文章
2119瀏覽量
75040 -
模型
+關(guān)注
關(guān)注
1文章
3507瀏覽量
50252 -
代碼
+關(guān)注
關(guān)注
30文章
4895瀏覽量
70499
原文標(biāo)題:三種主流模型部署框架YOLOv8推理演示
文章出處:【微信號(hào):CVSCHOOL,微信公眾號(hào):OpenCV學(xué)堂】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
基于YOLOv8實(shí)現(xiàn)自定義姿態(tài)評(píng)估模型訓(xùn)練

使用YOLOv8做目標(biāo)檢測(cè)和實(shí)例分割的演示
YOLOv8自定義數(shù)據(jù)集訓(xùn)練到模型部署推理簡(jiǎn)析
TensorRT 8.6 C++開(kāi)發(fā)環(huán)境配置與YOLOv8實(shí)例分割推理演示

在AI愛(ài)克斯開(kāi)發(fā)板上用OpenVINO?加速YOLOv8分類模型

在AI愛(ài)克斯開(kāi)發(fā)板上用OpenVINO?加速YOLOv8目標(biāo)檢測(cè)模型

AI愛(ài)克斯開(kāi)發(fā)板上使用OpenVINO加速YOLOv8目標(biāo)檢測(cè)模型

教你如何用兩行代碼搞定YOLOv8各種模型推理

解鎖YOLOv8修改+注意力模塊訓(xùn)練與部署流程

OpenCV4.8+YOLOv8對(duì)象檢測(cè)C++推理演示

基于YOLOv8的自定義醫(yī)學(xué)圖像分割

基于OpenCV DNN實(shí)現(xiàn)YOLOv8的模型部署與推理演示

RV1126 yolov8訓(xùn)練部署教程

RV1126 yolov8訓(xùn)練部署教程

評(píng)論