移动端的部署有这么几条路:
(以yolov5s.pt模型为例)

pt文件 --> onnx文件/torchscript文件 --> ncnn --> 安卓端部署(android studio编写)
pt文件 --> onnx文件/torchscript文件 --> ML文件 --> ios端部署(需要mac系统运行xcode编写)
pt文件 --> onnx文件 /torchscript文件/wts文件–> openvino/tensorrt 等部署平台 --> 树莓派/jetson部署(最好是在linux环境下)

目前yolov5的部署可以说是把onnx文件/torchscript文件作为中间模型去转换到相应的模型。
部署需要一定的c++操作水平及工具

参考大佬项目

https://github.com/enazoe/yolo-tensorrt作者封装了模型的转换
https://github.com/wang-xinyu/tensorrtx
https://github.com/jkjung-avt/tensorrt_demos

1、pt转ONNX、ML、TorchScript

安装ONNX

在yolov5文件夹下运行

pip install -r requirements.txt onnx # install requirements.txt and ONNX

转换文件

在这里,我以转换官方的yolov5s.pt模型文件为例
在yolov5文件夹下运行

python models/export.py --weights weights/yolov5s.pt --img 640 --batch 1

应该会多出现三个文件
分别是ONNX文件、ML文件、torchscript文件

使用Netron
使用Netron来查看你的ONNX文件模型
其实netron现已支持大部分格式的模型文件,都是可以查看的。
PaddlePaddle、OpenVINO、TensorFlow 、Caffe…
安装netron

pip install netron

进入python,运行netron.start()

import netron
netron.start('yolov5s.onnx')

2.Jetson nano的部署

下载yolov5、tensorrtx

git clone https://github.com/wang-xinyu/tensorrtx.git
git clone https://github.com/ultralytics/yolov5.git

生成trt引擎

yolov5官方教程:https://github.com/wang-xinyu/tensorrtx/tree/master/yolov5

1.生成wts文件

这一步可以在x86系统上完成。
首先你得有yolov5的模型文件,我上一篇有讲,我这里使用yolov5s.pt训练出来的best.pt文件来进行下面的操作。
复制 tensorrtx/yolov5/gen_wts.py文件 到 yolov5 文件夹中
5.0的tensorrtx修改了这一python文件
只需要输入一次文件路径即可生成对应文件。

python3 gen_wts.py weights/yolov5s.pt

这样就会在weights文件夹中生成一个yolov5s.wts文件。

2.build

这一步是生成部署引擎,必须来到部署该引擎的硬件设备上进行。
就像我这里模型是想在Jetson nano上部署,所以这一步就必须在Jetson nano上进行build。在此之前的有关yolov5的操作都可在x86的系统上完成。
将yolov5s.wts文件放到tensorrtx/yolov5文件夹中,
来到tensorrtx/yolov5文件夹中,查看yolov5.cpp中的模型是s。

yolov5.cpp文件中
还可以修改fp16还是fp32 int8、device(选择哪一个GPU设备)、nms_thresh(nms的阈值)、conf_thresh(conf的置信度)、batch_size(批次大小)

打开yololayer.h文件,

  • 修改num总数,根据你训练模型的类个数来
  • 修改输入图片的尺寸,但必须是32的倍数。缩小输入尺寸可以一定程度上加快推理速度。

确保tensorrtx/yolov5文件下有你的wts文件,并且相应地修改了yolov5.cpp文件和yolovlayer.h文件。
然后在tensorrtx/yolov5文件夹下依次执行下面的代码

mkdir build
cd build
cmake ..
make -j6
sudo ./yolov5 -s ../yolov5s.wts yolov5s.engine s
#sudo ./yolov5 -s [.wts] [.engine] [s/m/l/x/s6/m6/l6/x6 or c/c6 gd gw]
#模型引擎生成的命令解释如上

如果你是通过修改每一层卷积的宽度和深度来达到自定义的模型的话,就可以直接使用下面的命令来达成生成引擎,这是我认为4.0的这个版本最大的升级点了!!!

sudo ./yolov5 -s yolov5_custom.wts yolov5.engine c 0.17 0.25

我一般缩小宽度和深度来达到剪裁模型,加快运行速度的作用。这一api优化让我的调试十分的方便。
v5.0的tensorrtx库更新适配了yolov5的p6模型,如果你用的是p6模型训练,可以使用下面的命令。

sudo ./yolov5 -s ../yolov5s.wts yolov5s.engine s6
sudo ./yolov5 -s yolov5_custom.wts yolov5.engine c6 0.17 0.25

3.python调用

编辑tensorrtx/yolov5_trt.py文件

注释掉import torch和import torchvision,因为在nano上安装这两个库是有些麻烦的特别是torchvision。
当然你也可以去试试安装这两个库,网上的一些教程我有试过是可以成功,就是麻烦。

INPUT_W和INPUT_H根据你自己之前设置的来,我build时是写608,所以这里也是608。
CONF_THRESH 与 IOU_THRESHOLD 可根据最后的显示效果返回来修改他,暂且不调整。

详见:https://blog.csdn.net/weixin_45569617/article/details/108145046

yolov5 | 移动端部署yolov5s模型相关推荐

  1. Triton服务器部署Yolov5s模型应用

    目录 1. Triton介绍 2. Yolov5s模型部署 2.1 Triton服务端部署 2.2 Triton客户端部署 1. Triton介绍

  2. yolov5模型部署:Nvidia使用TensorRT部署yolov5s模型

    点上方计算机视觉联盟获取更多干货 仅作学术分享,不代表本公众号立场,侵权联系删除 转载于:作者丨梁彦哲@知乎(已授权) 来源丨https://zhuanlan.zhihu.com/p/38688102 ...

  3. 怎么将tflite部署在安卓上_tensorflow从训练自定义CNN网络模型到Android端部署tflite...

    网上有很多关于tensorflow lite在安卓端部署的教程,但是大多只讲如何把训练好的模型部署到安卓端,不讲如何训练,而实际上在部署的时候,需要知道训练模型时预处理的细节,这就导致了自己训练的模型 ...

  4. yolov5笔记(3)——移动端部署自己的模型(随5.0更新)

    一直以来学习目标检测的最终目标就是为了移动端的部署,比方说树莓派.jetson.安卓.ios等.之前因为实在对object_detection训练出来的东西效果不满意,所以当时没继续研究移动端部署.如 ...

  5. tensorflow Lite 2---- 移动端部署--yolov5+训练自己的数据集

    一.模型移动端环境部署 可以参考: tensorflow lite 1---- 移动端部署--object detection 官方历程手把手教程_行码阁119的博客-CSDN博客 二.训练模型 本文 ...

  6. Yolov5s模型在全志V853平台上的部署方法和应用

    AI部署这个词儿大家肯定不陌生,可能有些人还不是很清楚这个是干嘛的,但总归是听过了.近些年来,在深度学习算法已经足够卷之后,深度学习的另一个偏向于工程的方向–部署应用落地,才开始被谈论的多了起来.当然 ...

  7. 移动端调取摄像头上面如何给出框_飞桨实战笔记:自编写模型如何在服务器和移动端部署...

    ​ 作为深度学习小白一枚,从一开始摸索如何使用深度学习框架,怎么让脚本跑起来,到现在开始逐步读懂论文,看懂模型的网络结构,按照飞桨官方文档进行各种模型训练和部署,整个过程遇到了无数问题.非常感谢飞桨开 ...

  8. 飞桨模型保存_飞桨实战笔记:自编写模型如何在服务器和移动端部署

    ​ 作为深度学习小白一枚,从一开始摸索如何使用深度学习框架,怎么让脚本跑起来,到现在开始逐步读懂论文,看懂模型的网络结构,按照飞桨官方文档进行各种模型训练和部署,整个过程遇到了无数问题.非常感谢飞桨开 ...

  9. AI端部署“三问”:模型如何跑起来、跑得快、持续跑

    关注公众号,发现CV技术之美 最近摸鱼期间,发现身为程序员的我被赋予了另一个身份"新生代农民工",简直炸了!重点还官宣了,这就更加实锤了啊!我就想说,我们新生代农民工招谁惹谁了,我 ...

最新文章

  1. JSP实现银柜台业务绩效考核系统
  2. 如何用SPSS做协方差分析?超详细图文教程
  3. CSS+JS灰色树型菜单导航代码
  4. 浅谈怎么玩好微博如何做微博营销
  5. 【HDU - 1757】A Simple Math Problem (矩阵快速幂)
  6. python调用库函数用ecb模式加密图片_AES中ECB模式的加密与解密(Python3.7)
  7. 数据访问增删改查之单项查询
  8. 9206 课堂笔记 综合演练 添加数据与非空验证
  9. 11. GD32F103C8T6 入门教程-外部中断
  10. 【kafka】kafka record is corrupt(记录损坏)
  11. 利用根轨迹法进行控制系统的分析和设计
  12. ASP.NET AJAX入门系列(5):使用UpdatePanel控件(二)
  13. Tricks(二十六) —— 妙用关键字参数(keyword arguments)创建字典
  14. 神州数码最佳实践之一:向项目管理要效益
  15. 【读书笔记《Android游戏编程之从零开始》】12.游戏开发基础(Canvas 画布)
  16. muma很可能在陪你玩游戏
  17. c语言闹钟程序教学,C++实现闹钟程序的方法
  18. tp6多表联合查询的几种方式(模糊搜索+分页+字段限制)
  19. 芝诺数据高校产学研用成果展示|携程酒店(北京)数据分析报告
  20. 比较有用的若干EXCEL常用函数

热门文章

  1. 2018年Java面试题
  2. 软通动力新员工转正考试-新员工转正考试题
  3. batT脚本如何自动执行 adb shell 以后的命令(android抓包)
  4. 某手机在-20度环境下,只能读到电池温度为-18℃
  5. LSM-tree原理与应用
  6. phpyun人才招聘系统接入阿里云短信
  7. 基于流的深度生成模型
  8. 我的JQuery动画
  9. 斐波那契数列类 python实现
  10. oracle的opm,Oracle EBS OPM 发放生产批