![《架构师》2019年12月](https://wfqqreader-1252317822.image.myqcloud.com/cover/593/29101593/b_29101593.jpg)
特别专栏 | Column
在ARM盒子上使用IEF和Tensorflow Lite运行边缘AI
![](https://epubservercos.yuewen.com/955689/16256965504086606/epubprivate/OEBPS/Images/figure_0052_0001.jpg?sign=1738805545-l4glldSPnSw332mQfXCCxPOT0wdfUV0q-0-e0afaf6447c98ff8fa43633531072ffc)
场景介绍
在ARM盒子(我使用atlas500, arm64v8架构可以直接使用代码和镜像)上,接入网络摄像头,使用tensorflow lite框架,对图像进行图像分类推理,图像分类推理结果通过MQTT协议推送到web页面上进行展示。参考“在ARM盒子使用IEF和Tensorflow运行边缘AI”,这次使用tensorflow lite框架,并把对象检测模型更换成图像分类模型。
![](https://epubservercos.yuewen.com/955689/16256965504086606/epubprivate/OEBPS/Images/figure_0052_0002.jpg?sign=1738805545-v7IuCYkjFScZk6XjwXbSO3NdFQq6Dcmb-0-49eb18a7bd735ffa154958a6557ab14a)
运行环境
· 网络摄像头,支持RTSP协议,ipc格式
· 智能小站(atlas500),EulerOS
· tensorflow1.4.0, python2.7
· mosquitto 1.6.5
· python: opencv-python 4.1.1, paho-mqtt 1.4.0
· nodejs: mqtt 3.0.0, react 16.9.0
安装运行步骤
参考“在ARM盒子上使用IEF和Tensorflow运行边缘AI”,本文仅更换成tensorflow lite框架,并使用图像分类模型。
通过tensorflow对图像进行图像分类推理
先从
https://tensorflow.google.cn/lite/models/image_classification/overview
下载图像分类模型
并解压出模型和分类标签。
参考
代码,添加opencv对rtsp协议进行解析,并获取每一帧图像。针对图像数据,运行模型推理进行图像分类。最终推理的结果使用MQTT协议把结果发送出来。
参考代码-----如下:
![](https://epubservercos.yuewen.com/955689/16256965504086606/epubprivate/OEBPS/Images/figure_0054_0001.jpg?sign=1738805545-hoQay5YrxneQHeoFlcDPph4Qf9UNWpo3-0-c3eb91542cc8dfa2ea35be68337562eb)
完整的docker image可以在docker hub上参考
braveyuyong/tf_on_atlas:tagname:0.2.1-lite,
参考dockerfile如下:
![](https://epubservercos.yuewen.com/955689/16256965504086606/epubprivate/OEBPS/Images/figure_0055_0001.jpg?sign=1738805545-xrrBGSWWAo7WIcnx6pCnqgddoWJWb0zM-0-2fbd40cd5ba31b3ee59120c868a68a18)
最终效果
![](https://epubservercos.yuewen.com/955689/16256965504086606/epubprivate/OEBPS/Images/figure_0055_0002.jpg?sign=1738805545-bIlkR2Rw9QeLH2wHo1zyGlRel14nVWe3-0-be73125cadb05284d3253fd4192bd90d)
参考"在ARM盒子使用IEF和Tensorflow运行边缘AI"中下发应用,最终通过浏览器IE11打开http://192.168.1.111:3001,如果能看到摄像头视频流和图像分类结果,表明大功告成!