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

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創作中心

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

3天內不再提示

告別性能瓶頸:使用 Google Coral TPU 為樹莓派注入強大AI計算力!

上海晶珩電子科技有限公司 ? 2025-03-25 09:30 ? 次閱讀

bc27e802-0918-11f0-9434-92fbcf53809c.jpg

使用機器學習的應用程序通常需要高計算能力。這些計算通常發生在顯卡的GPU上。Raspberry Pi并不專門設計用于運行計算密集型應用程序。但Google Coral USB加速器能在此提供幫助!借助此設備,我們可以在視頻中實現實時計算,如對象識別。

在本教程中,我們將探討如何在Raspberry Pi上集成和使用Google Coral。然后,我們將利用Raspberry Pi攝像頭中的視頻流創建實時對象檢測。

所需硬件部件

我在本教程中使用了以下硬件部件。許多組件在之前的教程中已經使用過。

Raspberry Pi*

Edge TPU:Google Coral USB加速器

官方Raspberry Pi攝像頭模塊 或 USB網絡攝像頭

用于識別的簡單對象(辦公用品、水果等)

最佳選擇:一個為Raspberry Pi和USB加速器配備散熱器的外殼(也可3D打印)。

Google Coral USB加速器比Raspberry Pi4小,應通過USB 3.0端口連接。

bc3d4238-0918-11f0-9434-92fbcf53809c.png

Google Coral USB加速器用于什么?

Google Coral USB加速器包含一個專門為神經網絡計算而設計的處理器。這個處理器被稱為Edge-TPU(Tensor Processing Unit)。

以下視頻對神經網絡進行了很好的解釋,包括它們到底是什么,以及為什么你經常在閱讀機器學習相關內容時會看到它們:


因此,主要任務之一是解決這些神經網絡(以矩陣的形式),而Edge TPU特別擅長于此。Google提供了特殊的庫,以便我們可以利用Coral USB加速器的特性。

在Raspberry Pi上安裝Google Coral Edge TPU

為了使用Coral Edge TPU的處理能力,我們需要安裝一些軟件包。為此,我們主要遵循TPU網站的步驟。使用 USB 加速器入門:https://coral.ai/docs/accelerator/get-started/使用 SSH 和 Putty 遠程訪問樹莓派https://tutorials-raspberrypi.com/raspberry-pi-remote-access-by-using-ssh-and-putty/打開終端(或通過SSH連接),然后輸入以下命令:

echo "deb https://packages.cloud.google.com/apt coral-edgetpu-stable main" | sudo tee /etc/apt/sources.list.d/coral-edgetpu.listcurl https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -sudo apt-get update

之后,我們可以安裝Edge TPU運行時:

sudo apt-get install libedgetpu1-std

注意:如果你想安裝一個“更快”的運行時(意味著:頻率更高),請使用以下命令:sudo apt-get install libedgetpu1-max。但是,請記住,不能同時安裝這兩個版本。此外,高頻版本會使工作溫度升高,因此你應僅在具備足夠好的散熱條件時使用它。

安裝完成后,你可以將USB加速器連接到Raspberry Pi(最好連接到藍色的USB 3.0端口)。如果在安裝之前已經連接,請暫時斷開并重新連接。

現在,我們安裝Python軟件包。為此,以下命令已足夠:

sudo apt-get install python3-pycoral --yes

安裝TensorFlow Lite

我們還需要TensorFlow Lite。首先,我們檢查版本:

pip3 show tflite_runtime

我的結果如下:

Name: tflite-runtimeVersion: 2.5.0Summary: TensorFlow Lite is for mobile and embedded devices.Home-page: https://www.tensorflow.org/lite/Author: Google, LLCAuthor-email: packages@tensorflow.orgLicense: Apache 2.0Location: /usr/lib/python3/dist-packagesRequires:Required-by: pycoral

如果你尚未安裝TensorFlow,可以按以下方式操作,然后再次運行命令:

echo "deb https://packages.cloud.google.com/apt coral-edgetpu-stable main" | sudo tee /etc/apt/sources.list.d/coral-edgetpu.listcurl https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -sudo apt-get updatesudo apt-get install python3-tflite-runtime

使用Google Coral和Raspberry Pi攝像頭在視頻中進行對象識別

接下來,我們希望在視頻流中實時激活對象檢測。計算將在Edge TPU上運行。為了顯示圖像,我們有幾個選項。我們可以使用例如PyGame、PiCamera或OpenCV等軟件包。我更喜歡OpenCV,因為它允許我們使用計算機視覺領域的更多功能。

首先,我們通過CSI連接Raspberry Pi攝像頭,或通過USB連接網絡攝像頭。大多數網絡攝像頭會自動被檢測到

讓我們從一個示例項目開始。再次打開終端:

mkdir google-coral && cd google-coralgit clone https://github.com/google-coral/examples-camera --depth 1

下一步,我們加載預訓練模型。您也可以選擇使用自己訓練的模型。然而,在我們這個簡單的例子中,我們只加載了MobileNet SSD300模型:,它已經可以識別許多物體。

MobileNet SSD300模型:https://resources.wolframcloud.com/NeuralNetRepository/resources/SSD-MobileNet-V2-Trained-on-MS-COCO-Data

cd examples-camerash download_models.sh

這個過程需要幾分鐘。之后,我們切換到OpenCV文件夾并安裝依賴項(如果你想使用另一個示例,這里有這個選項)。

cd opencvbash install_requirements.sh

現在我們可以啟動示例應用程序了。為此,你需要一個桌面環境。如果你不是直接在Raspberry Pi上工作,我建議使用遠程桌面連接。

如何建立 Raspberry Pi 遠程桌面連接:https://tutorials-raspberrypi.com/raspberry-pi-remote-desktop-connection/

python3 detect.py

這會打開一個新的窗口,顯示視頻流。在視頻流中,檢測到的物體會用矩形標記出來。你還可以看到計算出的物體被檢測到的概率(以百分比表示)(即根據算法,這個物體被識別為特定物體的可能性有多大)。

bc5d8e4e-0918-11f0-9434-92fbcf53809c.jpg

現在讓我們仔細查看代碼,以了解發生了什么:

# Copyright 2019 Google LLC## Licensed under the Apache License, Version 2.0 (the "License");# you may not use this file except in compliance with the License.# You may obtain a copy of the License at## https://www.apache.org/licenses/LICENSE-2.0## Unless required by applicable law or agreed to in writing, software# distributed under the License is distributed on an "AS IS" BASIS,# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.# See the License for the specific language governing permissions and# limitations under the License. """A demo that runs object detection on camera frames using OpenCV. TEST_DATA=../all_models Run face detection model:python3 detect.py \ --model ${TEST_DATA}/mobilenet_ssd_v2_face_quant_postprocess_edgetpu.tflite Run coco model:python3 detect.py \ --model ${TEST_DATA}/mobilenet_ssd_v2_coco_quant_postprocess_edgetpu.tflite \ --labels ${TEST_DATA}/coco_labels.txt """import argparseimport cv2import os from pycoral.adapters.common import input_sizefrom pycoral.adapters.detect import get_objectsfrom pycoral.utils.dataset import read_label_filefrom pycoral.utils.edgetpu import make_interpreterfrom pycoral.utils.edgetpu import run_inference def main(): default_model_dir = '../all_models' default_model = 'mobilenet_ssd_v2_coco_quant_postprocess_edgetpu.tflite' default_labels = 'coco_labels.txt' parser = argparse.ArgumentParser() parser.add_argument('--model', help='.tflite model path', default=os.path.join(default_model_dir,default_model)) parser.add_argument('--labels', help='label file path', default=os.path.join(default_model_dir, default_labels)) parser.add_argument('--top_k', type=int, default=3, help='number of categories with highest score to display') parser.add_argument('--camera_idx', type=int, help='Index of which video source to use. ', default = 0) parser.add_argument('--threshold', type=float, default=0.1, help='classifier score threshold') args = parser.parse_args() print('Loading {} with {} labels.'.format(args.model, args.labels)) interpreter = make_interpreter(args.model) interpreter.allocate_tensors() labels = read_label_file(args.labels) inference_size = input_size(interpreter) cap = cv2.VideoCapture(args.camera_idx) while cap.isOpened(): ret, frame = cap.read() if not ret: break cv2_im = frame cv2_im_rgb = cv2.cvtColor(cv2_im, cv2.COLOR_BGR2RGB) cv2_im_rgb = cv2.resize(cv2_im_rgb, inference_size) run_inference(interpreter, cv2_im_rgb.tobytes()) objs = get_objects(interpreter, args.threshold)[:args.top_k] cv2_im = append_objs_to_img(cv2_im, inference_size, objs, labels) cv2.imshow('frame', cv2_im) if cv2.waitKey(1) & 0xFF == ord('q'): break cap.release() cv2.destroyAllWindows() def append_objs_to_img(cv2_im, inference_size, objs, labels): height, width, channels = cv2_im.shape scale_x, scale_y = width / inference_size[0], height / inference_size[1] for obj in objs: bbox = obj.bbox.scale(scale_x, scale_y) x0, y0 = int(bbox.xmin), int(bbox.ymin) x1, y1 = int(bbox.xmax), int(bbox.ymax) percent = int(100 * obj.score) label = '{}% {}'.format(percent, labels.get(obj.id, obj.id)) cv2_im = cv2.rectangle(cv2_im, (x0, y0), (x1, y1), (0, 255, 0), 2) cv2_im = cv2.putText(cv2_im, label, (x0, y0+30), cv2.FONT_HERSHEY_SIMPLEX, 1.0, (255, 0, 0), 2) return cv2_im if __name__ == '__main__': main()

  • 首先,包含了所需的PyCoral庫。
  • 在主函數中,定義了可以從命令行傳遞的參數(如指定模型等)。
  • 加載模型及其標簽,并根據模型確定尺寸(此處為300×300)。
  • 然后打開視頻流(cap = cv2.VideoCapture(args.camera_idx))。

接下來是核心部分:

objs = get_objects(interpreter, args.threshold)[:args.top_k]

  • 此過程中會確定“分類分數”最高的3個元素(且分數需高于閾值)。
  • 隨后,在圖像上標記每個檢測到的物體。

響應特定對象

如果我們想在檢測到某個特定對象(例如一個人)時立即觸發一個動作,現在應該怎么做呢?

為此,我們首先來看一下get_objects函數的返回值:

[Object(id=16, score=0.5, bbox=BBox(xmin=-2, ymin=102, xmax=158, ymax=296)), Object(id=0, score=0.16015625, bbox=BBox(xmin=6, ymin=114, xmax=270, ymax=300)), Object(id=61, score=0.12109375, bbox=BBox(xmin=245, ymin=166, xmax=301, ymax=302))]

我們看到,每個檢測到的對象都包含一個ID、一個分數以及一個帶有坐標的邊界框。為了確定檢測到了哪個對象,我們需要查看標簽:

{0: 'person', 1: 'bicycle', 2: 'car', 3: 'motorcycle', 4: 'airplane', 5: 'bus', 6: 'train', 7: 'truck', 8: 'boat', 9: 'traffic light', 10: 'fire hydrant', 12: 'stop sign', 13: 'parking meter', 14: 'bench', 15: 'bird', 16: 'cat', 17: 'dog', 18: 'horse', 19: 'sheep', 20: 'cow', 21: 'elephant', 22: 'bear', 23: 'zebra',24: 'giraffe', 26: 'backpack', 27: 'umbrella', 30: 'handbag', 31: 'tie', 32: 'suitcase', 33: 'frisbee', 34: 'skis', 35: 'snowboard', 36: 'sports ball', 37: 'kite', 38: 'baseball bat', 39: 'baseball glove', 40: 'skateboard', 41: 'surfboard', 42: 'tennis racket', 43: 'bottle', 45: 'wine glass', 46: 'cup', 47: 'fork', 48: 'knife', 49: 'spoon', 50: 'bowl', 51: 'banana', 52: 'apple', 53: 'sandwich', 54: 'orange', 55: 'broccoli', 56: 'carrot', 57: 'hot dog', 58: 'pizza', 59: 'donut', 60: 'cake', 61: 'chair', 62: 'couch', 63: 'potted plant',64: 'bed', 66: 'dining table', 69: 'toilet', 71: 'tv', 72: 'laptop', 73: 'mouse', 74: 'remote', 75: 'keyboard', 76: 'cell phone', 77: 'microwave', 78: 'oven', 79: 'toaster', 80: 'sink', 81: 'refrigerator', 83: 'book', 84: 'clock', 85: 'vase', 86: 'scissors', 87: 'teddy bear', 88: 'hair drier', 89: 'toothbrush'}

在我的案例中,識別到的對象有貓(ID=16)、人(ID=0)和椅子(ID=61)。

如果你想知道這些標簽是從哪里來的:它們是在模型中訓練的,因此被包含在內。如果你創建自己的模型,也可以只包含對你而言重要的一個或幾個對象。例如,識別你自己的臉也是可能的。在上面的例子中,我們想在檢測到某個特定對象(例如ID=5的公交車)時立即觸發一個動作。為此,我們首先查找該對象的ID。接下來,我們需要檢查是否找到了具有該ID的對象。我們還可以為分數添加一個閾值(例如0.8)。偽代碼看起來像這樣:

found_scores = [o.score for o in objs if o.id == 5]if len(found_scores) > 0 and max(found_scores) >= 0.8:# do something

正如你所見,對其做出反應非常簡單。之后,我們可以保存照片。

結論

對于那些覺得Raspberry Pi的計算能力不夠的人來說,Google的Edge TPU提供了一個很好的機會。與高端顯卡相比,USB加速器也非常便宜。高端顯卡的平均價格超過一千美元。

以300x300px的分辨率運行對象檢測非常流暢。也可以使用更高的分辨率,但你必須注意設備的溫度。我建議為連續運行增加一個額外的風扇。

此外,Google還提供了其他包含學習內容的存儲庫。對于Coral的其他用例,這個存儲庫仍然很有趣,并且除了其他內容外,還配備了圖像識別的示例。

https://github.com/google-coral/pycoral順便說一下,我們也可以使用TensorFlow創建自己的對象識別模型。為此,我們首先需要標注圖像,然后訓練一個模型。如果你感興趣,未來將提供相關的教程。

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

    關注

    87

    文章

    32937

    瀏覽量

    272580
  • TPU
    TPU
    +關注

    關注

    0

    文章

    146

    瀏覽量

    20924
  • 樹莓派
    +關注

    關注

    118

    文章

    1881

    瀏覽量

    106243
收藏 0人收藏

    評論

    相關推薦

    從CPU、GPU再到TPUGoogleAI芯片是如何一步步進化過來的?

    趨勢了,我認為這也是Google生產Tensor processing unit的一個重要出發點。至此,TPU便登上歷史舞臺。隨著機器學習算法越來越多的應用在各個領域并表現出優越的性能,例如街景、郵件
    發表于 03-15 11:40

    阿里云MaxCompute,用計算力讓數據發聲

    產品,用計算力讓數據發聲。計算的價值絕不止計算本身,而是讓本不會說話的數據發聲。從***到圓周率,從萬有引力定律到二進制,從固化的物體到虛擬的思維都由數據注入。阿里云大數據
    發表于 01-22 17:45

    好奇~!谷歌的 Edge TPU 專用 ASIC 旨在將機器學習推理能力引入邊緣設備

    或者嵌入式 CPU 的硬件方案相比,Edge TPU 的模型推理性能應該明顯更強。大約一個月之前,我們在 Geekbench 網站上發現了一段來自“Google Coral”這一神秘設
    發表于 03-05 21:20

    CORAL-EDGE-TPU:珊瑚開發板TPU

    ,可在低功耗轉換機器學習(ML)邊緣計算功能中實現高性能,本地推理。Coral Dev Board TPU的小巧外形可實現快速原型設計,涵蓋物聯網(IOT)和需要快速設備ML推理的通用
    發表于 05-29 10:43

    樹莓是什么

    樹莓樹莓是什么樹莓(英文名為Raspberry Pi,簡寫
    發表于 11-12 06:09

    BHR-AI-HX-M1產品概述

    基于ZYNQ7020的低成本低功耗嵌入式AI計算模組1 產品概述BHR-AI-HX-M1,內嵌EMBEDEEP EEP-TPU AI處理核,
    發表于 12-14 08:58

    谷歌人工智能之路:以強大創造AI注入發展活力

    長期以來,谷歌一直在其核心產品中大量使用AI技術,不斷研發新的AI產品。以強大創造AI
    發表于 11-12 10:38 ?973次閱讀

    2018中國AI計算力報告發布

    今天上午,浪潮公司聯合IDC在2018中國人工智能計算大會上發布了《2018中國AI計算力發展報告》(以下簡稱《報告》)。報告通過對AI計算力
    的頭像 發表于 09-15 08:37 ?4361次閱讀

    炸裂!小小樹莓要搭上 Google 的人工智能了

    樹莓以及 Google 獲取進一步信息,對方都表示暫時未能透露更多信息,但有望可在 2017 年見到新進展。Google 向來都致力于
    發表于 04-02 14:48 ?336次閱讀

    Python的PyCoral迎來多項更新,邊緣AI注入更多精彩

    針對 Edge TPU 優化 https://coral.ai/models Coral(https://coral.ai)是一個可用于構建本地
    的頭像 發表于 11-26 09:47 ?2495次閱讀

    樹莓

    樹莓樹莓是什么樹莓(英文名為Raspberry Pi,簡寫
    發表于 11-07 11:05 ?16次下載
    <b class='flag-5'>樹莓</b><b class='flag-5'>派</b>

    什么叫AI計算AI計算力是什么?

    什么叫AI計算AI計算力是什么? 隨著科技的不斷發展,人工智能(AI)已經成為當今最熱門的技術之一。而在人工智能中,
    的頭像 發表于 08-24 15:49 ?7638次閱讀

    樹莓攜手Hailo其新品注入人工智能功能

    套件用于支持樹莓5的AI功能。此次合作將以先進的人工智能功能助力專業以及創作愛好者在智能家居、安全、機器人等領域中提升解決方案效率。 Hailo的首席執行官兼聯合創始人Orr Danon表示:“我們非常榮幸能為
    的頭像 發表于 06-06 10:18 ?520次閱讀

    樹莓新推AI HAT+:26 TOPS高性能版本震撼登場

     在成功推出樹莓AI套件與AI攝像頭后,樹莓再次擴大其A
    的頭像 發表于 11-07 13:44 ?797次閱讀

    性能飆升!使用Python并行計算榨干樹莓

    Deepseek的引爆,讓AI大模型的本地化部署并應用于實際項目中變為可能。開發者們意識到——除了提升硬件性能,邊緣設備的算優化也是未來趨勢!當全球創客都在用樹莓
    的頭像 發表于 03-26 17:08 ?62次閱讀
    讓<b class='flag-5'>性能</b>飆升!使用Python并行<b class='flag-5'>計算</b>榨干<b class='flag-5'>樹莓</b><b class='flag-5'>派</b>算<b class='flag-5'>力</b>!
    主站蜘蛛池模板: 古代荡女丫鬟高H辣文纯肉 姑娘视频日本在线播放 | 人妖和美女玩 | 被吊起玩弄的女性奴 | 国产精品永久免费 | 日本免费一本天堂在线 | 无限资源在线观看播放 | 免费看黄的片多多APP下载 | 嘟嘟嘟WWW免费高清在线中文 | 色狠狠一区二区 | 无码人妻丰满熟妇啪啪网不卡 | 久久亚洲精品AV成人无 | 姉调无修版ova国语版 | 黄色天堂在线 | 亚洲AV无码国产精品色在线看 | a视频在线观看免费 | 日韩专区亚洲国产精品 | 人人超碰97caoporen国产 | 国产毛A片啊久久久久久A | 成人欧美尽粗二区三区AV | qovd电影 | 国产亚洲日韩另类在线观看 | 老色哥网站 | 快播性爱电影 | 日本国产精品无码一区免费看 | 韩国伦理三级 | 亚欧乱亚欧乱色视频 | 亚洲日韩中文字幕区 | 中俄两军在日本海等上空战略巡航 | 亚洲成人精品久久 | 俄罗斯14一18处交 | 伊人影院综合 | 野草视频在线观看 | mm625亚洲人成电影网 | 拔萝卜在线高清观看视频 | 国产麻豆精品传媒AV国产在线 | 伊人狼人久久精品热9 | 久久re视频这里精品09首页 | 伊人大香人妻在线播放 | 国产成人一区二区三中文 | 一级片mp4| 国产精品麻豆a在线播放 |

    電子發燒友

    中國電子工程師最喜歡的網站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術信息
    • 參加活動獲取豐厚的禮品