前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >在树莓派4B上使用YOLO v3 Tiny进行实时目标检测

在树莓派4B上使用YOLO v3 Tiny进行实时目标检测

作者头像
全栈程序员站长
发布2022-06-27 10:32:25
1.8K0
发布2022-06-27 10:32:25
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

首先尝试使用yolo官网yolo给的教程,在树莓派上测试,但是在运行时出现段错误,尝试很多方法无法解决。在国外的网站找到darknet-nnpack这个东西,可以完美的在树莓派上运行。

链接:https://pan.baidu.com/s/1-7DFRawhDDZXfrKH9aht6g 提取码:k3yp,评论说编译不通过,这里给出我用的ninja和NNPACK 参考的文章

  1. darknet-nnpack https://github.com/zxzhaixiang/darknet-nnpack
  2. Fun of DIY http://funofdiy.blogspot.com/2018/08/deep-learning-with-raspberry-pi-real.html 第二个链接是树莓派3B+上使用yolo,不过国内正常是打不开,根据这篇文章在Raspberry Pi 4上使用yolov3 tiny版本,测试结果可以达到2帧,这个结果是做了很多加速之后的。
  3. 安装NNPACK,这是神经网络的加速库,可以在多核CPU上运行
  4. 在Makefile中添加一些特殊配置,以在Cortex CPU和NNPACK优化上编译Darknet Yolo源代码。
  5. 安装opencv C ++(在raspberry pi上非常麻烦),不过我没安装也可以使用(编译总是报错,没有成功)
  6. 使用Yolo小版本(不是完整版本)运行Darknet!下载Yolov3-tiny.cfg和Yolov3-tiny.weights。

步骤0:准备工作

  1. 在树莓派4上安装系统等参考我的这篇博客
  2. 准备Python和Pi相机,我用的是树莓派的相机,使用usb摄像头会慢很多。 安装OpenCV。使用最简单的方法(不要从源代码构建!):
代码语言:javascript
复制
sudo apt-get install python-opencv

如果没有pip:

代码语言:javascript
复制
sudo apt-get install python-pip

启用pi相机:

代码语言:javascript
复制
sudo raspi-config

转到 Interfacing Options,然后启用 Pi/Camera,重启生效。

步骤1 安装 Ninja Building tool

安装 PeachPy 和 confu

代码语言:javascript
复制
sudo pip install --upgrade git+https://github.com/Maratyszcza/PeachPy
sudo pip install --upgrade git+https://github.com/Maratyszcza/confu

在 /home/pi目录下,安装ninja

代码语言:javascript
复制
git clone https://github.com/ninja-build/ninja.git
cd ninja
git checkout release
./configure.py --bootstrap
export NINJA_PATH=$PWD
cd

步骤2 安装修改后的 NNPACK

代码语言:javascript
复制
git clone https://github.com/shizukachan/NNPACK
cd NNPACK
confu setup
python ./configure.py --backend auto

用ninja构建NNPACK(需要一段时间,耐心等待,并且第一次可能崩溃。只需重新启动并再次运行):

代码语言:javascript
复制
$NINJA_PATH/ninja

可以用 ls ,有文件夹 lib , include 就成功了。 测试NNPACK是否正常工作:

代码语言:javascript
复制
bin/convolution-inference-smoketest

我第一次失败了,不过再次运行了测试,所有项目都通过了。因此,如果测试失败,请不要慌张,再尝试一次。

将库和头文件复制到系统环境:

代码语言:javascript
复制
sudo cp -a lib/* /usr/lib/
sudo cp include/nnpack.h /usr/include/
sudo cp deps/pthreadpool/include/pthreadpool.h /usr/include/

步骤3 安装darknet-nnpack

上面这些步骤其实都是安装darknet-nnpack的准备工作,现在正式开始

代码语言:javascript
复制
cd
git clone -b yolov3 https://github.com/zxzhaixiang/darknet-nnpack
cd darknet-nnpack
git checkout yolov3
make

这就完成了,开始测试。

步骤4 用YoloV3-tiny测试

运行:

代码语言:javascript
复制
sudo python rpi_video.py

或者:

代码语言:javascript
复制
sudo python rpi_record.py

也可以调一下参数:

代码语言:javascript
复制
yolo_proc = Popen(["./darknet",
                   "detect",
                   "./cfg/yolov3-tiny.cfg",
                   "./yolov3-tiny.weights",
                   "-thresh", "0.1"],
                   stdin = PIPE, stdout = PIPE)

这两个python文件,只是提供了一个进出的功能。 rpi_video.py 以动画形式在屏幕上显示实时目标检测结果; rpi_record.py 会将每一帧结果保存(如之后制作git动画)。 另外YoloV3-tiny不在乎输入图像的大小。因此,只要高度和宽度均为32的整数倍,就可以随意调整相机分辨率。

代码语言:javascript
复制
#camera.resolution = (224, 224)
#camera.resolution = (608, 608)
camera.resolution = (544, 416)

看下结果,还需要优化

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

竟然把人检测出sofa了

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

检测速度可以达到每秒2帧,树莓派4的性能比3B+要强很多,3B+只能达到1帧。 总的来说非常棒了。 参考博客:http://funofdiy.blogspot.com/2018/08/deep-learning-with-raspberry-pi-real.html

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/133340.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年6月9,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 步骤0:准备工作
  • 步骤1 安装 Ninja Building tool
  • 步骤2 安装修改后的 NNPACK
  • 步骤3 安装darknet-nnpack
  • 步骤4 用YoloV3-tiny测试
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档