瑞芯微(EASY EAI)RV1126B yolov5训练部署教程

描述

1. Yolov5简介

YOLOv5 模型是 Ultralytics 公司于 2020 年 6 月 9 日公开发布的。YOLOv5 模型是基于 YOLOv3 模型基础上改进而来的,有 YOLOv5s、YOLOv5m、YOLOv5l、YOLOv5x 四个模型。YOLOv5 相比YOLOv4 而言,在检测平均精度降低不多的基础上,具有均值权重文件更小,训练时间和推理速度更短的特点。YOLOv5 的网络结构分为输入端BackboneNeck、Head 四个部分。

本教程针对目标检测算法yolov5的训练和部署到EASY-EAI-Nano-TB(RV1126B)进行说明,而数据标注方法可以参考我们往期的文章。

人工智能

2. 准备数据集

2.1 数据集下载

本教程以口罩检测为例,数据集的百度网盘下载链接为:

https://pan.baidu.com/s/14TxzPfEaEBXYUdM4OfryKg?pwd=1234 提取码:1234

解压完成后得到以下三个文件:

人工智能

2.2 生成路径列表

在数据集目录下执行脚本list_dataset_file.py:

python list_dataset_file.py

执行现象如下图所示:

人工智能

得到训练样本列表文件train.txt和验证样本列表文件valid.txt,如下图所示:

人工智能

3. Yolov5目标检测算法训练

3.1 训练源码下载

通过git工具,在PC端克隆远程仓库(注:此处可能会因网络原因造成卡顿,请耐心等待):

git clone https://github.com/EASY-EAI/yolov5.git

人工智能

得到下图所示目录:

人工智能

3.2 训练模型

切换到yolov5的工作目录,接下来以训练一个口罩检测模型为例进行说明。需要修改data/mask.yaml里面的train.txtvalid.txt的路径。

人工智能

执行下列脚本训练算法模型:

python train.py --data mask.yaml --cfg yolov5s.yaml --weights "" --batch-size 64

开始训练模型,如下图所示:

人工智能

关于算法精度结果可以查看./runs/train/results.csv获得。

3.3 在PC端进行模型预测

训练完毕后,在./runs/train/exp/weights/best.pt生成通过验证集测试的最好结果的模型。同时可以执行模型预测,初步评估模型的效果:

python detect.py --source data/images --weights ./runs/train/exp/weights/best.pt --conf 0.5

人工智能

3.4 pt模型转换为onnx模型

算法部署到EASY-EAI-Nano需要转换为RKNN模型,而转换RKNN之前可以把模型先转换为ONNX模型,同时会生成best.anchors.txt:

python export.py --include onnx --rknpu RV1126 --weights ./runs/train/exp/weights/best.pt

生成如下图所示:

人工智能

4. rknn-toolkit模型转换

4.1 rknn-toolkit模型转换环境搭建

onnx模型需要转换为rknn模型才能在EASY-EAI-Nano-TB运行,所以需要先搭建rknn-toolkit模型转换工具的环境。当然tensorflow、tensroflow lite、caffe、darknet等也是通过类似的方法进行模型转换,只是本教程onnx为例。

4.1.1 概述

模型转换环境搭建流程如下所示:

人工智能

4.1.2 下载模型转换工具

为了保证模型转换工具顺利运行,请下载网盘里“06.AI算法开发/01.rknn-toolkit2模型转换工具/rknn-toolkit2-v2.3.2/docker/docker_image/rknn-toolkit2-v2.3.2-cp38-docker.tar.gz”

网盘下载链接:https://pan.baidu.com/s/1wUy-UBy9n81p7jlee_dBVA?pwd=1234提取码:1234。

4.1.3 把工具移到ubuntu20.04

把下载完成的docker镜像移到我司的虚拟机ubuntu20.04的rknn-toolkit2目录,如下图所示:

人工智能

4.1.4 运行模型转换工具环境

在该目录打开终端

人工智能

执行以下指令加载模型转换工具docker镜像:

docker load --input rknn-toolkit2-v2.3.2-cp38-docker.tar.gz

执行以下指令进入镜像bash环境:

docker run -t -i --privileged -v /dev/bus/usb:/dev/bus/usb -v /home/developer/rknn-toolkit2/model_convert_test:/test rknn-toolkit2:2.3.2-cp38 /bin/bash

现象如下图所示:

人工智能

输入“python”加载python相关库,尝试加载rknn库,如下图环境测试成功:

人工智能

至此,模型转换工具环境搭建完成。

4.2 型转换为RKNN

EASY-EAI-Nano-TB支持.rknn后缀的模型的评估及运行,对于常见的tensorflow、tensroflow lite、caffe、darknet、onnx和Pytorch模型都可以通过我们提供的 toolkit 工具将其转换至 rknn 模型,而对于其他框架训练出来的模型,也可以先将其转至 onnx 模型再转换为 rknn 模型。 模型转换操作流程入下图所示:

人工智能

4.2.1 模型转换Demo下载

下载百度网盘链接:https://pan.baidu.com/s/1bv3lBLFsClsX8a5n0L7Ppg?pwd=1234 提取码:1234。把 yolov5_model_convert.tar.bz2quant_dataset.zip解压到虚拟机,如下图所示:

人工智能

4.2.2 进入模型转换工具docker环境

执行以下指令把工作区域映射进docker镜像,其中/home/developer/rknn-toolkit2/model_convert为工作区域,/test为映射到docker镜像,/dev/bus/usb:/dev/bus/usb为映射usb到docker镜像:

docker run -t -i --privileged -v /dev/bus/usb:/dev/bus/usb -v /home/developer/rknn-toolkit2/model_convert:/test rknn-toolkit2:2.3.2-cp38 /bin/bash

执行成功如下图所示:

人工智能

4.2.3 模型转换Demo目录结构介绍

模型转换测试Demo由yolov5_model_convertquant_dataset组成。yolov5_model_convert存放软件脚本,quant_dataset存放量化模型所需的数据。如下图所示:

人工智能

yolov5_model_convert文件夹存放以下内容,如下图所示:

人工智能

4.2.4 生成量化图片列表

在docker环境切换到模型转换工作目录:

cd /test/yolov5_model_convert

如下图所示:

人工智能

执行gen_list.py生成量化图片列表:

python gen_list.py

命令行现象如下图所示:

人工智能

生成“量化图片列表”如下文件夹所示:

人工智能

4.2.5 onnx模型转换为rknn模型

rknn_convert.py脚本默认进行int8量化操作,脚本代码清单如下所示:

import os import urllib import traceback import time import sys import numpy as np import cv2 from rknn.api import RKNN ONNX_MODEL = 'best.onnx' RKNN_MODEL = './yolov5_mask_rv1126b.rknn' DATASET = './pic_path.txt' QUANTIZE_ON = True if __name__ == '__main__': # Create RKNN object rknn = RKNN(verbose=True) if not os.path.exists(ONNX_MODEL): print('model not exist') exit(-1) # pre-process config print('--> Config model') rknn.config(mean_values=[[0, 0, 0]], std_values=[[255, 255, 255]], target_platform = 'rv1126b') print('done') # Load ONNX model print('--> Loading model') ret = rknn.load_onnx(model=ONNX_MODEL) if ret != 0: print('Load yolov5 failed!') exit(ret) print('done') # Build model print('--> Building model') ret = rknn.build(do_quantization=QUANTIZE_ON, dataset=DATASET) if ret != 0: print('Build yolov5 failed!') exit(ret) print('done') # Export RKNN model print('--> Export RKNN model') ret = rknn.export_rknn(RKNN_MODEL) if ret != 0: print('Export yolov5rknn failed!') exit(ret) print('done')

把onnx模型best.onnx放到yolov5_model_convert目录,并执行rknn_convert.py脚本进行模型转换:

python rknn_convert.py

生成模型如下图所示,此模型可以在EASY EAI Nano-TB环境运行:

人工智能

5. 模型部署示例

5.1 模型部署示例介绍

本小节展示yolov5模型的在EASY EAI Nano-TB的部署过程,该模型仅经过简单训练供示例使用,不保证模型精度。

5.2 准备工作

5.2.1 硬件准备

需准备EASY EAI Nano-TB开发板,Type-C数据线、网线。可以基于MobaXterm的ssh远程桌面登录调试。首先使用网线把EASY EAI Nano-TB的千兆以太网接口连着路由LAN口的交换机或者路由器的LAN口连接,如下图所示。

人工智能

以及串口连接。

人工智能

5.2.2 开发环境准备

如果您初次阅读此文档,请阅读《入门指南/开发环境准备/Easy-Eai编译环境准备与更新》,并按照其相关的操作,进行编译环境的部署

在PC端Ubuntu系统中执行run脚本,进入EASY-EAI编译环境,具体如下所示。

cd ~/develop_environment ./run.sh 2204

人工智能

5.3 源码下载以及例程编译

下载yolov5 C Demo示例文件。

百度网盘链接: (https://pan.baidu.com/s/1oeCpFAcFdHgY_4FelAYP1Q?pwd=1234提取码:1234)。

下载程序包移至ubuntu环境后,执行以下指令解压:

tar -xvf yolov5_detect_C_demo.tar.bz2

下载解压后如下图所示:

人工智能

在EASY-EAI 编译环境下,进入到对应的例程目录执行编译操作,具体命令如下所示:

cd /opt/nfsroot/rknn-src/RV1126B/yolov5_detect_C_demo ./build.sh

人工智能

同时,把可执行程序目录yolov5_detect_demo_release/复制到开发板/userdata目录上:

cp yolov5_detect_demo_release/ /mnt/userdata/ -rf

人工智能

5.4 在开发板执行yolov5 目标检测算法

通过串口调试或ssh调试,进入板卡后台,定位到例程部署的位置,如下所示:

cd /userdata/yolov5_detect_demo_release/

 

人工智能

运行例程命令如下所示:

chmod 777 yolov5_detect_demo sudo ./yolov5_detect_demo

执行结果如下图所示,算法执行时间为38ms:

人工智能

在EASY-EAI编译环境可以取回测试图片:

cp /mnt/userdata/yolov5_detect_demo_release/result.jpg .

人工智能

测试结果如下图所示:

人工智能

至此,yolov5目标检测例程已成功在板卡运行。

6. 资料下载

人工智能
打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分