0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

盤點TensorFlow在智能終端中的應(yīng)用

jmiy_worldofai ? 來源:未知 ? 作者:胡薇 ? 2018-09-29 11:33 ? 次閱讀

深度學(xué)習(xí)在圖像處理、語音識別、自然語言處理領(lǐng)域的應(yīng)用取得了巨大成功,但是它通常在功能強大的服務(wù)器端進行運算。

如果智能手機通過網(wǎng)絡(luò)遠程連接服務(wù)器,也可以利用深度學(xué)習(xí)技術(shù),但這樣可能會很慢,而且只有在設(shè)備處于良好的網(wǎng)絡(luò)連接環(huán)境下才行,這就需要把深度學(xué)習(xí)模型遷移到智能終端。

由于智能終端CPU和內(nèi)存資源有限,為了提高運算性能和內(nèi)存利用率,需要對服務(wù)器端的模型進行量化處理并支持低精度算法。TensorFlow版本增加了對AndroidiOS和Raspberry Pi硬件平臺的支持,允許它在這些設(shè)備上執(zhí)行圖像分類等操作。這樣就可以創(chuàng)建在智能手機上工作并且不需要云端每時每刻都支持的機器學(xué)習(xí)模型,帶來了新的APP。

本文主要基于看花識名APP應(yīng)用,講解TensorFlow模型如何應(yīng)用于Android系統(tǒng);在服務(wù)器端訓(xùn)練TensorFlow模型,并把模型文件遷移到智能終端;TensorFlow Android開發(fā)環(huán)境構(gòu)建以及應(yīng)用開發(fā)API。

看花識名APP

使用AlexNet模型、Flowers數(shù)據(jù)以及Android平臺構(gòu)建了“看花識名”APP。TensorFlow模型對五種類型的花數(shù)據(jù)進行訓(xùn)練。如下圖所示:

Daisy:雛菊

Dandelion:蒲公英

Roses:玫瑰

Sunflowers:向日葵

Tulips:郁金香

在服務(wù)器上把模型訓(xùn)練好后,把模型文件遷移到Android平臺,在手機上安裝APP。使用效果如下圖所示,界面上端顯示的是模型識別的置信度,界面中間是要識別的花:

TensorFlow模型如何應(yīng)用于看花識名APP中,主要包括以下幾個關(guān)鍵步驟:模型選擇和應(yīng)用、模型文件轉(zhuǎn)換以及Android開發(fā)。如下圖所示:

模型訓(xùn)練及模型文件

本章采用AlexNet模型對Flowers數(shù)據(jù)進行訓(xùn)練。AlexNet在2012取得了ImageNet最好成績,top 5準確率達到80.2%。這對于傳統(tǒng)的機器學(xué)習(xí)分類算法而言,已經(jīng)相當出色。模型結(jié)構(gòu)如下:

本文采用TensorFlow官方Slim(https://github.com/tensorflow/models/tree/master/slim)AlexNet模型進行訓(xùn)練。

首先下載Flowers數(shù)據(jù),并轉(zhuǎn)換為TFRecord格式:

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

執(zhí)行模型訓(xùn)練,經(jīng)過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

結(jié)合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文件進行數(shù)據(jù)量化處理,減少模型文件的大小,生成的quantized_alexnet_v2_graph.pb為智能終端中應(yīng)用的模型文件

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位整數(shù)操作代替32位的浮點數(shù)操作,替換的操作包括:卷積操作、矩陣相乘、激活函數(shù)、池化操作等。量化節(jié)點的輸入、輸出為浮點數(shù),但是內(nèi)部運算會通過量化計算轉(zhuǎn)換為8位整數(shù)(范圍為0到255)的運算,浮點數(shù)和8位量化整數(shù)的對應(yīng)關(guān)系示例如下圖所示:

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

TensorFlow Android應(yīng)用開發(fā)環(huán)境構(gòu)建

在Android系統(tǒng)上使用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開發(fā)工具路徑

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開發(fā)的示例框架,下面基于AlexNet模型的看花識名APP做一些相應(yīng)源碼的修改,并編譯生成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和對應(yīng)的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到手機上,并執(zhí)行安裝,太陽花識別效果如下圖所示:

(點擊放大圖像)

TensorFlow移動端應(yīng)用開發(fā)API

在Android系統(tǒng)中執(zhí)行TensorFlow Inference操作,需要調(diào)用libandroid_tensorflow_inference_java.jar中的JNI接口,主要接口如下:

構(gòu)建TensorFlow Inference對象,構(gòu)建該對象時候會加載TensorFlow動態(tài)鏈接庫libtensorflow_inference.so到系統(tǒng)中;參數(shù)assetManager為android asset管理器;參數(shù)modelFilename為TensorFlow模型文件在android_asset中的路徑。

TensorFlowInferenceInterface inferenceInterface = new TensorFlowInferenceInterface(assetManager, modelFilename);

向TensorFlow圖中加載輸入數(shù)據(jù),本App中輸入數(shù)據(jù)為攝像頭截取到的圖片;參數(shù)inputName為TensorFlow Inference中的輸入數(shù)據(jù)Tensor的名稱;參數(shù)floatValues為輸入圖片的像素數(shù)據(jù),進行預(yù)處理后的浮點值;[1,inputSize,inputSize,3]為裁剪后圖片的大小,比如1張224*224*3的RGB圖片。

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

執(zhí)行模型推理; outputNames為TensorFlow Inference模型中要運算Tensor的名稱,本APP中為分類的Logist值。

inferenceInterface.run(outputNames);

獲取模型Inference的運算結(jié)果,其中outputName為Tensor名稱,參數(shù)outputs存儲Tensor的運算結(jié)果。本APP中,outputs為計算得到的Logist浮點數(shù)組。

inferenceInterface.fetch(outputName, outputs);

總結(jié)

本文基于看花識名APP,講解了TensorFlow在Android智能終端中的應(yīng)用技術(shù)。首先回顧了AlexNet模型結(jié)構(gòu),基于AlexNet的slim模型對Flowers數(shù)據(jù)進行訓(xùn)練;對訓(xùn)練后的CheckPoint數(shù)據(jù),進行Freeze和Quantized處理,生成智能終端要用的Inference模型。然后介紹了TensorFlow Android應(yīng)用開發(fā)環(huán)境的構(gòu)建,編譯生成TensorFlow在Android上的動態(tài)鏈接庫以及java開發(fā)包;文章最后介紹了Inference API的使用方式。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 智能終端
    +關(guān)注

    關(guān)注

    6

    文章

    885

    瀏覽量

    34813
  • 深度學(xué)習(xí)
    +關(guān)注

    關(guān)注

    73

    文章

    5511

    瀏覽量

    121355
  • tensorflow
    +關(guān)注

    關(guān)注

    13

    文章

    329

    瀏覽量

    60575

原文標題:深度學(xué)習(xí)利器:TensorFlow在智能終端中的應(yīng)用

文章出處:【微信號:worldofai,微信公眾號:worldofai】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    工業(yè)級智能手持終端:倉庫盤點與出入庫管理的得力助手

    在當今快節(jié)奏的商業(yè)環(huán)境,倉庫管理的效率和準確性對于企業(yè)的運營至關(guān)重要。工業(yè)級智能手持終端的出現(xiàn),為倉庫盤點與出入庫管理帶來了革命性的變化。工業(yè)級
    的頭像 發(fā)表于 01-08 16:09 ?78次閱讀
    工業(yè)級<b class='flag-5'>智能</b>手持<b class='flag-5'>終端</b>:倉庫<b class='flag-5'>盤點</b>與出入庫管理的得力助手

    重磅盤點 | 自連智能終端明星產(chǎn)品系列

    無論工業(yè)、醫(yī)療、城市還是教育領(lǐng)域,當前各行各業(yè)都迎來了智慧升級的快速發(fā)展。作為深耕物聯(lián)網(wǎng)10年的通信老兵,自連自主研發(fā)的智能終端產(chǎn)品系列,不同場景中發(fā)揮著應(yīng)有的重要作用。今天,小編
    的頭像 發(fā)表于 10-24 17:25 ?197次閱讀

    智能AI終端故障診斷具體是如何工作的?

    梯云物聯(lián)的智能AI終端故障診斷扮演著至關(guān)重要的角色。這一系統(tǒng)通過集成先進的物聯(lián)網(wǎng)技術(shù)、大數(shù)據(jù)分析和人工智能算法,實現(xiàn)了電梯維保與急修的精
    的頭像 發(fā)表于 10-17 11:46 ?259次閱讀

    如何在Tensorflow實現(xiàn)反卷積

    TensorFlow實現(xiàn)反卷積(也稱為轉(zhuǎn)置卷積或分數(shù)步長卷積)是一個涉及多個概念和步驟的過程。反卷積在深度學(xué)習(xí)領(lǐng)域,特別是圖像分割、圖像超分辨率、以及生成模型(如生成對抗網(wǎng)絡(luò)GA
    的頭像 發(fā)表于 07-14 10:46 ?674次閱讀

    TensorFlow是什么?TensorFlow怎么用?

    TensorFlow是由Google開發(fā)的一個開源深度學(xué)習(xí)框架,它允許開發(fā)者方便地構(gòu)建、訓(xùn)練和部署各種復(fù)雜的機器學(xué)習(xí)模型。TensorFlow憑借其高效的計算性能、靈活的架構(gòu)以及豐富的工具和庫,在學(xué)
    的頭像 發(fā)表于 07-12 16:38 ?763次閱讀

    tensorflow和pytorch哪個更簡單?

    PyTorch更簡單。選擇TensorFlow還是PyTorch取決于您的具體需求和偏好。如果您需要一個易于使用、靈活且具有強大社區(qū)支持的框架,PyTorch可能是一個更好的選擇。如果您需要一個
    的頭像 發(fā)表于 07-05 09:45 ?929次閱讀

    tensorflow和pytorch哪個好

    tensorflow和pytorch都是非常不錯的強大的框架,TensorFlow還是PyTorch哪個更好取決于您的具體需求,以下是關(guān)于這兩個框架的一些關(guān)鍵點: TensorFlow : 發(fā)布時間
    的頭像 發(fā)表于 07-05 09:42 ?735次閱讀

    tensorflow簡單的模型訓(xùn)練

    本文中,我們將詳細介紹如何使用TensorFlow進行簡單的模型訓(xùn)練。TensorFlow是一個開源的機器學(xué)習(xí)庫,廣泛用于各種機器學(xué)習(xí)任務(wù),包括圖像識別、自然語言處理等。我們將從安裝
    的頭像 發(fā)表于 07-05 09:38 ?737次閱讀

    keras模型轉(zhuǎn)tensorflow session

    在這篇文章,我們將討論如何將Keras模型轉(zhuǎn)換為TensorFlow session。 Keras和TensorFlow簡介 Keras是一個高級神經(jīng)網(wǎng)絡(luò)API,它提供了一種簡單、快速的方式來構(gòu)建
    的頭像 發(fā)表于 07-05 09:36 ?570次閱讀

    TensorFlow的定義和使用方法

    TensorFlow是一個由谷歌人工智能團隊谷歌大腦(Google Brain)開發(fā)和維護的開源機器學(xué)習(xí)庫。它基于數(shù)據(jù)流編程(dataflow programming)的概念,將復(fù)雜的數(shù)學(xué)運算表示為
    的頭像 發(fā)表于 07-02 14:14 ?841次閱讀

    TensorFlow與PyTorch深度學(xué)習(xí)框架的比較與選擇

    深度學(xué)習(xí)作為人工智能領(lǐng)域的一個重要分支,在過去十年取得了顯著的進展。構(gòu)建和訓(xùn)練深度學(xué)習(xí)模型的過程,深度學(xué)習(xí)框架扮演著至關(guān)重要的角色。Tenso
    的頭像 發(fā)表于 07-02 14:04 ?1018次閱讀

    工控電腦一體機商業(yè)智能終端的應(yīng)用

     工控電腦一體機商業(yè)智能終端的應(yīng)用,主要體現(xiàn)在其高穩(wěn)定性、強大的數(shù)據(jù)處理能力以及適應(yīng)復(fù)雜商業(yè)環(huán)境的能力上。以下是工控電腦一體機商業(yè)
    的頭像 發(fā)表于 06-20 09:46 ?514次閱讀
    工控電腦一體機<b class='flag-5'>在</b>商業(yè)<b class='flag-5'>智能</b><b class='flag-5'>終端</b><b class='flag-5'>中</b>的應(yīng)用

    手持PDA終端固定資產(chǎn)盤點中的應(yīng)用方案

    隨著科技的迅猛發(fā)展,手持式數(shù)據(jù)采集(PDA)終端已成為企業(yè)盤點固定資產(chǎn)不可或缺的工具。借助條碼掃描及無線射頻識別(RFID)技術(shù),手持PDA終端極大地促進了盤點效率和準確性的提升。以下
    的頭像 發(fā)表于 06-18 15:06 ?505次閱讀
    手持PDA<b class='flag-5'>終端</b><b class='flag-5'>在</b>固定資產(chǎn)<b class='flag-5'>盤點</b>中的應(yīng)用方案

    pda手持終端,小型公司使用用于倉庫出入庫、倉庫盤點

    小型公司,PDA手持終端可以很好地滿足倉庫出入庫和盤點的需求,尤其不需要聯(lián)網(wǎng)的情況下。PDA手持
    的頭像 發(fā)表于 05-15 10:59 ?488次閱讀
    pda手持<b class='flag-5'>終端</b>,小型公司使用用于倉庫出入庫、倉庫<b class='flag-5'>盤點</b>

    三防平板丨平板終端丨倉庫盤點應(yīng)用

    三防平板是一種能夠惡劣環(huán)境下使用的電子設(shè)備,其具有防水、防塵、抗震等特性,適用于各種場合,包括倉庫盤點。現(xiàn)代物流行業(yè),對于倉庫盤點來說
    的頭像 發(fā)表于 02-19 09:51 ?308次閱讀
    三防平板丨平板<b class='flag-5'>終端</b>丨倉庫<b class='flag-5'>盤點</b>應(yīng)用