[C++]使用纯opencv部署yolov8-cls图像分类onnx模型

【算法介绍】

使用纯OpenCV部署YOLOv8-cls图像分类ONNX模型涉及几个关键步骤。

首先,你需要将YOLOv8-cls模型从PyTorch格式转换为ONNX格式,这是为了确保模型在不同深度学习框架之间的互操作性。这个转换过程通常是通过ultralytics框架中的model.export方法完成的,你需要指定输出格式为ONNX,并设置输入图像的尺寸和opset版本。

接下来,配置OpenCV环境以支持ONNX模型的读取和推理。你需要确保OpenCV的版本至少为4.7.0,因为该版本及以上提供了对ONNX模型的全面支持。然后,你可以使用OpenCV的dnn模块中的readNetFromONNX函数来加载ONNX模型。

加载模型后,你可以对输入图像进行预处理,如调整图像大小和归一化,然后使用模型进行推理。推理的结果是一个包含分类信息的数组,你需要根据这些信息来确定图像的分类结果。

最后,你可以将分类结果以文本或图形的形式展示在图像上,或者使用其他方式进行处理。

使用纯OpenCV部署YOLOv8-cls图像分类ONNX模型的优势在于,OpenCV是一个广泛使用的计算机视觉库,它提供了丰富的图像处理和分析功能,同时支持跨平台和设备部署。这使得YOLOv8-cls模型能够在不同的环境中实现高效和准确的图像分类。

【效果展示】

【实现部分代码】

复制代码
#include <iostream>
#include<opencv2/opencv.hpp>
#include<math.h>
#include<time.h>
#include "yolov8_cls.h"
using namespace std;
using namespace cv;
using namespace dnn;

int main(int argc,char* argv[]) {
	
	
    if(argc==1)
	{
		cout<<"please input the image path"<<endl;
		return 0;
	}
	
	string img_path = argv[1];
	string cls_model_path = "yolov8s-cls.onnx";
	Mat img = imread(img_path);
	Yolov8ClsOnnx cls_net;
	cls_net.LoadWeights(cls_model_path);
	auto result = cls_net.Inference(img);
	cout << result.class_name<<"===>"<<std::to_string(result.confidence) << endl;
	getchar();
	return 0;
}

【测试环境】

vs2019

cmake==3.24.3

opencv==4.8.0

【运行步骤】

通过cmake编译出exe后,执行

yolov8-cls.exe 【图片路径】即可

【完整源码下载】

https://download.csdn.net/download/FL1623863129/89853564

相关推荐
Mortalbreeze几秒前
C++11 ---- 右值引用、值类型
开发语言·c++
少司府2 分钟前
C++进阶:多态
c语言·开发语言·c++·多态·抽象类·虚函数·虚表指针
并不喜欢吃鱼2 分钟前
从零开始 C++----- 十三【C++ 数据结构】哈希表从原理到手撕实现(开放定址 + 链地址全覆盖)
数据结构·c++·散列表
愿天垂怜3 分钟前
【C++脚手架】etcd 的介绍与使用
java·linux·服务器·c语言·c++·中间件·etcd
小则又沐风a9 分钟前
进程篇: 进程概念的补充(了解环境变量和虚拟地址空间)
linux·运维·服务器·c++
郝学胜-神的一滴9 分钟前
[简化版 GAMES 101] 计算机图形学 11:频域·卷积·抗锯齿
c++·unity·图形渲染·opengl·three·unreal
valan liya11 分钟前
C++ 继承
开发语言·c++
毕设做完了吗?13 分钟前
YOLO+paddlecor的智能车牌识别系统
人工智能·python·yolo·目标检测·计算机视觉
噜噜大王_17 分钟前
C++ 类和对象(下):初始化列表、static、友元与匿名对象全解
c++
lDevinl19 分钟前
【无标题】
数据结构·c++·青少年编程