前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >大意了| ONNXRUNTIME C++ 版本推理部署踩坑记录

大意了| ONNXRUNTIME C++ 版本推理部署踩坑记录

作者头像
OpenCV学堂
发布2022-03-29 15:40:11
6.5K1
发布2022-03-29 15:40:11
举报

点击上方蓝字关注我们

微信公众号:OpenCV学堂 关注获取更多计算机视觉与深度学习知识

前言

    之前我安装了CUDA10.0跟cuDnn7.6.5 然后我在VS2017中配置了包含路径、库路径跟连接器,把环境变量加上,重启一下就可以运行onnxruntime-1.4 gpu版本,用YOLOv5导出onnx格式模型,跑的很欢畅。

代码语言:javascript
复制
-VS2017-CUDA10.1-cuDnn7.6.5-onnxruntime-1.4-gpu

Faster-RCNN转ONNX

周末的时候我想试试tensorRT+YOLOv5最新版本,就把CUDA升级到11.02了,然后cuDnn改到8.3.2,然后我发现官方没有对应编译好的onnxruntime-gpu版本,就下载了onnxruntime1.7 CPU版本,跟以前的配置又走了一次,结果我得到下面的错误:

(进程 9336)已退出,返回代码为: -1073741701。

代码语言:javascript
复制
-VS2017-cuda11.0.2-cudnn8.3.2-onnxruntime1.7-cpu-python3.6.5

然后我发现只要不引用onnxruntime就没事,用了就无法启动,百度一搜索各种说法的都有,总结最关键一条,DLL加载失败了,有些依赖没有找到,然后我直接用dumpbin.exe分析依赖一波,发现这些DLL都有啊,怀疑人生ing~~~~~~

然后就开始疯狂各种版本测试,结果还是这个错误!

折腾了一天,到晚上问了两个人,都建议我直接onnxruntime相关的lib跟dll文件copy到编译的exe目录下,还配置个毛线环境变量!然后我照做了,死马当活马医!然后居然奇迹出现了,正常启动了,可以跑了,有图为证

代码语言:javascript
复制
std::shared_ptr<YOLOv5ORTDetector> detector(new YOLOv5ORTDetector());
std::vector<DetectResult> results;
detector->initConfig("D:/python/yolov5-6.1/yolov5s.onnx", 0.4, 0.25f);
cv::VideoCapture capture("D:/images/video/sample.mp4");
cv::Mat frame;
while (true) {
    bool ret = capture.read(frame);
    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("YOLOv5-6.1 + ONNXRUNTIME1.7 - by gloomyfish", frame);
    char c = cv::waitKey(1);
    if (c == 27) { // ESC 退出
        break;
    }
    // reset for next frame
    results.clear();
}

总结

遇见此错误,直接无脑copy dll跟lib文件到exe目录下就好啦!

必须说三遍!

别多想,操作系统跟VS配置有时候没那么靠谱:

(进程 9336)已退出,返回代码为: -1073741701。

扫码查看OpenCV+Pytorch系统化学习路线图

 推荐阅读 

CV全栈开发者说 - 从传统算法到深度学习怎么修炼

2022入坑深度学习,我选择Pytorch框架!

Pytorch轻松实现经典视觉任务

教程推荐 | Pytorch框架CV开发-从入门到实战

OpenCV4 C++学习 必备基础语法知识三

OpenCV4 C++学习 必备基础语法知识二

OpenCV4.5.4 人脸检测+五点landmark新功能测试

OpenCV4.5.4人脸识别详解与代码演示

OpenCV二值图象分析之Blob分析找圆

OpenCV4.5.x DNN + YOLOv5 C++推理

OpenCV4.5.4 直接支持YOLOv5 6.1版本模型推理

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-03-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 OpenCV学堂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
人脸识别
腾讯云神图·人脸识别(Face Recognition)基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、比对、搜索、验证、五官定位、活体检测等多种功能,为开发者和企业提供高性能高可用的人脸识别服务。 可应用于在线娱乐、在线身份认证等多种应用场景,充分满足各行业客户的人脸属性识别及用户身份确认等需求。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档