前言
深度學習模型部署有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::vector results;
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;
}
審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
封裝
+關注
關注
128文章
9248瀏覽量
148614 -
gpu
+關注
關注
28文章
5194瀏覽量
135431 -
C++
+關注
關注
22文章
2123瀏覽量
77110 -
模型
+關注
關注
1文章
3751瀏覽量
52099 -
代碼
+關注
關注
30文章
4967瀏覽量
73960
原文標題:三種主流模型部署框架YOLOv8推理演示
文章出處:【微信號:CVSCHOOL,微信公眾號:OpenCV學堂】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
熱點推薦
求助,關于K230部署yolov8時遇到問題求解
使用yolov8訓練出來了一個十個類別的模型并且按照要求轉換成了.kmodel模型,在部署到K230時 使用yolo大作戰里面的代碼提示我list out of range但是我看了我
發表于 08-12 07:26
在AI愛克斯開發板上用OpenVINO?加速YOLOv8目標檢測模型
《在 AI 愛克斯開發板上用 OpenVINO 加速 YOLOv8 分類模型》介紹了在 AI 愛克斯開發板上使用 OpenVINO 開發套件部署并測評 YOLOv8 的分類
AI愛克斯開發板上使用OpenVINO加速YOLOv8目標檢測模型
《在AI愛克斯開發板上用OpenVINO加速YOLOv8分類模型》介紹了在AI愛克斯開發板上使用OpenVINO 開發套件部署并測評YOLOv8的分類
OpenCV4.8+YOLOv8對象檢測C++推理演示
自從YOLOv5更新成7.0版本,YOLOv8推出以后,OpenCV4.6以前的版本都無法再加載導出ONNX格式模型了,只有OpenCV4.7以上版本才可以支持最新版本YOLOv5與
基于OpenCV DNN實現YOLOv8的模型部署與推理演示
基于OpenCV DNN實現YOLOv8推理的好處就是一套代碼就可以部署在Windows10系統、烏班圖系統、Jetson的Jetpack系統
RV1126 yolov8訓練部署教程
YOLOv8 是 ultralytics 公司在 2023 年 1月 10 號開源的基于YOLOV5進行更新的 下一個重大更新版本,目前支持圖像分類、物體檢測和實例分割任務,鑒于Yolov5的良好表現,
使用ROCm?優化并部署YOLOv8模型
://github.com/ultralytics/ultralytics/tree/main YOLOv8模型的卓越性能使其在多個領域具有廣泛的應用前景,如自動駕
三種主流模型部署框架YOLOv8推理演示
評論