YOLOv5全面解析教程⑧:将训练好的YOLOv5权重导为其它框架格式

撰文|FengWen、BBuf
 

1

模型导出

这个教程用来解释如何导出一个训练好的OneFlow YOLOv5模型到 ONNX。欢迎大家到这里查看本篇文章的完整版本:https://start.oneflow.org/oneflow-yolo-doc/tutorials/06_chapter/export_onnx_tflite_tensorrt.html

2

开始之前

克隆工程并在 Python>3.7.0 的环境中安装 requiresments.txt , OneFlow 请选择 nightly 版本或者 >0.9 版本 。模型和数据可以从源码中自动下载。

 
git clone https://github.com/Oneflow-Inc/one-yolov5.git
cd one-yolov5
pip install -r requirements.txt  # install


3

格式

YOLOv5支持多种模型格式的导出,并基于特定模型对应的框架获得推理加速。

67a4d83062119012c084ac53b4a1dac1.png

4

导出训练好的 YOLOv5 模型

下面的命令把预训练的 YOLOV5s 模型导出为 ONNX 格式。yolov5s 是小模型,是可用的模型里面第二小的。其它选项是 yolov5n ,yolov5m,yolov5l,yolov5x ,以及他们的 P6 对应项比如 yolov5s6 ,或者你自定义的模型,即 runs/exp/weights/best 。有关可用模型的更多信息,可以参考我们的README

 
python export.py --weights ../yolov5s/ --include onnx

💡 提示: 添加 --half 以 FP16 半精度导出模型以实现更小的文件大小。

输出:

 
export: data=data/coco128.yaml, weights=['../yolov5s/'], imgsz=[640, 640], batch_size=1, device=cpu, half=False, inplace=False, train=False, keras=False, optimize=False, int8=False, dynamic=False, simplify=False, opset=12, verbose=False, workspace=4, nms=False, agnostic_nms=False, topk_per_class=100, topk_all=100, iou_thres=0.45, conf_thres=0.25, include=['onnx']
YOLOv5 🚀 270ac92 Python-3.8.11 oneflow-0.8.1+cu117.git.0c70a3f6be CPUFusing layers... 
YOLOv5s summary: 157 layers, 7225885 parameters, 229245 gradientsOneFlow: starting from ../yolov5s with output shape (1, 25200, 85) (112.9 MB)ONNX: starting export with onnx 1.12.0...
Converting model to onnx....
Using opset <onnx, 12>
Optimizing ONNX model
After optimization: Const +17 (73->90), Identity -1 (1->0), Unsqueeze -60 (60->0), output -1 (1->0), variable -60 (127->67)
Succeed converting model, save model to ../yolov5s.onnx
<class 'tuple'>
Comparing result between oneflow and onnx....
Compare succeed!
ONNX: export success, saved as ../yolov5s.onnx (28.0 MB)Export complete (24.02s)
Results saved to /home/zhangxiaoyu
Detect:          python detect.py --weights ../yolov5s.onnx 
Validate:        python val.py --weights ../yolov5s.onnx 
OneFlow Hub:     model = flow.hub.load('OneFlow-Inc/one-yolov5', 'custom', '../yolov5s.onnx')
Visualize:       https://netron.app

导出的 onnx 模型使用 Netron Viewer 进行可视化的结果如下:

824ebd4a745bbba0a22affef6479e525.png

5

导出模型的示例用法

detect.py 可以对导出的模型进行推理:

 
python path/to/detect.py --weights yolov5s/                  # OneFlowyolov5s.onnx               # ONNX Runtime or OpenCV DNN with --dnnyolov5s.xml                # OpenVINOyolov5s.engine             # TensorRTyolov5s.mlmodel            # CoreML (macOS only)yolov5s_saved_model        # TensorFlow SavedModelyolov5s.pb                 # TensorFlow GraphDefyolov5s.tflite             # TensorFlow Liteyolov5s_edgetpu.tflite     # TensorFlow Edge TPU

val.py 可以对导出的模型进行验证:

 
python path/to/val.py --weights    yolov5s/                  # OneFlowyolov5s.onnx               # ONNX Runtime or OpenCV DNN with --dnnyolov5s.xml                # OpenVINOyolov5s.engine             # TensorRTyolov5s.mlmodel            # CoreML (macOS only)yolov5s_saved_model        # TensorFlow SavedModelyolov5s.pb                 # TensorFlow GraphDefyolov5s.tflite             # TensorFlow Liteyolov5s_edgetpu.tflite     # TensorFlow Edge TPU

6

ONNX Runtime 推理

基于 onnx 模型使用 onnxruntime 进行推理:

 
python3 detect.py --weights ../yolov5s/yolov5s.onnx

输出:

 
detect: weights=['../yolov5s/yolov5s.onnx'], source=data/images, data=data/coco128.yaml, imgsz=[640, 640], conf_thres=0.25, iou_thres=0.45, max_det=1000, device=, view_img=False, save_txt=False, save_conf=False, save_crop=False, nosave=False, classes=None, agnostic_nms=False, augment=False, visualize=False, update=False, project=runs/detect, name=exp, exist_ok=False, line_thickness=3, hide_labels=False, hide_conf=False, half=False, dnn=False
YOLOv5 🚀 270ac92 Python-3.8.11 oneflow-0.8.1+cu117.git.0c70a3f6be 
Loading ../yolov5s/yolov5s.onnx for ONNX Runtime inference...
detect.py:159: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an indexs += f"{n} {names[int(c)]}{'s' * (n > 1)}, "  # add to string
image 1/2 /home/zhangxiaoyu/one-yolov5/data/images/bus.jpg: 640x640 4 persons, 1 bus, Done. (0.009s)
image 2/2 /home/zhangxiaoyu/one-yolov5/data/images/zidane.jpg: 640x640 2 persons, 2 ties, Done. (0.011s)
0.5ms pre-process, 10.4ms inference, 4.8ms NMS per image at shape (1, 3, 640, 640)
Results saved to runs/detect/exp14
6e01acc60c6fe097ca80843cdd5fe58f.png

参考文章

https://github.com/ultralytics/yolov5/issues/251
 

其他人都在看

  • Transformer模型的基础演算

  • 关于大型语言模型的争论和局限

  • 揭秘RLHF;可商用开源LLM列表

  • John Schulman:通往TruthGPT之路

  • 为什么ChatGPT用强化学习而非监督学习

  • OneEmbedding:单卡训练TB级推荐模型不是梦

  • GLM训练加速:性能最高提升3倍,显存节省1/3

欢迎Star、试用OneFlow: github.com/Oneflow-Inc/oneflow/icon-default.png?t=N4P3http://github.com/Oneflow-Inc/oneflow/

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

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

相关文章

2023西湖论剑RE--BabyRE

用IDA打开附件&#xff0c;搜索字符串发现“Good, flag is DASCTF{your input}”字符串 一直交叉引用&#xff0c;发现以下三个函数 下面分析中的部分函数名&#xff0c;变量名和变量类型我做了修改 一、sub_401000函数 该函数先调用sub_401170函数&#xff0c;然后注册了一个退…

AIGC专题二:ChatGPT更懂人类的叙事

ChatGPT是OpenAI推出的聊天机器人模型&#xff0c;月度用户已破亿&#xff0c;正在逐步探索商业化途径。ChatGPT能够通过学习和理解人类的语言来进行对话&#xff0c;还能根据聊天的上下文进行互动&#xff0c;真正像人类一样来聊天交流&#xff0c;甚至能完成撰写邮件、视频脚…

【ARMv8/v9 异常模型入门及渐进2 - 系统控制寄存器 SCTRL_ELx 介绍】

文章目录 SCTRL_ELx 介绍背景ARMv8 SCTLR_ELx 介绍ARMv9 SCTLR_ELx 介绍 SCTRL_ELx 介绍背景 由于在做DFD 测试过程中需要测试 EL1 状态下的 self-hosted trace 功能&#xff0c;但是这个测试是在UEFI中做的&#xff0c;在开发验证阶段UEFI默认是运行在EL3 下的&#xff0c;所…

关于UVC设备拥有两个/dev/video*节点的原因以及来历?

在ubuntu18.04/ubuntu16.04系统上,插入UVC设备,你会发现V4L2框架替它创建了两个video设备节点,分别是 /dev/video0, /dev/video1: 经过实际测试,可以通过/dev/video0获取图像,但是无法通过/dev/video1获取图像,具体的试验请看下面两篇博客: V4L2子系统架构设计初探 美…

从千亿模型到ChatGPT的⼀点思考

近年来人工智能的快速发展受到社会各界的广泛关注&#xff0c;超大规模预训练模型取得了突飞猛进的进步。唐杰从OpenAI发布的大规模自然语言预训练模型GPT-3谈起&#xff0c;详细介绍了大模型的进化史&#xff0c;及其所表现出来的能够更好处理现实世界复杂性问题的能力与可能性…

230502-LLM-Vicuna介绍、安装与注意事项整理

排名模型Elo 得分描述许可证1&#x1f947; GPT-41274OPENAI 公司&#xff1a;ChatGPT-4OpenAI公司专有2&#x1f948;Claude-v11224Anthtopic 公司&#xff1a;ClaudeAnthtopic公司专有3&#x1f949; GPT-3.5-turbo1155OPENAI 公司&#xff1a;ChatGPT-3.5OpenAI公司专有4⭐️…

ChatGPT又为我省了一笔钱

作为家长你可能会关注。我周围的朋友&#xff0c;一般都会请外教来帮助孩子提高英语口语能力。然而&#xff0c;外教的费用不菲&#xff0c;这也成为了很多人的负担。但现在&#xff0c;有了ChatGPT语音插件&#xff0c;我们可以省下雇佣外教的钱&#xff0c;而又能有效地提高英…

跟着ChatGPT手把实现一个websocket连接管理器! 毛骨悚然

全是贴图了&#xff1a; 多说无益&#xff01;&#xff01;&#xff01; 开始&#xff1a; 实现一个某安的连接管理&#xff1a; 其中步骤1到7列的明明白白&#xff0c;而且一开始就提出了要有connectionManager&#xff0c;这已经是很职业的方式了&#xff0c;至少不是学生气&…

2023 商业化ChatGpt Web源码

简介 一款使用React搭建的一款可商业化的ChatGpt Web应用,支持接入支付宝当面付及易支付 主要功能 后台管理系统,可对用户,Token,商品,卡密等进行管理精心设计的 UI&#xff0c;响应式设计极快的首屏加载速度&#xff08;~100kb&#xff09;支持Midjourney绘画和DALLE模型绘…

基于ChatGPT的文档知识库客服系统-支持上传网址/文本/docx等数据

现在&#xff0c;很多公司都有自己的内容知识库&#xff0c;会产生大量的碎片话的内部知识&#xff0c;但是这样内部知识难以整合搜索。 我开发的文档知识库客服系统 gofly.v1kf.com &#xff0c;可以应用于企业内部知识库管理&#xff0c;用户可以使用自然语言提问&#xff0c…

学编程一定要数学很好吗?看到网友这样说,我松了一口气 ...

学好数理化&#xff0c;走遍全天下&#xff01;小时候&#xff0c;这句顺口溜时常在耳边响起&#xff0c;而迈入编程行业以后&#xff0c;又有人想问&#xff1a;我数学不好&#xff0c;能写好代码吗&#xff1f; 不过最近的 MIT 神经科学家在 eLife期刊发表了一项新研究&#…

答读者:数学不好,能学好算法吗?

点击关注上方“五分钟学算法”&#xff0c; 设为“置顶或星标”&#xff0c;第一时间送达干货。 转自是不是很酷 这是在我的知识星球上&#xff0c;一个同学问我的问题。 波波老师您好。 我今年 28 了&#xff0c;也算是科班出身&#xff0c;但是大学的时候基本没怎么上过课。毕…

5小时掌握提示词工程,写出高价值大模型Prompt!中文!免费!

写出优质的提示词&#xff0c;让AI生成惊艳的图文作品。 ——这就是如今年薪百万仍一人难求的提示词工程师们在解决的问题。大语言模型时代下&#xff0c;不断涌现出众多让人瞳孔地震的绘画、拍案叫绝的文案&#xff0c;它们的创作者并非传统定义的画家、作家&#xff0c;而是这…

大模型部署的方案

借着热点&#xff0c;简单聊聊大模型的部署方案&#xff0c;作为一个只搞过CV部署的算法工程师&#xff0c;在最近LLM逐渐改变生活的大背景下&#xff0c;猛然意识到LLM部署也是很重要的。大模型很火&#xff0c;而且确实有用&#xff08;很多垂类场景可以针对去训练&#xff0…

大大大模型部署方案抛砖引玉

作者 | Oldpan 编辑 | oldpan博客 点击下方卡片&#xff0c;关注“自动驾驶之心”公众号 ADAS巨卷干货&#xff0c;即可获取 点击进入→自动驾驶之心【模型部署】技术交流群 借着热点&#xff0c;简单聊聊大模型的部署方案&#xff0c;作为一个只搞过CV部署的算法工程师&#…

为什么很多企业把35岁视为分水岭

(点击即可收听) 为什么很多企业把35岁视为分水岭 有时候,别人的故事,若干年后,就是自己的故事,只要身在互联网这个行业里,可以说,每个人都避免不了35岁危机 不要五十步笑百步 前阵子,朋友圈一位行业知名大佬,35岁,每天兢兢业业,任劳任怨,本以为安稳渡过3个月试用期,正快要转正时…

AI冲击人工:资深翻译3年前就接受了可能到来的失业,原画师被取代后又出现了“AI概念师”...

九派新闻AI会取代我们吗&#xff1f; 高盛公司最新一份研究报告指出&#xff0c;ChatGPT等AI领域出现突破后&#xff0c;全球预计将有3亿个工作岗位被生成式AI取代。OpenAI近日发表论文称&#xff0c;如果一项工作使用AI能减少50%以上的时间&#xff0c;那么它就是可替代的。其…

项目完成小结:使用Blazor和gRPC开发大模型客户端

先介绍下这个项目。 最近我一直在探索大语言模型&#xff0c;根据不同场景训练了好几个模型&#xff0c;为了让用户测试使用&#xff0c;需要开发前端。 这时候&#xff0c;用 Gradio 搭建的前端是不太够的&#xff0c;虽说 GitHub 上也有一堆开源的 ChatGPT 前端&#xff0c…

Mac 上的搜狗输入法卡顿问题

我的 Mac 使用的中文输入法是搜狗拼音输入法&#xff0c;一直有一个问题&#xff0c;就是 Mac 开机太久&#xff0c;输入法会出现卡顿问题&#xff0c;按下按键 0.5s 后需才会显示对应的汉字&#xff0c;用着非常难受&#xff0c;以前这种情况我都是通过重启 Mac 来解决&#x…

大语言模型将如何影响软件开发?

当人人具备编写代码的能力之后&#xff0c;这将会给软件生产和分配带来哪些结构性的变化&#xff1f; 原文链接&#xff1a;https://www.geoffreylitt.com/2023/03/25/llm-end-user-programming.html 未经授权&#xff0c;禁止转载&#xff01; 作者 | Geoffrey Litt 译者 | 弯…