在 https://gitee.com/gpus/maskDetection_jetson 代码仓有个口罩识别的案例,我们来看看能不能在Jetson AGX Orin上搞定。
先将该代码仓fork到自己的代码仓(以便魔改)

回到自己的代码仓:

根据README.md来操作吧!
首先需要下载darknet框架并安装,但是众所周知,github不是很友好。
所以还是把 https://github.com/AlexeyAB/darknet 通过gitee来过渡:https://gitee.com/zhanghui_china/darknet

git clone https://gitee.com/zhanghui_china/darknet

根据README

我们来操作:
cd darknet
mkdir build_release
cd build_release
cmake ..

cmake的版本好像有点不够:
记得上次是装过cmake 3.23了。
那怎么回事呢?原来张小白上次整理存储,把/home/zhanghui下的很多东西都挪到/home/zhanghui1下面去了。
那就改一下.bashrc吧:

source ~/.bashrc
cmake --version
cd darknet/build_release/
cmake ..

cmake --build . --target install --parallel 12

...

成功完成安装。
下载darknet53.conv.74模型:
wget https://pjreddie.com/media/files/darknet53.conv.74

由于这又不是一个好的URL,张小白只好再用其他方法下载:

然后使用MobaXterm传到Orin上去。

下载口罩识别工程:
git clone https://gitee.com/zhanghui_china/maskDetection_jetson

cd maskDetection_jetson
unzip dataset.zip

执行 ./0_dataDispatch.py

执行结果如下:

修改mask.data文件:

将每个文件或目录名改为真实的地址:

复制 /home1/zhanghui/darknet/cfg/yolov4-tiny-custom.cfg 到当前目录:

根据以下要求:

修改 yolov4-tiny-custom.cfg

编辑 1_trainMask.sh

将前面下载的74文件移动到当前目录:

开始模型训练:

屏幕会闪很久:

据说Jetson Nano 4G会训练90分钟左右。
看看Orin到底需要训练多久:
在训练的过程中,Orin的风扇开始响了。前面都是静悄悄的干活。。。
我们另开一个终端窗口,打开jtop看下使用情况:
ALL:

GPU:

CPU:

确实有12个CPU。
看来主要是GPU在跑。
跑完了。

其实时间也帮我算了:
real 13m19.088s
user 26m12.781s
sys 2m59.157s
现在GPU是休息了:

看来算力比Jetson Nano 4G大很多的结论是没跑的了。(等有空把这些骚操作在我的Jetson Nano B01上试一下——你这个喜新厌旧的张小白。。。)
cp yolov4-tiny-custom.cfg yolov4-tiny-custom.cfg.train
再按照下面的指引:

修改yolov4-tiny-custom.cfg的参数:

像上图那样打开注释,增加注释即可。
修改推理代码 2_demoMask.sh

先用本地test试一下吧:
./2_demoMask.sh

由于MobaXterm的加持,图形界面显示到了Windows中:



从测试视频上来看,正面戴口罩识别率较好,侧脸识别率略差。也有误识别的情况:

你对着一个口罩识别它没有戴口罩是几个意思?
当然,也可以识别出人没有戴口罩:


识别完毕!
下次等张小白搞定了摄像头后,再来看下Jetson AGX Orin能否用摄像头识别有没有戴口罩。
(全文完,谢谢阅读)
















![[stm32]外中断控制灯光](https://img-blog.csdnimg.cn/17e739abf95f441098635e1722631807.png)


![2023年中国助消化药物行业现状分析:消化不良患者逐年上升,提升需求量[图]](https://img-blog.csdnimg.cn/img_convert/25439f200d470dba0ea0f58f272ab4c8.png)