0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

盘点TensorFlow在智能终端中的应用

jmiy_worldofai 来源:未知 作者:胡薇 2018-09-29 11:33 次阅读

深度学习在图像处理、语音识别、自然语言处理领域的应用取得了巨大成功,但是它通常在功能强大的服务器端进行运算。

如果智能手机通过网络远程连接服务器,也可以利用深度学习技术,但这样可能会很慢,而且只有在设备处于良好的网络连接环境下才行,这就需要把深度学习模型迁移到智能终端。

由于智能终端CPU和内存资源有限,为了提高运算性能和内存利用率,需要对服务器端的模型进行量化处理并支持低精度算法TensorFlow版本增加了对AndroidiOS和Raspberry Pi硬件平台的支持,允许它在这些设备上执行图像分类等操作。这样就可以创建在智能手机上工作并且不需要云端每时每刻都支持的机器学习模型,带来了新的APP。

本文主要基于看花识名APP应用,讲解TensorFlow模型如何应用于Android系统;在服务器端训练TensorFlow模型,并把模型文件迁移到智能终端;TensorFlow Android开发环境构建以及应用开发API。

看花识名APP

使用AlexNet模型、Flowers数据以及Android平台构建了“看花识名”APP。TensorFlow模型对五种类型的花数据进行训练。如下图所示:

Daisy:雏菊

Dandelion:蒲公英

Roses:玫瑰

Sunflowers:向日葵

Tulips:郁金香

在服务器上把模型训练好后,把模型文件迁移到Android平台,在手机上安装APP。使用效果如下图所示,界面上端显示的是模型识别的置信度,界面中间是要识别的花:

TensorFlow模型如何应用于看花识名APP中,主要包括以下几个关键步骤:模型选择和应用、模型文件转换以及Android开发。如下图所示:

模型训练及模型文件

本章采用AlexNet模型对Flowers数据进行训练。AlexNet在2012取得了ImageNet最好成绩,top 5准确率达到80.2%。这对于传统的机器学习分类算法而言,已经相当出色。模型结构如下:

本文采用TensorFlow官方Slim(https://github.com/tensorflow/models/tree/master/slim)AlexNet模型进行训练。

首先下载Flowers数据,并转换为TFRecord格式:

DATA_DIR=/tmp/data/flowers python download_and_convert_data.py --dataset_name=flowers --dataset_dir="${DATA_DIR}"

执行模型训练,经过36618次迭代后,模型精度达到85%

TRAIN_DIR=/tmp/data/train python train_image_classifier.py --train_dir=${TRAIN_DIR} --dataset_dir=${DATASET_DIR} --dataset_name=flowers --dataset_split_name=train --model_name=alexnet_v2 --preprocessing_name=vgg

生成Inference Graph的PB文件

python export_inference_graph.py --alsologtostderr --model_name=alexnet_v2 --dataset_name=flowers --dataset_dir=${DATASET_DIR} --output_file=alexnet_v2_inf_graph.pb

结合CheckPoint文件和Inference GraphPB文件,生成Freeze Graph的PB文件

python freeze_graph.py --input_graph=alexnet_v2_inf_graph.pb --input_checkpoint= ${TRAIN_DIR}/model.ckpt-36618 --input_binary=true --output_graph=frozen_alexnet_v2.pb --output_node_names=alexnet_v2/fc8/squeezed

对Freeze Graph的PB文件进行数据量化处理,减少模型文件的大小,生成的quantized_alexnet_v2_graph.pb为智能终端中应用的模型文件

bazel-bin/tensorflow/tools/graph_transforms/transform_graph --in_graph=frozen_alexnet_v2.pb --outputs="alexnet_v2/fc8/squeezed" --out_graph=quantized_alexnet_v2_graph.pb --transforms='add_default_attributes strip_unused_nodes(type=float, shape="1,224,224,3") remove_nodes(op=Identity, op=CheckNumerics) fold_constants(ignore_errors=true) fold_batch_norms fold_old_batch_norms quantize_weights quantize_nodes strip_unused_nodes sort_by_execution_order'

为了减少智能终端上模型文件的大小,TensorFlow中常用的方法是对模型文件进行量化处理,本文对AlexNet CheckPoint文件进行Freeze和Quantized处理后的文件大小变化如下图所示:

量化操作的主要思想是在模型的Inference阶段采用等价的8位整数操作代替32位的浮点数操作,替换的操作包括:卷积操作、矩阵相乘、激活函数、池化操作等。量化节点的输入、输出为浮点数,但是内部运算会通过量化计算转换为8位整数(范围为0到255)的运算,浮点数和8位量化整数的对应关系示例如下图所示:

量化Relu操作的基本思想如下图所示:

TensorFlow Android应用开发环境构建

在Android系统上使用TensorFlow模型做Inference依赖于两个文件libtensorflow_inference.so和libandroid_tensorflow_inference_java.jar。这两个文件可以通过下载TensorFlow源代码后,采用bazel编译出来,如下所示:

下载TensorFlow源代码

git clone --recurse-submoduleshttps://github.com/tensorflow/tensorflow.git

下载安装Android NDK

下载安装Android SDK

配置tensorflow/WORKSPACE中android开发工具路径

android_sdk_repository(name = "androidsdk", api_level = 23, build_tools_version = "25.0.2", path = "/opt/android",) android_ndk_repository(name="androidndk", path="/opt/android/android-ndk-r12b", api_level=14)

编译libtensorflow_inference.so

bazel build -c opt //tensorflow/contrib/android:libtensorflow_inference.so --crosstool_top=//external:android/crosstool --host_crosstool_top= @bazel_tools//tools/cpp:toolchain --cpu=armeabi-v7a

编译libandroid_tensorflow_inference_java.jar

bazel build //tensorflow/contrib/android:android_tensorflow_inference_java

TensorFlow提供了Android开发的示例框架,下面基于AlexNet模型的看花识名APP做一些相应源码的修改,并编译生成Android的安装包:

基于AlexNet模型,修改Inference的输入、输出的Tensor名称

private static final String INPUT_NAME = "input"; private static final String OUTPUT_NAME = "alexnet_v2/fc8/squeezed";

放置quantized_alexnet_v2_graph.pb和对应的labels.txt文件到assets目录下,并修改Android文件路径

private static final String MODEL_FILE = "file:///android_asset/quantized_alexnet_v2_graph.pb"; private static final String LABEL_FILE = "file:///android_asset/labels.txt";

编译生成安装包

bazel build -c opt //tensorflow/examples/android:tensorflow_demo

拷贝tensorflow_demo.apk到手机上,并执行安装,太阳花识别效果如下图所示:

(点击放大图像)

TensorFlow移动端应用开发API

在Android系统中执行TensorFlow Inference操作,需要调用libandroid_tensorflow_inference_java.jar中的JNI接口,主要接口如下:

构建TensorFlow Inference对象,构建该对象时候会加载TensorFlow动态链接库libtensorflow_inference.so到系统中;参数assetManager为android asset管理器;参数modelFilename为TensorFlow模型文件在android_asset中的路径。

TensorFlowInferenceInterface inferenceInterface = new TensorFlowInferenceInterface(assetManager, modelFilename);

向TensorFlow图中加载输入数据,本App中输入数据为摄像头截取到的图片;参数inputName为TensorFlow Inference中的输入数据Tensor的名称;参数floatValues为输入图片的像素数据,进行预处理后的浮点值;[1,inputSize,inputSize,3]为裁剪后图片的大小,比如1张224*224*3的RGB图片。

inferenceInterface.feed(inputName, floatValues, 1, inputSize, inputSize, 3);

执行模型推理; outputNames为TensorFlow Inference模型中要运算Tensor的名称,本APP中为分类的Logist值。

inferenceInterface.run(outputNames);

获取模型Inference的运算结果,其中outputName为Tensor名称,参数outputs存储Tensor的运算结果。本APP中,outputs为计算得到的Logist浮点数组。

inferenceInterface.fetch(outputName, outputs);

总结

本文基于看花识名APP,讲解了TensorFlow在Android智能终端中的应用技术。首先回顾了AlexNet模型结构,基于AlexNet的slim模型对Flowers数据进行训练;对训练后的CheckPoint数据,进行Freeze和Quantized处理,生成智能终端要用的Inference模型。然后介绍了TensorFlow Android应用开发环境的构建,编译生成TensorFlow在Android上的动态链接库以及java开发包;文章最后介绍了Inference API的使用方式。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 智能终端
    +关注

    关注

    6

    文章

    808

    浏览量

    34274
  • 深度学习
    +关注

    关注

    73

    文章

    5218

    浏览量

    119850
  • tensorflow
    +关注

    关注

    13

    文章

    313

    浏览量

    60240

原文标题:深度学习利器:TensorFlow在智能终端中的应用

文章出处:【微信号:worldofai,微信公众号:worldofai】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    三防平板丨平板终端丨仓库盘点应用

    三防平板是一种能够在恶劣环境下使用的电子设备,其具有防水、防尘、抗震等特性,适用于各种场合,包括仓库盘点。在现代物流行业中,对于仓库盘点来说,三防平板不仅能够提高盘点效率,还可以有效地减少人为错误和操作失误。本文将介绍三防平板在
    的头像 发表于 02-19 09:51 83次阅读
    三防平板丨平板<b class='flag-5'>终端</b>丨仓库<b class='flag-5'>盘点</b>应用

    如何使用TensorFlow构建机器学习模型

    在这篇文章中,我将逐步讲解如何使用 TensorFlow 创建一个简单的机器学习模型。
    的头像 发表于 01-08 09:25 312次阅读
    如何使用<b class='flag-5'>TensorFlow</b>构建机器学习模型

    车载终端功能盘点(车载终端工业行业解决方案案例)

    ​ 随着车联网的蓬勃发展,车载终端在物流运输、公共交通等领域得到广泛应用。车载终端以其强大的功能,为不同行业提供定制化的解决方案。本文将盘点车载终端的核心功能,并给出工业场景的应用案例
    的头像 发表于 11-17 14:28 224次阅读
    车载<b class='flag-5'>终端</b>功能<b class='flag-5'>盘点</b>(车载<b class='flag-5'>终端</b>工业行业解决方案案例)

    PDA手持终端设备在仓库固定资产盘点中的应用

    相符。传统的资产盘点方式需要大量的人力和时间,容易出现错误和延误。而PDA手持终端设备的应用可以极大地提高盘点效率和准确性,正为这一过程带来革命性的改变。PDA手持终端
    的头像 发表于 10-17 14:07 351次阅读
    PDA手持<b class='flag-5'>终端</b>设备在仓库固定资产<b class='flag-5'>盘点</b>中的应用

    远景达MV8工业手持智能移动终端(PDA),让药品盘点更轻松!

    患者信息管理、移动护理、药品追溯...都可以通过二维码数据采集搞定。对于药品盘点来说,也不例外,借助工业级智能手持终端,只需简单地使用设备进行扫描,即可自动采集、
    的头像 发表于 10-10 14:16 634次阅读
    远景达MV8工业手持<b class='flag-5'>智能</b>移动<b class='flag-5'>终端</b>(PDA),让药品<b class='flag-5'>盘点</b>更轻松!

    如何用BMlang搭建Tensorflow模型?

    EVM1684上如何用BMlang搭建一个Tensorflow模型,求助官方一个demo。
    发表于 09-18 07:00

    道尔芬智能终端客户现场

    智能终端
    道尔芬智能
    发布于 :2023年09月01日 10:56:24

    深度学习框架tensorflow介绍

    深度学习框架tensorflow介绍 深度学习框架TensorFlow简介 深度学习框架TensorFlow由Google开发,是一个开放源代码的深度学习框架,可用于构建人工智能应用程
    的头像 发表于 08-17 16:11 1352次阅读

    TensorFlow将神经网络量化为8位

    随着TensorFlow Lite的推出,TensorFlow已经更新了量化技术和工具,您可以使用这些技术和工具来提高网络性能。 本指南向您展示如何量化网络,使其训练过程中使用8位数
    发表于 08-10 06:01

    如何使用TensorFlow将神经网络模型部署到移动或嵌入式设备上

    、iOS和Linux。每个框架和操作系统的部署过程是相似的,但每个框架和系统可能使用不同的工具。本演练专门介绍Android、Linux和iOS上部署TensorFlow模型的准备工作
    发表于 08-02 06:43

    东集AUTOID UTouch超高频手持终端怎么进行固定资产盘点

    。接下来,我们了解一下AUTOID UTouch超高频手持终端在固定资产盘点中的具体操作流程: 1、企业需要为每个固定资产贴上RFID标签,并记录下标签ID和相应资产的信息,包括名称、型号、采购日期等。 2、盘点人员使用AUTO
    的头像 发表于 07-21 09:54 359次阅读

    使用Wio Terminal和Tensorflow Lite创建智能气象站

    电子发烧友网站提供《使用Wio Terminal和Tensorflow Lite创建智能气象站.zip》资料免费下载
    发表于 06-25 10:30 0次下载
    使用Wio Terminal和<b class='flag-5'>Tensorflow</b> Lite创建<b class='flag-5'>智能</b>气象站

    盘点最新光纤终端盒的作用

      光缆尾纤如果想要连接就要用到光纤终端盒了,光纤终端盒是把一条光缆拆分成单条光纤的设备,安装在墙上的用户光缆终端盒,它的功能是提供光纤与光纤的熔接、光纤与尾纤的熔接以及光连接器的交接。下面科兰下边为大家
    的头像 发表于 06-06 09:59 613次阅读

    如何使用meta-imx层中提供的tensorflow-lite编译图像?

    我们正在尝试使用 meta-imx 层中提供的 tensorflow-lite 编译图像。我们没有任何 自定义更改/bbappends (Highlight to read)sources
    发表于 05-29 06:55

    L5.4.47_2.2.0Tensorflow Lite 2.2.0 NNAPI内存不足怎么处理?

    L5.4.47_2.2.0 Tensorflow Lite 2.2.0 NNAPI 内存不足
    发表于 04-21 06:38