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

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

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

探討如何將機器學習應用到物聯(lián)網(wǎng)中

設計idea ? 來源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2018-05-23 09:24 ? 次閱讀

本項目探討如何將機器學習(Machine learning)應用到物聯(lián)網(wǎng)IoT,Internet of Things)中。我們將使用 Android Things 作為我們的物聯(lián)網(wǎng)平臺,并且采用 Google TensorFlow 作為我們的機器學習引擎。如今,機器學習與物聯(lián)網(wǎng)都是技術話題中的大熱門。

下面是維基百科上對機器學習的一個簡單定義

機器學習是計算機科學中的一個領域,它使計算機系統(tǒng)能夠利用數(shù)據(jù)進行 “學習”(即逐步提高特定任務的性能),而不需要進行顯式編程(Explicitly programmed)。

換句話說,在進行訓練步驟以后,系統(tǒng)就可以預測結(jié)果(即使這不是專門為這些結(jié)果進行編程的)。另一方面,我們都了解物聯(lián)網(wǎng)以及連接設備的概念。最有前途的話題之一便是如何將機器學習應用于物聯(lián)網(wǎng)之中,以構(gòu)建能夠 “學習” 的專家系統(tǒng)。此外,該系統(tǒng)會運用這些知識來控制和管理實物。

下面列舉一些應用到機器學習,以及物聯(lián)網(wǎng)能產(chǎn)生重要價值的領域:

  • 預測維護(Predictive maintenance)中的工業(yè)物聯(lián)網(wǎng)(IIoT,Industrial IoT)。

  • 在消費者物聯(lián)網(wǎng)(Consumer IoT)中,機器學習可以使設備變得更加智能化,從而適應我們的習慣。

在本教程中,我們將探索如何使用 Android Things 和 TensorFlow 將機器學習應用到物聯(lián)網(wǎng)中。這一 Android Things 物聯(lián)網(wǎng)項目背后的基本思想就是,探索如何構(gòu)建一個能夠識別一些基本形狀(比如箭頭)并被控制的機器人小車(Robot car)。我們已經(jīng)介紹過如何使用 Android Things 構(gòu)建機器人小車,我建議您在開始此項目之前先閱讀那篇教程。

本次機器學習和物聯(lián)網(wǎng)項目主要涵蓋以下主題:

  • 如何使用 Docker 配置 TensorFlow 環(huán)境

  • 如何訓練 TensorFlow 系統(tǒng)

  • 如何集成 TensorFlow 與 Android Things

  • 如何使用 TensorFlow 輸出結(jié)果來控制機器人小車

本項目衍生自 Android Things TensorFlow 圖像分類器。

我們開始吧!

如何在 Tensorflow 中創(chuàng)建一個圖像分類器

在開始之前,我們有必要先安裝并配置好 TensorFlow 環(huán)境。我并非機器學習專家,所以我需要找一些速成的東西并準備好使用,以便我們可以構(gòu)建 TensorFlow 圖像分類器。因此,我們可以使用 Docker 來運行一個搭載了 TensorFlow 的映像。照著以下步驟進行:

1. 克隆 TensorFlow 倉庫:

gitclonehttps://github.com/tensorflow/tensorflow.git
cd/tensorflow
gitcheckoutv1.5.0

2. 創(chuàng)建一個目錄(/tf-data),該目錄將保存我們在項目中需要用到的所有文件。

3. 運行 Docker:

dockerrun-it\--volume/tf-data:/tf-data\--volume/tensorflow:/tensorflow\
--workdir/tensorflowtensorflow/tensorflow:1.5.0bash

使用這些命令,我們就可以運行一個交互式 TensorFlow 環(huán)境并增加(Mount)一些我們將在項目中使用到的目錄。

如何訓練 TensorFlow

在 Android Things 系統(tǒng)能夠識別圖像之前,我們有必要先訓練 TensorFlow 引擎,以構(gòu)建其模型。以此為由,收集一些圖片是有必要的。如前所述,我們希望使用箭頭來控制 Android Things 機器人小車 —— 所以我們必須收集至少四種類型的箭頭:

  • 向上箭頭

  • 向下箭頭

  • 左箭頭

  • 右箭頭

為訓練該系統(tǒng),我們有必要對這四種不同的圖像類別創(chuàng)建一個“知識庫”。在 /tf-data 中一個名為 images 的目錄下創(chuàng)建四個目錄,命名如下:

  • up-arrow

  • down-arrow

  • left-arrow

  • right-arrow

現(xiàn)在是時候去搜集圖像資源了。我使用的是 Google 圖片搜索,您也可以使用其他方法進行搜集。為了簡化圖片下載過程,您應該安裝 Chrome 插件,它能夠一鍵下載所有圖片??蓜e忘了,您下載的圖像越多,其訓練過程(Training process)越好(即使創(chuàng)建模型的時間可能會有所增加)。

打開瀏覽器,開始查找以下四類圖像:

每個類別我分別下載了 80 張圖。我并不關心圖片的擴展。

一旦所有類別都有其圖像,請按照以下步驟操作(在 Docker 界面中):

python/tensorflow/examples/image_retraining/retrain.py\
--bottleneck_dir=tf_files/bottlenecks\
--how_many_training_steps=4000\
--output_graph=/tf-data/retrained_graph.pb\
--output_labels=/tf-data/retrained_labels.txt\
--image_dir=/tf-data/images

這操作可能需要花費一些時間,所以要耐心等待。最后,在你的文件夾 /tf-data 中應有兩個文件:

  1. retrained_graph.pb

  2. retrained_labels.txt

第一個文件包含我們的模型,這是 TensorFlow 訓練過程的結(jié)果。而第二個文件則包含了與我們的四個圖像類別相關的標簽。

如何測試 Tensorflow 模型

如果你想測試模型,以檢查一切是否正常,你可以使用以下命令:

pythonscripts.label_image\
--graph=/tf-data/retrained-graph.pb\
--image=/tf-data/images/[category]/[image_name.jpg]

優(yōu)化模型

在能夠使用這個 TensorFlow 模型到 Android Things 項目中之前,我們有必要優(yōu)化它:

python/tensorflow/python/tools/optimize_for_inference.py\--input=/tf-data/retrained_graph.pb\--output=/tf-data/opt_graph.pb\--input_names="Mul"\--output_names="final_result"

這就是我們的模型。我們將使用此模型將機器學習應用于物聯(lián)網(wǎng)(即集成 Android Things 與 TensorFlow)。其目標是為 Android Things 應用提供智能識別箭頭圖像,并作出相應反應,從而控制機器人小車的方向。

如果您想了解更多關于 TensorFlow 的細節(jié),以及如何生成模型,請查看官方文檔和這個教程

如何使用 Android Things 和 TensorFlow 將機器學習應用到物聯(lián)網(wǎng)中

一旦 TensorFlow 數(shù)據(jù)模型準備就緒,我們就可以進入下一步:如何集成 Android Things 與 TensorFlow。為達成這一目的,我們可以將此任務分為兩步:

  1. 硬件部分,我們將電機和其他外圍設備(Peripheral)連接到 Android Things 板上

  2. 實現(xiàn)應用程序

Android Things 原理圖

在深入探討如何連接外圍設備之前,我們先看看下面這個 Android Things 項目中使用的組件列表:

  1. Android Things 板(樹莓派 3,Raspberry Pi 3)

  2. 樹莓派相機

  3. 一個 LED

  4. LN298N 雙H橋(用以控制電機)

  5. 帶兩個輪子的機器人小車底盤

我不在此介紹如何使用 Android Things 控制電機,因為我們已經(jīng)在之前的文章中介紹過這一點。

以下是原理圖:

1620

上圖中,相機組件并未表現(xiàn)出來。其最終的結(jié)果如下:

基于 TensorFlow 實現(xiàn) Android Things App

最后一步便是實現(xiàn) Android Things 應用程序。為此,我們可以重用 GitHub 上名為 TensorFlow 圖像分類器示例的示例項目。在開始之前,先克隆 GitHub 倉庫,以便您可以修改源代碼。

該 Android Things 應用與原來的應用有所不同,在于:

  1. 它不使用按鈕來啟動相機捕捉圖像

  2. 它使用不同的模型

  3. 它使用一個閃爍的 LED 進行通知,攝像機在 LED 停止閃爍后拍攝照片

  4. 它在 TensorFlow 檢測到圖像(箭頭)時控制電機。此外,在從步驟 3 開始循環(huán)之前,先打開電機 5 秒

要處理閃爍的 LED,請使用以下代碼:

privateHandlerblinkingHandler=newHandler();privateRunnableblinkingLED=newRunnable(){
@Overridepublicvoidrun(){
try{
//Ifthemotorisrunningtheappdoesnotstartthecam
if(mc.getStatus())
return;
Log.d(TAG,"Blinking..");
mReadyLED.setValue(!mReadyLED.getValue());
if(currentValue<=?NUM_OF_TIMES)?{
???????currentValue++;
???????blinkingHandler.postDelayed(blinkingLED,?
???????????????????????BLINKING_INTERVAL_MS);
?????}
?????else?{
??????mReadyLED.setValue(false);
??????currentValue?=?0;
??????mBackgroundHandler.post(mBackgroundClickHandler);
?????}
???}?catch?(IOException?e)?{
?????e.printStackTrace();
???}
??}};

當 LED 停止閃爍時,應用程序?qū)⒉东@圖像。

現(xiàn)在有必要關注如何根據(jù)檢測到的圖像來控制電機。修改方法如下:

@OverridepublicvoidonImageAvailable(ImageReaderreader){
finalBitmapbitmap;
try(Imageimage=reader.acquireNextImage()){
bitmap=mImagePreprocessor.preprocessImage(image);
}
finalListresults=
mTensorFlowClassifier.doRecognize(bitmap);
Log.d(TAG,
"GotthefollowingresultsfromTensorflow:"+results);
//Checktheresult
if(results==null||results.size()==0){
Log.d(TAG,"Nocommand..");
blinkingHandler.post(blinkingLED);
return;
}
Classifier.Recognitionrec=results.get(0);
Floatconfidence=rec.getConfidence();
Log.d(TAG,"Confidence"+confidence.floatValue());
if(confidence.floatValue()

在這種方法中,當 TensorFlow 返回匹配捕獲圖像的可能標簽后,應用程序會將結(jié)果與可能的方向進行比較,從而控制電機。

最后,是時候使用在剛開始時創(chuàng)建的模型了??截?assets 文件夾下的 opt_graph.pb 與 reatrained_labels.txt 文件,并替換現(xiàn)有文件。

打開 Helper.java 并修改以下幾行:

publicstaticfinalintIMAGE_SIZE=299;privatestaticfinalintIMAGE_MEAN=128;privatestaticfinalfloatIMAGE_STD=128;privatestaticfinalStringLABELS_FILE="retrained_labels.txt";publicstaticfinalStringMODEL_FILE="file:///android_asset/opt_graph.pb";publicstaticfinalStringINPUT_NAME="Mul";publicstaticfinalStringOUTPUT_OPERATION="output";publicstaticfinalStringOUTPUT_NAME="final_result";

運行應用程序,試試向相機展示箭頭,并檢查結(jié)果。機器人小車必須按照所示的箭頭進行移動。

小結(jié)

在本教程的最后,我們介紹了如何運用 Android Things 與 TensorFlow 將機器學習應用到物聯(lián)網(wǎng)中。我們可以使用圖像控制機器人小車,并根據(jù)顯示的圖像移動機器人小車。

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

    關注

    66

    文章

    8306

    瀏覽量

    131841
  • IOT
    IOT
    +關注

    關注

    186

    文章

    4097

    瀏覽量

    195085
  • tensorflow
    +關注

    關注

    13

    文章

    327

    瀏覽量

    60413
  • Android Things
    +關注

    關注

    0

    文章

    10

    瀏覽量

    4176
收藏 人收藏

    評論

    相關推薦

    如何將TRIZ的“最終理想解”應用到機器人電機控制設計?

    的是產(chǎn)品或技術系統(tǒng)的理想化狀態(tài),即低成本、高功能、高可靠性、無污染等特性的完美結(jié)合。 在機器人電機控制設計,工程師們常常面臨諸多挑戰(zhàn),如如何在提高控制精度的同時降低能耗和噪音,如何在有限的資源下實現(xiàn)最優(yōu)的系統(tǒng)
    的頭像 發(fā)表于 08-13 10:19 ?227次閱讀

    如何將人工智能應用到效能評估工具中去解決

    智慧華盛恒輝人工智能應用到效能評估工具,可以通過以下幾個步驟來實現(xiàn),以提升評估的準確性、效率和實用性: 智慧華盛恒輝一、明確評估目標與指標 確定效能評估的目標:首先,需要明確效能評估的具體目標
    的頭像 發(fā)表于 07-24 10:34 ?195次閱讀

    機器學習的數(shù)據(jù)分割方法

    機器學習,數(shù)據(jù)分割是一項至關重要的任務,它直接影響到模型的訓練效果、泛化能力以及最終的性能評估。本文將從多個方面詳細探討機器
    的頭像 發(fā)表于 07-10 16:10 ?613次閱讀

    機器學習在數(shù)據(jù)分析的應用

    隨著大數(shù)據(jù)時代的到來,數(shù)據(jù)量的爆炸性增長對數(shù)據(jù)分析提出了更高的要求。機器學習作為一種強大的工具,通過訓練模型從數(shù)據(jù)中學習規(guī)律,為企業(yè)和組織提供了更高效、更準確的數(shù)據(jù)分析能力。本文深入
    的頭像 發(fā)表于 07-02 11:22 ?302次閱讀

    [天拓四方]4G MQTT網(wǎng)關在聯(lián)網(wǎng)應用的優(yōu)勢探討

    ,因其高效、可靠、簡單的特性,在聯(lián)網(wǎng)領域得到了廣泛的應用。而4G MQTT網(wǎng)關,作為連接物聯(lián)網(wǎng)設備和MQTT服務器的橋梁,其在聯(lián)網(wǎng)應用
    的頭像 發(fā)表于 05-28 17:22 ?331次閱讀

    如何將人工智能應用到戰(zhàn)略評估系統(tǒng)中去做

    智慧華盛恒輝人工智能應用到戰(zhàn)略評估系統(tǒng),可以極大地提升戰(zhàn)略評估的效率和準確性,以下是具體的應用方式: 是要實現(xiàn)戰(zhàn)場態(tài)勢的主動感知及精確判斷。無論是戰(zhàn)前預先規(guī)劃還是作戰(zhàn)行動的臨機規(guī)
    的頭像 發(fā)表于 04-24 14:01 ?196次閱讀

    如何將增量旋轉(zhuǎn)編碼器與Arduino連接

    在本教程,您將學習如何將增量旋轉(zhuǎn)編碼器與Arduino連接,以讀取旋鈕的運動。這對于在機器人和其他應用程序創(chuàng)建用戶界面或讀取機械位置非常
    的頭像 發(fā)表于 02-11 10:00 ?1000次閱讀
    <b class='flag-5'>如何將</b>增量旋轉(zhuǎn)編碼器與Arduino連接

    如何將工業(yè)設備快速接入到ZWS聯(lián)網(wǎng)云平臺

    工業(yè)設備作為工業(yè)互聯(lián)網(wǎng)的底層終端,承擔著數(shù)據(jù)感知和智能控制的重要作用。本文介紹如何將工業(yè)設備快速接入到ZWS聯(lián)網(wǎng)云平臺。應用場景工業(yè)現(xiàn)場
    的頭像 發(fā)表于 11-30 08:24 ?794次閱讀
    <b class='flag-5'>如何將</b>工業(yè)設備快速接入到ZWS<b class='flag-5'>物</b><b class='flag-5'>聯(lián)網(wǎng)</b>云平臺

    如何將visualAudio設計加進項目中?

    Hi, 因為剛接觸ADSP,一切都從0開始也沒有前輩指導,要學習的東西太多。遇到的問題也很多,可能大多問題都比較低級,沒辦法。請見諒! 這次想問下,我用VA設計了一個簡單的通路,用以VA
    發(fā)表于 11-30 08:01

    MCU在線技術講座-EFM和EFR: 面向聯(lián)網(wǎng)開發(fā)的通用MCU平臺

    開發(fā)人員了解專門針對聯(lián)網(wǎng)開發(fā)而優(yōu)化的EFM和EFR系列MCU平臺,我們針對亞洲地區(qū)于2023年12月12日上午10點(北京時間)在線舉辦全新MCU專題的Tech Talk技術講座-“EFM和EFR
    發(fā)表于 11-23 13:45

    聯(lián)網(wǎng)機器學習如何創(chuàng)造智能未來

    聯(lián)網(wǎng)設備能產(chǎn)生大量數(shù)據(jù),機器學習算法可以評估分析這些數(shù)據(jù),兩者搭配相得益彰。機器學習作為人工智
    的頭像 發(fā)表于 11-11 08:23 ?818次閱讀
    <b class='flag-5'>物</b><b class='flag-5'>聯(lián)網(wǎng)</b>與<b class='flag-5'>機器</b><b class='flag-5'>學習</b>如何創(chuàng)造智能未來

    如何將Kafka使用到我們的后端設計

    本文介紹了以下內(nèi)容: 1.什么是Kafka? 2.為什么我們需要使用Kafka這樣的消息系統(tǒng)及使用它的好處 3.如何將Kafka使用到我們的后端設計。 譯自timber.io
    的頭像 發(fā)表于 10-30 14:30 ?417次閱讀
    <b class='flag-5'>如何將</b>Kafka使<b class='flag-5'>用到</b>我們的后端設計<b class='flag-5'>中</b>

    如何將1-Wire主機復用到多個通道?

    如何將1-Wire主機復用到多個通道? 1-Wire是一種串行通信協(xié)議,可用于連接各種感測器和芯片,如溫度傳感器、濕度傳感器、EEPROM等。通常情況下,每個1-Wire主機(例如單片機)只能連接一
    的頭像 發(fā)表于 10-29 14:21 ?451次閱讀

    具有高性價比的無線 MCU 如何幫助您將低功耗 Bluetooth?? 技術應用到更多產(chǎn)品

    具有高性價比的無線 MCU 如何幫助您將低功耗 Bluetooth?? 技術應用到更多產(chǎn)品
    的頭像 發(fā)表于 10-24 17:41 ?441次閱讀

    如何將大模型應用到效能評估系統(tǒng)中去

    如何將大模型應用到效能評估系統(tǒng)中去 智慧華盛恒輝效能評估系統(tǒng)大數(shù)據(jù)的應用效能評估系統(tǒng)及其評估方法,以應用基礎數(shù)據(jù)和應用運行數(shù)據(jù)為基礎,從數(shù)據(jù)開放集約能力、用戶認可度、平安運行能力和運維保障支持四個
    的頭像 發(fā)表于 09-27 16:16 ?438次閱讀