- 前言
在現代科技的日益發展中,智慧邊緣裝置的應用範圍不斷擴大。其中ESP32這樣的微控制器在物聯網和嵌入式應用中扮演著重要角色。但是ESP32也面臨著內存和計算資源的限制。在這樣的情況下,實現即時目標檢測可能會面臨挑戰。然而即使在內存限制的環境中,利用ESP32運行Swift YOLO模型仍然是一個具有吸引力的選擇。讓我們一起探索這個引人注目的技術。
- ESP32-S3搭載YOLO:智慧邊緣裝置實現即時目標檢測的突破
首先我們使用的裝置為ESP32-S3-EYE,模型的部分可以在ModelAssistant Github 選擇。
首先我們需要clone SSCMA Source Code:
git clone https://github.com/Seeed-Studio/ModelAssistant.git --depth 1 && \
cd ModelAssistant
另外需要建立虛擬環境
conda create --name sscma python=3.8 -y && \
conda activate sscma
然後安裝 PyTorch,在這裡有兩種選擇,分別是 CPU-Only 平台和 GPUs (CUDA) 平台,請根據個人需求選擇。這裡使用 GPUs (CUDA) 平台:
pip3 install torch torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/cu117
在ModelAssistant路徑中安裝必須的依賴:
pip3 install -r requirements/base.txt && \
mim install -r requirements/mmlab.txt && \
mim install -e .
其他的部分如export.txt inference.txt則依照個人需求
接下來進行模型訓練的部分,ModelAssistant提供了數種模型選擇
這裡選擇 swift-yolo,準備好訓練資料並修改配置文件進行訓練。資料集格式為 COCO DATASET。
根據資料集位置圖像大小修改紅框部分,有需求的話也可以修改anchor。
接下來就可以進行訓練了,使用以下指令:
python tools/train.py configs/swift_yolo/street_coco.py --cfg-options \work_dir=work_dirs/street640 num_classes=1 epochs=300 height=640 width=640 data_root=/home/ubuntu/Documents/street/street_coco/ load_from=/home/ubuntu/Documents/ModelAssistant/work_dirs/person_detection.pth
訓練完成後,接下來匯出模型:
python tools/export.py configs/swift_yolo/street_coco.py /home/ubuntu/Documents/ModelAssistant/work_dirs/street4/best_coco_bbox_mAP_epoch_260.pth --target tflite --cfg-options \
work_dir=work_dirs/street3 \
num_classes=1 \
epochs=300 \
height=192 \
width=192 \
data_root=/home/ubuntu/Documents/street/street_coco/
模型訓練完後就能進行部屬了,clone sscma-example-esp32:
git clone https://github.com/Seeed-Studio/sscma-example-esp32
更新模組
git submodule update –init
在使用模型之前需要將 tflite 轉換成二進制,在 sscma-example-esp32 中執行:
python tools/tflite2c.py --input ./model_zoo/street3_epoch_295_int8.tflite --name street3 --output_dir ./examples/yolo_detection_demo/main --classes='("person")'
轉換完成後,對 example 中的模型進行修改。這裡使用的是 swift-yolo 模型,將下面的部分替換為您自己的模型。
接下來就能進行編譯了:
idf.py set-target esp32s3
idf.py build
idf.py --port /dev/ttyACM0 flash
idf.py --port /dev/ttyACM0 monitor
結果如下
- 結語
總的來說,我們的努力展示了如何在ESP32-S3上運行YOLO模型,實現了智慧邊緣裝置的即時目標檢測。這一突破克服了內存和計算資源的限制,拓展了智慧邊緣裝置的應用範圍。這一技術的應用將為物聯網和嵌入式應用帶來更多可能性,為智慧邊緣裝置的未來發展提供了新的方向。
- Q&A
- Q: 為什麼選擇ESP32-S3來部署模型?
A: 低成本:ESP32-S3是一種成本相對較低的微控制器,相比於一些更昂貴的硬件平台,如NVIDIA Jetson等,ESP32-S3的價格更為親民。
低功耗:ESP32-S3具有低功耗的特點,能夠在不影響性能的情況下實現長時間運行,這使得它非常適合應用於物聯網設備等需要長時間運行的場景。
- Q: 如何處理ESP32-S3的計算資源限制?
A: ESP32-S3的計算資源有限,需要對模型進行優化和壓縮,以適應其硬件限制。可以採用量化、剪枝、模型簡化等技術,減少模型大小和計算量。
- Q: ESP32-S3在部署模型時有什麼缺陷?
A: 在在硬體限制方面,ESP32-S3-EYE只有8MB的記憶體,模型在處理圖像時不能夠太大,這裡建議192x192的圖片大小。
- Q: ESP32-S3相對於ESP32有哪些改進?
A: 核心數量:ESP32 和 ESP32-S3 都有雙核處理器,但 ESP32-S3 使用的是 Xtensa LX7 核心,而 ESP32 使用的是 Xtensa LX6 核心。
運行速度:ESP32-S3 的主頻最高可達 240 MHz,與 ESP32 相同,但 ESP32-S3 的處理器性能更優化。
- Q: ESP32-S3上部署模型後,可以應用在哪些實際場景中?
A: 根據不同的模型可以做到
智慧家居: ESP32-S3可以用於監控家中的安全和環境,例如人員活動檢測、 煙霧和氣體警報等。
物聯網設備: 將ESP32-S3部署在物聯網設備中,可以實現遠程監控、數據收集和分析等功能。
農業和環境監測: ESP32-S3可以用於監測農作物的生長狀況、土壤濕度、氣象數據等,從而實現智慧農業和環境監測。
智慧城市: 在城市中部署ESP32-S3可以實現交通監控、停車管理、垃圾收集等功能,從而提高城市運行的效率。
健康監測: ESP32-S3可以用於實時監測人體生理數據,例如心率、血氧、體溫等,從而實現健康監測和警報功能。
- 引用
評論