当前位置: 首页 > news >正文

使用C++实现YOLO图像分类:从环境搭建到性能评估的完整指南

⭐️我叫忆_恒心,一名喜欢书写博客的研究生👨‍🎓。
如果觉得本文能帮到您,麻烦点个赞👍呗!

近期会不断在专栏里进行更新讲解博客~~~ 有什么问题的小伙伴 欢迎留言提问欧,喜欢的小伙伴给个三连支持一下呗。👍⭐️❤️
Qt5.9专栏定期更新Qt的一些项目Demo
项目与比赛专栏定期更新比赛的一些心得面试项目常被问到的知识点。

在这里插入图片描述

一、引言

YOLO(You Only Look Once)是一种先进的实时对象检测系统,其核心思想是在一个单一的神经网络中直接预测对象边界框和类概率。与传统的对象检测方法相比,YOLO在速度和准确性上都有显著优势。在这篇文章中,我们将介绍如何使用C++实现YOLO进行图像分类,并提供示例代码和相关资源。

随着YOLO技术的迅速发展,使用Python进行yolo部署变得相对简单。然而,在实际的业务场景中,我们往往需要利用C++进行高效调用。因此,本文将重点介绍如何使用C++实现YOLO进行图像分类,并提供相关的示例代码和资源,帮助您在自己的项目中灵活应用YOLO。

yolo发展迅猛,且参数变得更少
在这里插入图片描述

1.1 YOLO的基本概念

接下来,我们将详细介绍如何搭建环境、下载并配置YOLO模型文件,以及如何编写和运行示例代码。

在这里插入图片描述

YOLO的基本思想是将整个图像分为SxS的网格,每个网格负责预测多个边界框和这些边界框的置信度,以及每个边界框中包含的类别概率。通过训练一个深度卷积神经网络,YOLO可以在一个前向传递中预测多个对象。

除了进行目标检测,也可以将这个应用在图像分类中。
在这里插入图片描述
在这里插入图片描述

二、 环境搭建

在开始之前,您需要确保已经安装了以下工具和库:

  1. C++编译器(如GCC)
  2. OpenCV库(用于图像处理)
  3. YOLOv模型文件(.cfg和.weights文件)

您可以通过以下命令在Ubuntu上安装OpenCV:

sudo apt-get update
sudo apt-get install libopencv-dev

2.1 下载YOLO模型

首先,您需要下载YOLO的配置文件和权重文件。您可以从以下链接获取这些文件:

  • YOLO配置文件(.cfg)
  • YOLO权重文件(.weights)

将这些文件放在您的项目目录中。如果计算机性能较差,可以直接使用训练好的模型,直接调用:C++版本的YOLO文件。

三、关键要点

  • YOLO是一种先进的实时对象检测系统,能够在单次前向传递中预测多个对象。
  • 使用OpenCV的DNN模块可以方便地加载和运行YOLO模型。
  • 提供的示例代码展示了如何使用C++实现YOLO图像分类,并进行了详细的注释。
  • 相关的仓库可以帮助获取模型文件、更多的示例代码和文档。

3.1 示例代码

接下来,让我们来看一个使用YOLO和C++进行图像分类的简单示例代码。您可以参考这篇文章获取详细的代码实现。

以下是一个基本的代码示例:

#include <opencv2/opencv.hpp>
#include <fstream>
#include <iostream>
#include <vector>// 载入模型和配置文件
std::string modelConfiguration = "yolov.cfg";
std::string modelWeights = "yolov.weights";
cv::dnn::Net net = cv::dnn::readNetFromDarknet(modelConfiguration, modelWeights);void classifyImage(const std::string& imagePath) {// 读取图像cv::Mat frame = cv::imread(imagePath);if (frame.empty()) {std::cerr << "Could not read the image: " << imagePath << std::endl;return;}// 图像预处理cv::Mat blob;cv::dnn::blobFromImage(frame, blob, 1/255.0, cv::Size(416, 416), cv::Scalar(0, 0, 0), true, false);// 设置输入net.setInput(blob);// 前向传播获取结果std::vector<cv::Mat> outs;net.forward(outs, net.getUnconnectedOutLayersNames());// 解析结果for (const auto& out : outs) {for (int i = 0; i < out.rows; i++) {// 解析每个检测结果const auto* data = out.ptr<float>(i);// 此处省略详细的解析代码}}// 显示结果cv::imshow("Image", frame);cv::waitKey(0);
}int main() {std::string imagePath = "path_to_your_image.jpg";classifyImage(imagePath);return 0;
}

3.2 性能评估

在COCO数据集上的训练效果如下:

ModelGPUModeInference Time
Yolov3-416GTX 1060Caffe54.593ms
Yolov3-416GTX 1060float3223.817ms
Yolov3-416GTX 1060int811.921ms
Yolov3-608GTX 1060Caffe88.489ms
Yolov3-608GTX 1060float3243.965ms
Yolov3-608GTX 1060int821.638ms
Yolov3-608GTX 1080 Tifloat3219.353ms
Yolov3-608GTX 1080 Tiint89.727ms
Yolov3-416GTX 1080 Tifloat329.677ms
Yolov3-416GTX 1080 Tiint86.129ms

3.3 评估结果

ModelGPUModeDatasetMAP(0.50)MAP(0.75)
Yolov3-416GTX 1060Caffe(fp32)COCO val201450.3333.00
Yolov3-416GTX 1060float32COCO val201450.2732.98
Yolov3-416GTX 1060int8COCO val201444.1530.24
Yolov3-608GTX 1060Caffe(fp32)COCO val201452.8935.31
Yolov3-608GTX 1060float32COCO val201452.8435.26
Yolov3-608GTX 1060int8COCO val201448.5535.53

四、 相关仓库

以下是一些与YOLO相关的仓库,这些仓库提供了模型文件、示例代码以及文档:

  1. Darknet:YOLO的原始实现,可以在此找到模型配置文件和权重文件。
  2. AlexeyAB/darknet:Darknet的一个常用分支,提供了更多的功能和优化。
  3. opencv/opencv:OpenCV库,提供了对YOLO的DNN模块支持。
    在这里插入图片描述

完整的测试练习demo

五、结论

通过本文,您了解了如何利用YOLO模型和C++进行图像分类。我们从环境搭建开始,逐步讲解了模型文件的下载和示例代码的实现。希望这些内容能对您的项目有所帮助。如果您有任何问题或建议,请随时在评论区留言。

最后,最后
如果觉得有用,麻烦三连👍⭐️❤️支持一下呀,希望这篇文章可以帮到你,你的点赞是我持续更新的动力

相关文章:

使用C++实现YOLO图像分类:从环境搭建到性能评估的完整指南

⭐️我叫忆_恒心&#xff0c;一名喜欢书写博客的研究生&#x1f468;‍&#x1f393;。 如果觉得本文能帮到您&#xff0c;麻烦点个赞&#x1f44d;呗&#xff01; 近期会不断在专栏里进行更新讲解博客~~~ 有什么问题的小伙伴 欢迎留言提问欧&#xff0c;喜欢的小伙伴给个三连支…...

Linux中安装Docker,并使用Docker安装MySQL和Redis

1、安装docker 1卸载系统之前的docker yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine2、安装Docker-CE #安装必须的依赖 sudo yum install -y yum-utils \device-map…...

期货短线交易的核心技术是什么

一、市场分析是短线交易的基础&#xff1a; 技术分析在短线交易中尤为重要&#xff0c;包括K线图、均线系统、成交量与持仓量等指标。K线图可以帮助交易者识别关键价格形态和趋势线&#xff0c;从而判断市场走势。均线系统则可以利用短期均线交叉作为买卖信号&#xff0c;如金…...

VSCode+Vite+Vue3断点调试

目录 lunch.json创建 vite.config.ts 打断点运行 lunch.json创建 首先&#xff0c;点击VSCode左上角&#xff0c;甲壳虫运行的按钮&#xff0c;然后点击运行与调试&#xff0c;选择chrome浏览器&#xff0c;修改成一下配置。 { // 使用 IntelliSense 了解相关属性。 // 悬停…...

RPC框架原理(一)

RPC框架原理 网络和IO的关系&#xff0c;IO&#xff08;input和output&#xff09;面向的是谁&#xff1f;OSI 7层参考模型&#xff0c;TCP/IP协议为什么会出现一个会话层三次握手socket心跳keep alive四次挥手 网络IO&#xff08;IO模型&#xff09; IO框架底层 学习顺序&…...

LCTF 2018 bestphp‘s revenge

考点:Soap原生类Session反序列化CRLF注入 <?php highlight_file(__FILE__); $b implode; call_user_func($_GET[f], $_POST); session_start(); if (isset($_GET[name])) { $_SESSION[name] $_GET[name]; } var_dump($_SESSION); $a array(reset($_…...

MySQL主从搭建--保姆级教学

MYSQL主从搭建步骤 主节点 # 进入目录 cd /opt# 下载安装包 wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz# 解压 tar -xvf mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz# 拷贝到/usr/local mv /opt/mysql-8.0.20-linux-g…...

Modbus通信协议--RTU

一、RTU介绍 MODBUS协议支持多种功能码&#xff0c;不同的功能码对应不同的操作&#xff1a; 0x01读线圈状态0x02读离散输入状态0x03读保持寄存器0x04读输入寄存器0x05写单个线圈0x06写单个保持寄存器0x0F写多个线圈0x10写多个保持寄存器 二、实验 1.0x03功能码读单个保持寄…...

我是大学生,应该选系统运维方向,还是web开发方向?

选择系统运维方向还是Web开发方向取决于你的兴趣、职业目标和个人技能。以下是对这两个方向的详细对比和建议&#xff0c;帮助你做出更明智的选择 双方比较 &#x1f926;‍♀️系统运维方向 优点&#xff1a; 稳定性&#xff1a;系统运维工作通常比较稳定&#xff0c;许多…...

Qt窗口与对话框

目录 Qt窗口 1.菜单栏 2.工具栏 3.状态栏 4.滑动窗口 QT对话框 1.基础对话框QDiaog 创建新的ui文件 模态对话框与非模态对话框 2.消息对话框 QMessageBox 3.QColorDialog 4.QFileDialog文件对话框 5.QFontDialog 6.QInputDialog Qt窗口 前言&#xff1a;之前以上…...

【笔记】Windows 中 一键部署本地私人专属知识库:MaxKB + Docker + MaxKB docker + Ollama

Docker的部署&#xff1a; Docker下载直接进入链接&#xff1a; https://www.docker.com/ Docker使用需要启动Docker,启动Docker以后&#xff0c;会在桌面右下角看到Docker的一个图标&#xff1a; 只有启动了Docker以后&#xff0c;Docker的各种命令才可以使用。 好像还需要…...

【Vue】scoped解决样式冲突

默认情况下写在组件中的样式会 全局生效 → 因此很容易造成多个组件之间的样式冲突问题。 全局样式: 默认组件中的样式会作用到全局&#xff0c;任何一个组件中都会受到此样式的影响 局部样式: 可以给组件加上scoped 属性,可以让样式只作用于当前组件 一、代码示例 BaseOne…...

word模板内容替换

1.pom引入依赖&#xff1a; <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.0.5</version> </dependency> <dependency><groupId>com.deepoove</groupId><a…...

docker安装和使用

1. docker-ce Docker Community Edition (CE): 功能: 这是 Docker 的主要组件&#xff0c;用于创建、管理和运行容器。它包括 Docker 守护进程 (dockerd)&#xff0c;该守护进程负责处理容器的生命周期&#xff0c;包括创建、启动、停止和删除容器。用途: 允许用户在其系统上…...

【AIGC X UML 落地】通过多智能体实现自然语言绘制UML图

前天写了篇博文讲到用PlantUML来绘制C类图和流程图。后台有读者留言&#xff0c;问这步能否自动化生成&#xff0c;不想学习 PlantUML 语法。 我想了下&#xff0c;发现这事可行&#xff0c;确实可以做到通过自然语言的描述就能实现 UML图的绘制&#xff0c;昨天晚上加了个班到…...

C++访问越界

常见场景 访问数组元素越界vector容器访问等 vector<int>;vec<2>&#xff1b;字符串访问越界string str;str[2];array数组访问越界字符串处理&#xff0c;没有添加’\0’字符&#xff0c;导致访问字符串的时候越界了&#xff1b;使用类型强转&#xff0c;让一个大…...

MATLAB format

在MATLAB中&#xff0c;format 是一个函数&#xff0c;用于控制命令窗口中数值的显示格式。这个函数可以设置数值的精度、显示的位数等。以下是一些常用的 format 命令&#xff1a; format long&#xff1a;以默认的长格式显示数值&#xff0c;通常显示15位有效数字。format s…...

Face Forgery Detection by 3D Decomposition

文章目录 Face Forgery Detection by 3D Decomposition研究背景研究目标创新点方法提出问题研究过程技术贡献实验结果未来工作Face Forgery Detection by 3D Decomposition 会议:CVPR2021 作者: 研究背景 面部伪造引发关注传统面部伪造检测主要关注原始RGB图像研究目标 将…...

socket网络编程——多进程、多线程处理并发

如下图所示, 当一个客户端与服务器建立连接以后,服务器端 accept()返回,进而准备循环接收客户端发过来的数据。 如果客户端暂时没发数据,服务端会在 recv()阻塞。此时,其他客户端向服务器发起连接后,由于服务器阻塞了,无法执行 accept()接受连接,也就是其他客户端发送…...

C++---模板进阶(非类型模板参数,模板的特化,模板分离编译)

我们都学习和使用过模板&#xff0c;而这篇文章我们来将一些更深入的知识。在此之前&#xff0c;我们在使用C编程时可以看到模板是随处可见的&#xff0c;它能支持泛型编程。模板包括函数模板和类模板&#xff0c;我们有的人可能会说是模板函数和模板类&#xff0c;但严格讲这样…...

缓存穿透的解决方式?—布隆过滤器

在技术领域&#xff0c;我们常常被那些闪耀的、可见的成果所吸引。今天&#xff0c;这个焦点无疑是大语言模型技术。它们的流畅对话、惊人的创造力&#xff0c;让我们得以一窥未来的轮廓。然而&#xff0c;作为在企业一线构建、部署和维护复杂系统的实践者&#xff0c;我们深知…...

栈(C语言)

目录 1. 栈的定义 2. 代码实现 1. 栈的定义 栈属于线性表&#xff0c;具有后进先出的特点&#xff0c;存储结构类似羽毛球桶&#xff0c;可以依次取出最后放入栈中的数据。实现&#xff1a;栈一般采用数组 / 链表实现&#xff0c;但是推荐程度&#xff1a;数组 > 单链表 …...

专业级OBS模糊插件全攻略:obs-composite-blur技术解析与应用指南

专业级OBS模糊插件全攻略&#xff1a;obs-composite-blur技术解析与应用指南 【免费下载链接】obs-composite-blur A comprehensive blur plugin for OBS that provides several different blur algorithms, and proper compositing. 项目地址: https://gitcode.com/gh_mirro…...

QMCDecode:让QQ音乐加密文件重获自由的macOS工具

QMCDecode&#xff1a;让QQ音乐加密文件重获自由的macOS工具 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac&#xff0c;qmc0,qmc3转mp3, mflac,mflac0等转flac)&#xff0c;仅支持macOS&#xff0c;可自动识别到QQ音乐下载目录&#xff0c;默认转换结…...

Zstats高级版教程(3):如何进行数据整理(下),分类变量如何设置对照组?设置值标签?

本篇是风暴统计平台教程系列的第三章&#xff0c;将详细说明如何使用数据整理模块&#xff0c;节省后续分析的时间。因为涉及内容比较多&#xff0c;分为上中下三篇&#xff0c;此为下篇。前两篇数据整理教程分别向大家详细介绍了数据整理模块的定量数据转分类、计算新变量、变…...

18年产品经理生涯精华:从交付到规划,项目管理、解决方案、业务理解深度解析!

本期访谈只有1位老师&#xff0c;大海老师&#xff0c;18年工作经验&#xff0c;从干交付&#xff0c;到项目管理&#xff0c;再到资深技术专家、解决方案专家&#xff0c;目前做的更多的是业务规划、产品规划&#xff0c;是从一线实战走到真正的专家层面&#xff0c;老师分享的…...

Qwen3-VL-2B-Instruct保姆级教程:视觉对话机器人部署

Qwen3-VL-2B-Instruct保姆级教程&#xff1a;视觉对话机器人部署 1. 环境准备与快速部署 想要体验AI视觉对话的神奇能力吗&#xff1f;Qwen3-VL-2B-Instruct让你不用昂贵的显卡也能拥有一个能"看懂"图片的智能助手。这个教程将手把手带你完成整个部署过程&#xff…...

OpenClaw新手入门:千问3.5-9B镜像一键部署与初体验

OpenClaw新手入门&#xff1a;千问3.5-9B镜像一键部署与初体验 1. 为什么选择这个组合&#xff1f; 去年冬天&#xff0c;我第一次在本地尝试用OpenClaw自动整理电脑上的照片。当时对接的是GPT-3.5&#xff0c;每次识别图片内容都要消耗大量token&#xff0c;一个月下来账单让…...

07_Cursor之语言支持与扩展生态

关键字&#xff1a;语言支持, VS Code扩展, 跨平台, Electron, Python开发, 扩展生态 07_Cursor之语言支持与扩展生态 Cursor知识体系 Cursor知识体系&#xff08;续&#xff09; | -- 生态支持层 | -- 多语言支持 | | -- 通用LLM支持 | | -- 自动语言检测 | | …...

有源vs无源晶振怎么选?从接法差异到成本对比的5个实战建议

有源与无源晶振选型指南&#xff1a;5个关键决策维度与实战技巧 在硬件设计领域&#xff0c;时钟信号如同系统的心跳&#xff0c;而晶振的选择直接影响着整个电路的稳定性和可靠性。面对市场上琳琅满目的有源和无源晶振&#xff0c;工程师常常陷入选择困境——是追求有源晶振的…...