data:image/s3,"s3://crabby-images/31c5d/31c5df440d4718341b062aade11cabcead6466c4" alt="《架构师》2019年12月"
特别专栏 | Column
在ARM盒子上使用IEF和Tensorflow Lite运行边缘AI
data:image/s3,"s3://crabby-images/cddea/cddea1810eeaf9272ba881b382811bc6d7f57404" alt=""
场景介绍
在ARM盒子(我使用atlas500, arm64v8架构可以直接使用代码和镜像)上,接入网络摄像头,使用tensorflow lite框架,对图像进行图像分类推理,图像分类推理结果通过MQTT协议推送到web页面上进行展示。参考“在ARM盒子使用IEF和Tensorflow运行边缘AI”,这次使用tensorflow lite框架,并把对象检测模型更换成图像分类模型。
data:image/s3,"s3://crabby-images/56965/56965133e3f9c54234673aad6fcd157d8d190cf4" alt=""
运行环境
· 网络摄像头,支持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协议把结果发送出来。
参考代码-----如下:
data:image/s3,"s3://crabby-images/d4fc5/d4fc59d36ee1f08e37d75a4cde4e45fb6332e505" alt=""
完整的docker image可以在docker hub上参考
braveyuyong/tf_on_atlas:tagname:0.2.1-lite,
参考dockerfile如下:
data:image/s3,"s3://crabby-images/78955/78955eff170852f11402b16a27fdd0b47e98997c" alt=""
最终效果
data:image/s3,"s3://crabby-images/26ea0/26ea05d9766cca7c31d0bd2592703cdd41f50058" alt=""
参考"在ARM盒子使用IEF和Tensorflow运行边缘AI"中下发应用,最终通过浏览器IE11打开http://192.168.1.111:3001,如果能看到摄像头视频流和图像分类结果,表明大功告成!