色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

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

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

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

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

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

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

看花識(shí)名APP

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

Daisy:雛菊

Dandelion:蒲公英

Roses:玫瑰

Sunflowers:向日葵

Tulips:郁金香

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

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

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

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

本文采用TensorFlow官方Slim(https://github.com/tensorflow/models/tree/master/slim)AlexNet模型進(jìn)行訓(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)過(guò)36618次迭代后,模型精度達(dá)到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

對(duì)Freeze Graph的PB文件進(jìn)行數(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中常用的方法是對(duì)模型文件進(jìn)行量化處理,本文對(duì)AlexNet CheckPoint文件進(jìn)行Freeze和Quantized處理后的文件大小變化如下圖所示:

量化操作的主要思想是在模型的Inference階段采用等價(jià)的8位整數(shù)操作代替32位的浮點(diǎn)數(shù)操作,替換的操作包括:卷積操作、矩陣相乘、激活函數(shù)、池化操作等。量化節(jié)點(diǎn)的輸入、輸出為浮點(diǎn)數(shù),但是內(nèi)部運(yùn)算會(huì)通過(guò)量化計(jì)算轉(zhuǎn)換為8位整數(shù)(范圍為0到255)的運(yùn)算,浮點(diǎn)數(shù)和8位量化整數(shù)的對(duì)應(yīng)關(guān)系示例如下圖所示:

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

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

在Android系統(tǒng)上使用TensorFlow模型做Inference依賴于兩個(gè)文件libtensorflow_inference.so和libandroid_tensorflow_inference_java.jar。這兩個(gè)文件可以通過(guò)下載TensorFlow源代碼后,采用bazel編譯出來(lái),如下所示:

下載TensorFlow源代碼

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

下載安裝Android NDK

下載安裝Android SDK

配置tensorflow/WORKSPACE中android開(kāi)發(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開(kāi)發(fā)的示例框架,下面基于AlexNet模型的看花識(shí)名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和對(duì)應(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到手機(jī)上,并執(zhí)行安裝,太陽(yáng)花識(shí)別效果如下圖所示:

(點(diǎn)擊放大圖像)

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

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

構(gòu)建TensorFlow Inference對(duì)象,構(gòu)建該對(duì)象時(shí)候會(huì)加載TensorFlow動(dòng)態(tài)鏈接庫(kù)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為輸入圖片的像素?cái)?shù)據(jù),進(jìn)行預(yù)處理后的浮點(diǎn)值;[1,inputSize,inputSize,3]為裁剪后圖片的大小,比如1張224*224*3的RGB圖片。

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

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

inferenceInterface.run(outputNames);

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

inferenceInterface.fetch(outputName, outputs);

總結(jié)

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

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

    關(guān)注

    6

    文章

    887

    瀏覽量

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

    關(guān)注

    73

    文章

    5512

    瀏覽量

    121494
  • tensorflow
    +關(guān)注

    關(guān)注

    13

    文章

    329

    瀏覽量

    60615

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

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    工業(yè)級(jí)智能手持終端:倉(cāng)庫(kù)盤點(diǎn)與出入庫(kù)管理的得力助手

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

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

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

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

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

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

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

    TensorFlow是什么?TensorFlow怎么用?

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

    tensorflow和pytorch哪個(gè)更簡(jiǎn)單?

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

    tensorflow和pytorch哪個(gè)好

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

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

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

    keras模型轉(zhuǎn)tensorflow session

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

    TensorFlow的定義和使用方法

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

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

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

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

     工控電腦一體機(jī)商業(yè)智能終端的應(yīng)用,主要體現(xiàn)在其高穩(wěn)定性、強(qiáng)大的數(shù)據(jù)處理能力以及適應(yīng)復(fù)雜商業(yè)環(huán)境的能力上。以下是工控電腦一體機(jī)商業(yè)
    的頭像 發(fā)表于 06-20 09:46 ?537次閱讀
    工控電腦一體機(jī)<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)盤點(diǎn)中的應(yīng)用方案

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

    pda手持終端,小型公司使用用于倉(cāng)庫(kù)出入庫(kù)、倉(cāng)庫(kù)盤點(diǎn)

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

    三防平板丨平板終端丨倉(cāng)庫(kù)盤點(diǎn)應(yīng)用

    三防平板是一種能夠惡劣環(huán)境下使用的電子設(shè)備,其具有防水、防塵、抗震等特性,適用于各種場(chǎng)合,包括倉(cāng)庫(kù)盤點(diǎn)現(xiàn)代物流行業(yè),對(duì)于倉(cāng)庫(kù)盤點(diǎn)來(lái)說(shuō)
    的頭像 發(fā)表于 02-19 09:51 ?315次閱讀
    三防平板丨平板<b class='flag-5'>終端</b>丨倉(cāng)庫(kù)<b class='flag-5'>盤點(diǎn)</b>應(yīng)用
    主站蜘蛛池模板: 含羞草国产亚洲精品岁国产精品 | 免费人成视频X8X8国产更快乐 | 兽交白浆喷水高潮 | 小SAO货水真多把你CAO烂 | 快播看黄片 | 韩国电影real在线观看完整版 | 国产成人精品男人免费 | 亚洲欧美日韩另类精品一区二区三区 | 与子敌伦刺激对白亂輪亂性 | 国产白色视频在线观看w | 开心片色99xxxx | 麻豆国产99在线中文 | 亚洲黄色网页 | 女人一级毛片免费观看 | 久久久无码精品亚洲欧美 | 精品性影院一区二区三区内射 | 在公交车上被JB草坏了被轮J了 | 偷拍自怕亚洲在线第7页 | 快播看av | 日韩精品亚洲专区在线电影不卡 | 成人国内精品久久久久影院 | 中文字幕永久在线观看 | 姑娘视频日本在线播放 | 亚洲不卡高清免v无码屋 | 中文国产在线观看 | 四虎永久免费 | 我要搞av| 成人性生交大片免费看4 | 欧美日韩精品不卡在线观看 | jizz丝袜| 女性酥酥影院 | 九九免费精品视频 | 在线视频一区二区三区在线播放 | 国产久青青青青在线观看 | 999av视频| 久久久精品国产免费A片胖妇女 | 九九久久久2| 亚洲 欧美 国产 综合 在线 | 亚洲春色AV无码专区456 | 日韩精品 电影一区 亚洲高清 | 久久精品亚洲AV高清网站性色 |