ncnn yolov5.cpp切换yolov5n6模型(一)

本文讲述了如何将Yolo5n6模型转换为NCNN以提升手机上的检测速度,并详细介绍了参数调整过程,包括Reshape层的修改、anchor数量的对应和输出层的更新。作者提到精度有所下降,计划进一步研究strip64参数以提高性能。
部署运行你感兴趣的模型镜像


背景: ncnn yolo demo源码里面使用的模型是yolov5s_6.0。在手机上运行检测正常,但是速度稍慢,打算更换模型为yolo5n6,遇到的问它再此记录

问题1:yolo模型转ncnn模型

  1. 进入虚拟环境
    conda activate yolo5

  2. 安装onnx
    pip install onnx
    pip install onnx-simplifier

  3. 运行export.py
    python export.py --weights yolo5n6.pt --img 640 640 --batch 1 --train --simplify --include onnx
    python -m onnxsim yolo5n6.onnx yolo5n6-sim.onnx

  4. 在线ncnn转换:https://convertmodel.com/#outputFormat=ncnn

问题2:yolo5n6.param参数修改

  1. 把所有Resharp层的 0=-1,使输出的BBOX可以自适应
    在这里插入图片描述
  2. yolov5.cpp 每一层的参数需要与模型的anchors对应
    在这里插入图片描述
  3. yolov5只处理了3个anchors,v6版本有4个
    在这里插入图片描述
    4.yolov5.cpp stride 8、16、32的层名字,要对应修改
    ex.extract(blob_name, out);
    在这里插入图片描述

我这边暂时按照原来3层输出的代码,丢弃了strip64的输出,检测正常。
但是准确率确实比v5s要差些。
后续研究strip64参数作用,修改代码增加strip64层输出,看效果是否有改善

请看下集


您可能感兴趣的与本文相关的镜像

Yolo-v5

Yolo-v5

Yolo

YOLO(You Only Look Once)是一种流行的物体检测和图像分割模型,由华盛顿大学的Joseph Redmon 和Ali Farhadi 开发。 YOLO 于2015 年推出,因其高速和高精度而广受欢迎

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值