Zum Inhalt springen

Coral Edge TPU auf einem Raspberry Pi mit Ultralytics YOLO11 🚀

Raspberry Pi Einplatinencomputer mit USB Edge TPU Beschleuniger

Was ist eine Coral Edge TPU?

Der Coral Edge TPU ist ein kompaktes Gerät, das Ihr System um einen Edge TPU Coprozessor erweitert. Er ermöglicht stromsparende und leistungsstarke ML-Inferenz für TensorFlow Lite-Modelle. Lesen Sie mehr auf der Coral Edge TPU Homepage.



Beobachten: Wie man Inferenz auf dem Raspberry Pi mit Google Coral Edge ausführt TPU

Steigerung der Leistung des Raspberry Pi-Modells mit Coral Edge TPU

Viele Menschen möchten ihre Modelle auf einem eingebetteten oder mobilen Gerät wie einem Raspberry Pi ausführen, da diese Geräte sehr stromsparend sind und in vielen verschiedenen Anwendungen eingesetzt werden können. Die Inferenzleistung auf diesen Geräten ist jedoch in der Regel schlecht, selbst wenn Formate wie ONNX oder OpenVINO. Der Coral Edge TPU ist eine großartige Lösung für dieses Problem, da er mit einem Raspberry Pi verwendet werden kann und die Inferenzleistung erheblich beschleunigt.

Edge TPU auf Raspberry Pi mit TensorFlow Lite (Neu)⭐

Die bestehende Anleitung von Coral zur Verwendung des Edge TPU mit einem Raspberry Pi ist veraltet, und die aktuellen Coral Edge TPU Runtime-Builds funktionieren nicht mehr mit den aktuellen TensorFlow Lite-Runtime-Versionen. Darüber hinaus scheint Google das Coral-Projekt komplett aufgegeben zu haben, und es gab zwischen 2021 und 2024 keine Updates mehr. Diese Anleitung zeigt Ihnen, wie Sie den Edge TPU mit den neuesten Versionen der TensorFlow Lite-Laufzeitumgebung und einer aktualisierten Coral Edge TPU -Laufzeitumgebung auf einem Raspberry Pi Single Board Computer (SBC) zum Laufen bringen.

Voraussetzungen

Installations-Durchgang

In dieser Anleitung wird davon ausgegangen, dass Sie bereits ein funktionierendes Raspberry Pi-Betriebssystem haben und Folgendes installiert haben ultralytics und alle Abhängigkeiten. Zum Erhalten ultralytics installiert, besuchen Sie die Schnellstart-Anleitung einrichten, bevor Sie hier fortfahren.

Installieren der Edge TPU Laufzeitumgebung

First, we need to install the Edge TPU runtime. There are many different versions available, so you need to choose the right version for your operating system. The high frequency version runs the Edge TPU at a higher clock speed, which improves performance. However, it might result in the Edge TPU thermal throttling, so it is recommended to have some sort of cooling mechanism in place.

Raspberry Pi OS Hochfrequenz-Modus Version zum Herunterladen
Volltreffer 32bit Nein libedgetpu1-std_ ... .bullseye_armhf.deb
Volltreffer 64bit Nein libedgetpu1-std_ ... .bullseye_arm64.deb
Volltreffer 32bit Ja libedgetpu1-max_ ... .bullseye_armhf.deb
Volltreffer 64bit Ja libedgetpu1-max_ ... .bullseye_arm64.deb
Bücherwurm 32bit Nein libedgetpu1-std_ ... .bookworm_armhf.deb
Bücherwurm 64bit Nein libedgetpu1-std_ ... .bookworm_arm64.deb
Bücherwurm 32bit Ja libedgetpu1-max_ ... .bookworm_armhf.deb
Bücherwurm 64bit Ja libedgetpu1-max_ ... .bookworm_arm64.deb

Laden Sie die neueste Version von hier herunter.

Nachdem Sie die Datei heruntergeladen haben, können Sie sie mit dem folgenden Befehl installieren:

sudo dpkg -i path/to/package.deb

Nach der Installation der Laufzeitumgebung müssen Sie Ihren Coral Edge TPU an einen USB 3.0-Port Ihres Raspberry Pi anschließen. Dies liegt daran, dass laut der offiziellen Anleitung eine neue udev Regel nach der Installation in Kraft treten muss.

Wichtig

Wenn Sie die Coral Edge TPU Runtime bereits installiert haben, deinstallieren Sie sie mit dem folgenden Befehl.

# If you installed the standard version
sudo apt remove libedgetpu1-std

# If you installed the high frequency version
sudo apt remove libedgetpu1-max

Export to Edge TPU

Um den Edge TPU zu verwenden, müssen Sie Ihr Modell in ein kompatibles Format konvertieren. Es wird empfohlen, den Export auf Google Colab, einem x86_64-Linux-Rechner, mit dem offiziellen Ultralytics Docker-Container oder mit Ultralytics HUB auszuführen, da der Edge TPU Compiler auf ARM nicht verfügbar ist. Siehe Exportmodus für die verfügbaren Argumente.

Exportieren des Modells

from ultralytics import YOLO

# Load a model
model = YOLO("path/to/model.pt")  # Load an official model or custom model

# Export the model
model.export(format="edgetpu")
yolo export model=path/to/model.pt format=edgetpu  # Export an official model or custom model

Das exportierte Modell wird in der Datei <model_name>_saved_model/ Ordner mit dem Namen <model_name>_full_integer_quant_edgetpu.tflite. Es ist wichtig, dass Ihr Modell mit dem Suffix _edgetpu.tflite, otherwise ultralytics doesn't know that you're using an Edge TPU model.

Ausführung des Modells

Bevor Sie das Modell tatsächlich ausführen können, müssen Sie die richtigen Bibliotheken installieren.

Wenn tensorflow installiert ist, deinstallieren Sie tensorflow mit dem folgenden Befehl:

pip uninstall tensorflow tensorflow-aarch64

Dann installieren/aktualisieren Sie tflite-runtime:

pip install -U tflite-runtime

Jetzt können Sie die Inferenz mit folgendem Code ausführen:

Ausführung des Modells

from ultralytics import YOLO

# Load a model
model = YOLO("path/to/<model_name>_full_integer_quant_edgetpu.tflite")  # Load an official model or custom model

# Run Prediction
model.predict("path/to/source.png")
yolo predict model=path/to/<model_name>_full_integer_quant_edgetpu.tflite source=path/to/source.png  # Load an official model or custom model

Umfassende Informationen finden Sie auf der Seite Vorhersage für alle Details zum Vorhersagemodus.

Inferenz mit mehreren Edge TPUs

Wenn Sie mehrere Edge TPUs haben, können Sie den folgenden Code verwenden, um eine bestimmte TPU auszuwählen.

from ultralytics import YOLO

# Load a model
model = YOLO("path/to/<model_name>_full_integer_quant_edgetpu.tflite")  # Load an official model or custom model

# Run Prediction
model.predict("path/to/source.png")  # Inference defaults to the first TPU

model.predict("path/to/source.png", device="tpu:0")  # Select the first TPU

model.predict("path/to/source.png", device="tpu:1")  # Select the second TPU

Benchmarks

Benchmarks

Tested with Raspberry Pi Os Bookworm 64-Bit and a USB Coral Edge TPU.

Hinweis

Shown is the inference time, pre-/postprocessing is not included.

Bildgröße Modell Standard Inference Time (ms) High Frequency Inference Time (ms)
320 YOLOv8n 32.2 26.7
320 YOLOv8s 47.1 39.8
512 YOLOv8n 73.5 60.7
512 YOLOv8s 149.6 125.3
Bildgröße Modell Standard Inference Time (ms) High Frequency Inference Time (ms)
320 YOLOv8n 22.2 16.7
320 YOLOv8s 40.1 32.2
512 YOLOv8n 53.5 41.6
512 YOLOv8s 132.0 103.3

On average:

  • The Raspberry Pi 5 is 22% faster with the standard mode than the Raspberry Pi 4B.
  • The Raspberry Pi 5 is 30.2% faster with the high frequency mode than the Raspberry Pi 4B.
  • The high frequency mode is 28.4% faster than the standard mode.

FAQ

Was ist ein Coral Edge TPU und wie verbessert es die Leistung des Raspberry Pi mit Ultralytics YOLO11 ?

Der Coral Edge TPU ist ein kompaktes Gerät, mit dem Sie Ihr System um einen Edge TPU Coprozessor erweitern können. Dieser Coprozessor ermöglicht eine stromsparende und leistungsstarke Inferenz für maschinelles Lernen, die insbesondere für TensorFlow Lite-Modelle optimiert ist. Bei Verwendung eines Raspberry Pi beschleunigt der Edge TPU die Inferenz von ML-Modellen und steigert die Leistung erheblich, insbesondere für Ultralytics YOLO11 Modelle. Weitere Informationen über den Coral Edge TPU finden Sie auf der Homepage des Unternehmens.

Wie installiere ich die Coral Edge TPU Laufzeitumgebung auf einem Raspberry Pi?

Um die Coral Edge TPU Laufzeitumgebung auf Ihrem Raspberry Pi zu installieren, laden Sie die entsprechende .deb Paket für Ihre Raspberry Pi OS Version von dieser Link. Verwenden Sie nach dem Herunterladen den folgenden Befehl, um es zu installieren:

sudo dpkg -i path/to/package.deb

Stellen Sie sicher, dass Sie alle früheren Coral Edge TPU Runtime-Versionen deinstallieren, indem Sie die Schritte im Abschnitt "Installationsanleitung" ausführen.

Kann ich mein Ultralytics YOLO11 Modell exportieren, damit es mit Coral Edge TPU kompatibel ist?

Ja, Sie können Ihr Ultralytics YOLO11 Modell exportieren, damit es mit Coral Edge TPU kompatibel ist. Es wird empfohlen, den Export auf Google Colab, einem x86_64 Linux-Rechner oder mit dem Ultralytics Docker-Container durchzuführen. Sie können auch Ultralytics HUB zum Exportieren verwenden. Hier sehen Sie, wie Sie Ihr Modell mit Python und CLI exportieren können:

Exportieren des Modells

from ultralytics import YOLO

# Load a model
model = YOLO("path/to/model.pt")  # Load an official model or custom model

# Export the model
model.export(format="edgetpu")
yolo export model=path/to/model.pt format=edgetpu  # Export an official model or custom model

Weitere Informationen finden Sie in der Dokumentation zum Exportmodus.

What should I do if TensorFlow is already installed on my Raspberry Pi, but I want to use tflite-runtime instead?

Wenn Sie TensorFlow auf Ihrem Raspberry Pi installiert haben und zu tflite-runtimemüssen Sie zunächst TensorFlow deinstallieren:

pip uninstall tensorflow tensorflow-aarch64

Installieren oder aktualisieren Sie dann tflite-runtime mit dem folgenden Befehl:

pip install -U tflite-runtime

Für ein bestimmtes Rad, z. B. TensorFlow 2.15.0 tflite-runtimekönnen Sie es herunterladen unter dieser Link und installieren Sie es mit pip. Detaillierte Anweisungen finden Sie im Abschnitt über die Ausführung des Modells Ausführen des Modells.

Wie führe ich Inferenz mit einem exportierten YOLO11 Modell auf einem Raspberry Pi unter Verwendung des Coral Edge TPU durch?

Nachdem Sie Ihr YOLO11 Modell in ein mit Edge TPU kompatibles Format exportiert haben, können Sie die Inferenz mit Hilfe der folgenden Codeschnipsel durchführen:

Ausführung des Modells

from ultralytics import YOLO

# Load a model
model = YOLO("path/to/edgetpu_model.tflite")  # Load an official model or custom model

# Run Prediction
model.predict("path/to/source.png")
yolo predict model=path/to/edgetpu_model.tflite source=path/to/source.png  # Load an official model or custom model

Umfassende Details zu allen Funktionen des Vorhersagemodus finden Sie auf der Seite Vorhersage.

📅 Erstellt vor 11 Monaten ✏️ Aktualisiert vor 3 Tagen

Kommentare