用YOLOv5代码训练模型并部署到Android客户端


仅做记录。


YOLOv5代码来源

训练模型时遇到的问题

(1)RuntimeError: CUDA error: no kernel image is available for execution on the device

报错信息显示显卡的CUDA计算能力和pytorch版本不匹配
安装适用于使用显卡的pytorch
卸载当前版本的pytorch, 重新安装匹配版本

pip uninstall torch
pip uninstall torchvision
pip install torch==1.7.0+cu110 torchvision==0.8.1+cu110 torchaudio===0.7.0 -f https://download.pytorch.org/whl/torch_stable.html -i  https://pypi.tuna.tsinghua.edu.cn/simple/

注意上面的内容要与自己的cuda版本匹配哈,怎么查看当前环境的cuda版本,命令如下:

查看可用cuda最大可用版本:

nvidia-smi

在这里插入图片描述
查看当前环境的cuda版本:

nvcc -V

在这里插入图片描述

(2)在vscode上使用tensorboard

(1)找到log文件的保存地址:
在这里插入图片描述
(2)vscode连接上服务器之后,在终端输入:

tensorboard --logdir=/databank/home/**/**/yolov5/runs/train/exp12/   #这里的地址为上述地址

在这里插入图片描述
这样就可以啦!!!

将YOLOv5训练得到的模型部署到Android客户端:

配置好环境,使用如下命令,运行train.py文件得到“.pt”模型

YOLOv5代码来源

CUDA_VISIBLE_DEVICES=0 python train.py --img 640 --batch 16 --epochs 300 --data  data/my.yaml  --weights weights/yolov5s.pt

在这里插入图片描述

使用export.py中代码将“.pt”模型转为“.torchscript.ptl”模型

注意,原export.py中只能将“.pt”模型转为“.torchscript.pt”,不能转为“.torchscript.ptl”,所以需要稍微修改下代码,具体如下:

在这里插入图片描述
把蓝色框中代码注释掉,并写入红色框中代码:

f = file.with_suffix('.torchscript.ptl')
(optimize_for_mobile(ts) if optimize else ts)._save_for_lite_interpreter(str(f))

然后使用如下命令:

python export.py --weights runs/train/exp11/weights/best.pt --include torchscript

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

将生成的best.torchscript.ptl模型部署到android客户端进行目标检测

Git中提供的android-demo-app模板代码
(1)在MainActivity.java文件中改变自己的图片列表:
在这里插入图片描述

private String[] mTestImages = {"aicook1.jpg", "aicook2.jpg", "aicook3.jpg", "test1.png", "test2.jpg", "test3.png"};

(2)在MainActivity.java文件中改成自己的模型:
在这里插入图片描述

mModule = LiteModuleLoader.load(MainActivity.assetFilePath(getApplicationContext(), "best.torchscript.ptl"));
BufferedReader br = new BufferedReader(new InputStreamReader(getAssets().open("aicook.txt")));

(3)将PrePostProcessor.java中的mOutputColumn的数值改为自己模型的预测种类+5,例如,如果自己模型可以检测的目标种类为30,则值为30+5=35;
在这里插入图片描述

private static int mOutputColumn = 35;

(4)将ObjectDetectionActivity.java文件中的模型也给成自己的:
在这里插入图片描述

mModule = LiteModuleLoader.load(MainActivity.assetFilePath(getApplicationContext(), "yolov5s.torchscript.ptl"));

(5)运行demo_app
在这里插入图片描述


  • 5
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
YOLOv5 训练好的模型部署到树莓派需要以下步骤: 1. 安装必要的依赖项和软件包:首先,您需要在树莓派上安装必要的依赖项和软件包,例如 OpenCV 和 PyTorch。您可以使用以下命令在树莓派上安装它们: ``` sudo apt install python3-opencv sudo pip3 install torch torchvision ``` 2. 将 YOLOv5 模型转换为 TorchScript 格式:YOLOv5 模型是以 PyTorch 训练的,因此您需要将其转换为 TorchScript 格式,这样可以更快地在树莓派上运行。您可以使用以下命令将模型转换为 TorchScript 格式: ``` python3 models/export.py --weights <path_to_your_weights> --img 640 --batch 1 ``` 其中,`<path_to_your_weights>` 是您训练好的权重文件的路径。这将生成一个名为 `yolov5s.torchscript.pt` 的文件。 3. 在 Python 中加载 TorchScript 模型:在 Python 中加载 TorchScript 模型非常简单。您只需要使用以下代码即可加载模型: ```python import torch model = torch.jit.load('yolov5s.torchscript.pt') ``` 4. 在树莓派上运行推理:最后,您需要在树莓派上运行推理以检测对象。您可以使用以下代码运行推理: ```python import cv2 cap = cv2.VideoCapture(0) while True: ret, frame = cap.read() # 进行图像预处理 # 进行推理 # 处理推理结果 cv2.imshow('frame', frame) if cv2.waitKey(1) == ord('q'): break cap.release() cv2.destroyAllWindows() ``` 在这个代码片段中,我们首先使用 OpenCV 从摄像头中读取帧。然后我们进行图像预处理,例如调整大小和归一化。接下来,我们将图像输入 TorchScript 模型进行推理,并处理推理结果。最后,我们将帧显示在屏幕上。 注意,这只是一个简单的示例,并且您需要根据您的应用程序进行更改。例如,您可能需要使用 GPIO 控制树莓派上的 LED 灯或马达。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值