前言
深度学习模型部署有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文章
9395浏览量
149233 -
gpu
+关注
关注
28文章
5335浏览量
136238 -
C++
+关注
关注
22文章
2139浏览量
77500 -
模型
+关注
关注
1文章
3879浏览量
52355 -
代码
+关注
关注
30文章
4985浏览量
74568
原文标题:三种主流模型部署框架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模型的卓越性能使其在多个领域具有广泛的应用前景,如自动驾
瑞芯微(EASY EAI)RV1126B yolov8训练部署教程
表现,Yolov8在还没有开源时就收到了用户的广泛关注。其主要结构如下图所示:本教程针对目标检测算法yolov8的训练和部署到EASY-EAI-Nano-TB(R
三种主流模型部署框架YOLOv8推理演示
评论