Qt调用Yolov11导出的Onnx分类模型开发分类检测软件

软件视频地址:视频地址

代码开源地址

  1. 之前用Python配合YOLOV11开发一个了分类训练软件,软件只要准备好数据,然后导入就可以训练数据,训练完成后还可以验证,测试,但是要真正落地,还是有点欠缺。
  2. 配合YOLOV11训练后导出的onnx模型,再开发一个Qt软件,主要是调用onnx模型。
  3. 软件界面

请添加图片描述
请添加图片描述
4. 软件运行效果

请添加图片描述
请添加图片描述
5. 核心代码

  /***创建一个环境****/_env=Ort::Env(ORT_LOGGING_LEVEL_ERROR, "OnnxModel");/***初始化Session选项 使用10个线程执行op,若想提升速度,增加线程数***/_session_options.SetInterOpNumThreads(1);/***ORT_ENABLE_ALL: 启用所有可能的优化***///session_options.SetGraphOptimizationLevel(GraphOptimizationLevel::ORT_ENABLE_ALL);_session_options.SetGraphOptimizationLevel( GraphOptimizationLevel::ORT_ENABLE_ALL);
/***获取QString的UTF-16表示****/const ushort* utf16Data = model_path_.utf16();int length = model_path_.length();/***分配足够的空间来存储wchar_t字符串(包括空字符)***/std::vector<wchar_t> wcharArray(length + 1);/***复制数据到新的wchar_t数组****/std::copy(utf16Data, utf16Data + length, wcharArray.begin());wcharArray[length] = L'\0';ORTCHAR_T* session_model_path=wcharArray.data();/***创建一个回话***/_session=new Ort::Session(_env,session_model_path,_session_options);/***获取输入输出的批量节点***/_num_input_nodes = _session->GetInputCount();_num_output_nodes = _session->GetOutputCount();Ort::AllocatorWithDefaultOptions allocator_;/***确定输入的维度,和输入的入口名****///_input_node_names={"input"};_input_node_names.resize(_num_input_nodes);_input_node_name_strings.resize(_num_input_nodes);for (int i = 0; i < _num_input_nodes; i++){Ort::TypeInfo type_info = _session->GetInputTypeInfo(i);auto tensor_info = type_info.GetTensorTypeAndShapeInfo();ONNXTensorElementDataType type = tensor_info.GetElementType();std::vector<int64_t> in_node_shape = tensor_info.GetShape();int shape_index = 0;for (auto& shape: in_node_shape){_input_node_dims[shape_index++] = shape;}_input_node_name_strings[i]=_session->GetInputNameAllocated(i, allocator_).get();_input_node_names[i]=_input_node_name_strings[i].c_str();}/***确定输出的维度,和输出的出口名称****///_output_node_names={"output"};_output_node_names.resize(_num_output_nodes);_output_node_name_strings.resize(_num_output_nodes);for (int i = 0; i < _num_output_nodes; i++){Ort::TypeInfo type_info = _session->GetOutputTypeInfo(i);auto tensor_info = type_info.GetTensorTypeAndShapeInfo();std::vector<int64_t> out_node_shape = tensor_info.GetShape();int shape_index = 0;for (auto& shape : out_node_shape){_output_node_dims[shape_index++] = shape;}_output_node_name_strings[i]=_session->GetOutputNameAllocated(i,allocator_).get();_output_node_names[i]=_output_node_name_strings[i].c_str();}
/***创建内存信息***/Ort::MemoryInfo memory_info = Ort::MemoryInfo::CreateCpu(OrtArenaAllocator, OrtMemTypeCPU);vector<Ort::Value> input_tensors;input_tensors.push_back(Ort::Value::CreateTensor<float>(memory_info,/***处理内存的地方***/input_tensor_values.data(),/***数据***/input_tensor_values.size(),/****数据大小****/_input_node_dims.data(),/****维度数据****/_input_node_dims.size()));_output_tensor.clear();/***创建一个运行的选项***/Ort::RunOptions r_op;_output_tensor = _session->Run(r_op,/****运行*****/_input_node_names.data(),/*****输入的名称******/input_tensors.data(),/****输入的数据******/_input_node_names.size(),/****输入的量******/_output_node_names.data(),/***输出的名*****/_output_node_names.size());/***输出的维度大小*****//***获取反馈的结构***/auto info_=_output_tensor.front().GetTensorTypeAndShapeInfo();std::vector<int64_t> shape_=info_.GetShape();int batch_size_=shape_[0];//识别的批次int class_count_=shape_[1];//识别到的类int out_size=  _output_tensor.size();float const *output_tensor_=_output_tensor[0].GetTensorData<float>();float ng_sorce_=output_tensor_[0];float ok_sorce_=output_tensor_[1];if(ng_sorce_>ok_sorce_){_class_str="ng:"+QString::number(ng_sorce_);_class_id=0;}else{_class_str="ok:"+QString::number(ok_sorce_);_class_id=1;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/883103.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

入门数据结构JAVADS——如何通过遍历顺序构建二叉树

目录 前言 构建二叉树的前提&#xff1a; 为什么需要两个不同类型的遍历&#xff1a; 前序遍历 中序遍历 我们的算法思路如下: 举例&#xff1a; 代码实现 后序遍历 中序遍历 结尾 前言 入门数据结构JAVA DS——二叉树的介绍 (构建,性质,基本操作等) (1)-CSDN博客 在上…

我毕业后的8年嵌入式工作

2015年毕业&#xff0c;2016年工作到现在已经过了8个年头&#xff0c;借着征文&#xff0c;做个简单的回顾与总结。 2015年从广州番禺职业技术学院毕业&#xff0c;学的是嵌入式技术与应用&#xff0c;我的下一届学弟学妹变物联网了&#xff0c;算是绝版专业了吧。出来后谨遵校…

07 设计模式-结构型模式-桥接模式

桥接&#xff08;Bridge&#xff09;是用于把抽象化与实现化解耦&#xff0c;使得二者可以独立变化。这种类型的设计模式属于结构型模式&#xff0c;它通过提供抽象化和实现化之间的桥接结构&#xff0c;来实现二者的解耦。 这种模式涉及到一个作为桥接的接口&#xff0c;使得…

JAVA单列集合

List系列集合:添加的元素是 有序、可重复、有索引 Set系列集合:添加的元素是 无序、不重复、无索引 Collection Collection是单列集合的接口&#xff0c;它的功能是全部单列集合都可以继承使用的 public boolean add(E e) 把给定的对象添加到当前集合中 public void …

Spring MVC(下)

博主主页: 码农派大星. 数据结构专栏:Java数据结构 数据库专栏:MySQL数据库 JavaEE专栏:JavaEE 关注博主带你了解更多JavaEE知识 目录 1.响应 1.1 返回静态页面 1.2 返回数据ResponseBody 1.3 返回HTML代码⽚段 1.4 返回JSON 1.5 设置状态码 1.6 设置Header 2 . …

【文献及模型、制图分享】基于国际湿地城市视角的常德市湿地保护修复成效与归因分析及其政策启示

文献介绍 《湿地公约》提出的“国际湿地城市”认证是促进湿地保护修复的新举措。以国际湿地城市常德市为例&#xff0c;基于2000—2022年15 m空间分辨率湿地分类数据&#xff0c;监测常德市湿地保护修复逐年动态变化&#xff0c;定量分析湿地保护修复驱动因素的重要性和贡献率…

K8s中TSL证书如何续期

TSL是什么 K8s中的作用是什么&#xff1f; 在 Kubernetes&#xff08;K8s&#xff09;中&#xff0c;TSL 指的是 Transport Layer Security&#xff0c;也就是传输层安全协议。它是用来保护在网络上传输的数据的安全性和隐私性。 TSL 在 Kubernetes 中的作用包括&#xff1a;…

第1讲(ASP.NET Core 6 Web Api 开发入门):第一个Web Api项目

一、运行模板项目 二、验证模板项目的api 法1&#xff1a;直接在网页上进行验证api 法2&#xff1a;通过命令行验证api 复制下图的Curl语句&#xff0c;打开命令行进行粘贴。&#xff08;对于windows系统&#xff0c;需要把换成"&#xff0c;再去掉所有的/&#xff0c;最…

一文了解AOSP是什么?

一文了解AOSP是什么&#xff1f; AOSP基本信息 基本定义 AOSP是Android Open Source Project的缩写&#xff0c;这是一个由Google维护的完全免费和开放的操作系统开发项目。它是Android系统的核心基础&#xff0c;提供了构建移动操作系统所需的基本组件。 主要特点 完全开源…

【景观生态学实验】实验一 ArcGIS地理数据处理及制图基础

实验目的 1.掌握ArcGIS软件基本操作&#xff1a;通过实验操作与学习&#xff0c;熟练掌握ArcGIS软件相关的基本操作&#xff0c;包括界面熟悉、工具栏使用、数据的加载和保存、基本数据处理操作等; 2.掌握如何使用ArcGIS进行影像拼接及裁剪&#xff1a;通过实验操作与学习&am…

传知代码-ChatGPT多模态命名实体识别

代码以及视频讲解 本文所涉及所有资源均在传知代码平台可获取 ChatGPT辅助细化知识增强&#xff01; 多模态命名实体识别&#xff08;MNER&#xff09;最近引起了广泛关注。 用户在社交媒体上生成大量非结构化内容&#xff0c;主要由图像和文本组成。这些帖子具有与社交媒体相…

GISBox vs CesiumLab:哪款GIS工具更适合你的项目?

在地理信息系统&#xff08;GIS&#xff09;领域&#xff0c;越来越多的用户开始关注GIS工具箱的选择&#xff0c;其中GISBox和CesiumLab是两款备受推崇的产品。那么&#xff0c;哪一款更适合你的需求呢&#xff1f;本文将从功能、使用体验和应用场景等方面&#xff0c;对GISBo…

产品如何实现3D展示?具体步骤如下

产品实现3D展示主要依赖于先进的3D建模与展示技术。以下是产品实现3D展示的具体步骤和方法&#xff1a; 一、3D建模 使用专业的3D建模软件&#xff0c;如Blender、Maya、3ds Max等&#xff0c;这些软件提供了丰富的建模工具和材质编辑器&#xff0c;能够创建出高精度的3D模型…

Python基于amazon/chronos-t5-base的预训练模型离线对时间系列数据的未来进行预测

Python基于预训练模型对时间系列数据的未来进行预测 导入库 %matplotlib inline import matplotlib.pyplot as plt import numpy as np import pandas as pd import torch from chronos import ChronosPipeline from tqdm.auto import tqdm from autogluon.timeseries import…

电脑定期运行某个程序

1、右键计算机-管理&#xff0c;点击任务计划程序&#xff0c;再点击创建基本任务&#xff1b; 2、写名称&#xff0c;下一步 3、选择任务开始计划&#xff0c;下一步 4、选择触发时间&#xff0c;下一步 5、选择启动程序&#xff0c;下一步 6、选择运行的程序&#xff0c;下一…

模型拆解(一):DBINet、GCPANet、CPD、ACCoNet、FPS-U2Net

文章目录 一、DBINet1.1编码器模块&#xff1a;ResNet50PVT双分支结构1.2解码器模块&#xff1a;自细化模块SR的应用1.3DFM&#xff1a;双分支融合模块1.4转换器模块&#xff1a;调整编码器输出至解码器中1.5深度监督损失函数 二、GCPANet2.1编码器模块&#xff1a;ResNet50主干…

uniapp移动端优惠券! 附源码!!!!

本文为常见的移动端uniapp优惠券&#xff0c;共有6种优惠券样式&#xff08;参考了常见的优惠券&#xff09;&#xff0c;文本内容仅为示例&#xff0c;您可在此基础上调整为你想要的文本 预览效果 通过模拟数据&#xff0c;实现点击使用优惠券让其变为灰色的效果&#xff08;模…

来自骨关节炎计划的膝关节MR图像的自动异常感知3D骨骼和软骨分割|文献速递-基于生成模型的数据增强与疾病监测应用

Title 题目 Automated anomaly-aware 3D segmentation of bones and cartilages in kneeMR images from the Osteoarthritis Initiative 来自骨关节炎计划的膝关节MR图像的自动异常感知3D骨骼和软骨分割 Background 背景 近年来&#xff0c;多个机器学习算法被提出用于图像…

windows|常见的文件伪装方法

几种常见的文件伪装方法&#xff1a; 扩展名伪装unicode字符伪装压缩包伪装隐写术 方法仅限于学习目的&#xff0c;不用于任何恶意或非法用途。 ———— 一、扩展名伪装&#xff1a;假装是另一种类型的文件 修改文件的扩展名&#xff0c;使得文件看起来像其他类型的文件&a…

python常用设计模式,单例模式和工厂设计模式

python常用设计模式&#xff0c;单例和工厂设计模式Demo 单例模式 单例设计模式是一种创建型设计模式&#xff0c;它确保一个类只有一个实例&#xff0c;并提供一个全局访问点来获取该实例。 应用场景&#xff1a;日志记录、线程池、缓存等 优点&#xff1a; 全局访问&…