基于opencv dnn模块的yolov5部署

本文详述如何利用OpenCV的dnn模块部署Yolov5的ONNX模型,包括模型读取、数据处理和后处理步骤。文章提供了一个基于Yolov5 4.0和OpenCV 4.5.2的项目源码,适用于5个类别的检测。部署过程需要理解Yolov5的基础知识,以及解决可能因OpenCV版本导致的错误。模型导出、ONNX模型分析和网络结构详解一应俱全。
摘要由CSDN通过智能技术生成


  • 这边文章将介绍基于dnn模块的yolov5 onnx模型的部署 包括读取模型和数据处理和后处理
  • 先给出整个项目的源码
  • yolov5版本为4.0
  • opencv 为 4.5.2
  • 使用的模型是自己训练的 类别数为5的模型
  • 不同的版本此源码可能会报错 由于opencv版本报错解决办法
  • 部署需要一些yolov5的基本知识支持 网上比比皆是

opencv dnn模块的使用

这里并不详细介绍 这里给出一篇详细的dnn模块的使用方法
关于深度学习实时检测的三种方法(三)——Opencv DNN加载ONNX模型
onnx模型导出
具体可以参考yolov5的官方github的Tutorials
在这里插入图片描述

  • 运行py文件 yolov5-4.0/models/export.py即可导出onnx
 python models/export.py --weights ./weights/yolov5s.pt --img 640 --batch 1

onnx模型分析

  • 可以使用“Netron”这个软件去查看onnx模型的具体网络

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

  • 上图可以看出网络输出有三层 由先到后为

    • 1×3×80×80×10
    • 1×3×40×40×10
    • 1×3×20×20×10
  • 10 == 类别数(5) + bbox 的 xywh + confidence

  • 80 40 20分别为不同数量的grid cell 用于检测大物体 中物体 小物体

  • 3 代表每个grid cell有三个anchor boxs

在这里插入图片描述

输出层数据处理

  • 代码中每一行都有详细的注释
int n = 0, q = 0, i = 0, j = 0, nout = this->classes.size() + 5, row_ind = 0;
// 遍历三种大小的grid cell
for (n = 0; n < 3; n++)   
{
   
	int num_grid_x = (int)(this
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

【网络星空】

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值