YOLOV8目标检测C++推理问题总结

背景

数据集有限,使用paddleOCR直接识别准确率无法达到99%,这里尝试用目标检测对识别得分比较低的图片进行二次处理;

类别数目:数字(10)+字母(26)+字符(2)= 38

数据集标注跟训练过程这里使用自己开发的软件;

标注格式与labelimg一致,使用官网方法训练效果也一样;yolo目标检测官网

具体参考官方代码,这里记录注意事项(VS2019 + Qt);

推理参考:https://github.com/ultralytics/ultralytics/tree/main/examples

一、使用OpenCV的DNN

二、ONNXRuntime

三、Libtorch

libtorch 1.13.0

cpu-release:
https://download.pytorch.org/libtorch/cpu/libtorch-win-shared-with-deps-1.13.0%2Bcpu.zip

bash 复制代码
opencv_world490.lib
asmjit.lib
c10.lib
clog.lib
torch.lib
torch_cpu.lib

报错:#error: Macro clash with min and max -- define NOMINMAX when compiling your program on Windows

解决:Qt的slot冲突

注意把#include <torch/torch.h>放到include "opencv.hpp"前面,不然也会冲突报错。

四、OpenVINO

没有试,转换时需要先转为onnx再转为openvino 下载OpenVINO™ toolkit

问题:如图,针对同一张图片,上图为python直接预测的结果,下图为OpenCV的DNN推理结果(ONNXRuntime也和下图差不多),和结果差异很大,原因未知。

最后使用Libtorch推理,效果可以。

相关推荐
睡不醒的kun1 小时前
leetcode算法刷题的第二十一天
数据结构·c++·算法·leetcode·职场和发展·回溯算法·回归算法
小欣加油1 小时前
leetcode 461 汉明距离
c++·算法·leetcode
淮北4941 小时前
linux系统学习(15.启动管理)
运维·服务器·网络·c++·vscode·学习
mit6.8241 小时前
[游戏中的空间划分] KD树|四叉树|价格系统
c++·游戏·游戏程序
三小尛3 小时前
C++继承
开发语言·c++
WSSWWWSSW4 小时前
Python OpenCV图像处理与深度学习:Python OpenCV入门-图像处理基础
图像处理·python·opencv
小苏兮5 小时前
【C++】类与对象(上)
开发语言·c++·学习
大龄门外汉6 小时前
CPP学习之map和set
c++·笔记·学习·stl·set·map·改行学it
上官鹿离6 小时前
C++学习笔记之输入输出流
c++·笔记·学习
小乖兽技术7 小时前
C#与C++交互开发系列(三十):C#非托管内存分配大比拼,哪种方式才是真正的性能王者?
c++·c#·交互