Kommunikation Raspberry Pi mit ROS2: Unterschied zwischen den Versionen
Zeile 41: | Zeile 41: | ||
===== SSH auf dem Raspberry Pi nutzen ===== | ===== SSH auf dem Raspberry Pi nutzen ===== | ||
Damit der Raspberry Pi über SSH verbunden werden kann, wird die | Damit der Raspberry Pi über SSH verbunden werden kann, wird die IPv4-Adresse des Raspberry Pi's benötigt. | ||
Dafür wird der RPi mit einem HDMI-Kabel an einem Bildschirm angeschlossen. | Dafür wird der RPi mit einem HDMI-Kabel an einem Bildschirm angeschlossen. | ||
Nach einer kurzen Ladezeit des Raspberry Pi's erscheint ein login Bildschirm, wo nach dem Benutzernamen (ubuntu) und nach dem Passwort (Hshl2021) gefragt wird. | Nach einer kurzen Ladezeit des Raspberry Pi's erscheint ein login Bildschirm, wo nach dem Benutzernamen (ubuntu) und nach dem Passwort (Hshl2021) gefragt wird. | ||
Zeile 47: | Zeile 47: | ||
Nach der Anmeldung auf dem Raspberry Pi, kann die IP-Adresse abgelesen werden, wie in Abb. 3 gezeigt: | Nach der Anmeldung auf dem Raspberry Pi, kann die IP-Adresse abgelesen werden, wie in Abb. 3 gezeigt: | ||
IPv4 address for wlan0: 192.168.10.108 | |||
[[Datei:StartBild_Ubuntu_Server.png|left|mini|300px|Abb 3: Beispiel <nowiki>IP-Adresse</nowiki>]] | [[Datei:StartBild_Ubuntu_Server.png|left|mini|300px|Abb 3: Beispiel <nowiki>IP-Adresse</nowiki>]] |
Version vom 27. Januar 2022, 14:14 Uhr
Autoren: Jonas Gerken
Betreuer: Prof. Schneider
Art: Praxissemester
Projektlaufzeit: 02.11.2021-20.02.2022
Einleitung
Dieser Artikel beschreibt die Kommunikation von einem Raspberry Pi mit ROS2. Dazu wird erklärt, wie ein Raspberry Pi mit einem PC über SSH(Secure Shell) verbunden werden kann.
An dieser Stelle sollten Ubuntu Server 20.04 und ROS2 base auf dem Raspberry Pi installiert sein. Wenn dies noch nicht der Fall ist, siehe hier Installation von ROS2 für die Installation.
Übersicht
Dokumentation
Raspberry Pi mit Ubuntu Server verbinden über SSH(Secure Shell)
Hier wird zunächst erklärt was SSH ist wie es aktiviert wird und wie es verwendet werden kann.
Was ist SSH (Secure Shell)?
Secure Shell oder SSH bezeichnet ein kryptographisches Netzwerkprotokoll für den sicheren Betrieb von Netzwerkdiensten über ungesicherte Netzwerke. Häufig wird es verwendet, um lokal eine entfernte Kommandozeile verfügbar zu machen, d. h., auf einer lokalen Konsole werden die Ausgaben der entfernten Konsole ausgegeben (hier: PC) und die lokalen Tastatureingaben werden an den entfernten Rechner gesendet (hier: Raspberry Pi). Genutzt werden kann dies z. B. zur Fernwartung eines in einem entfernten Rechenzentrum stehenden Servers. Oder wie in diesem Projekt zur Programmierung des Raspberry Pi's
Um den Microcontroller anzusteuern wurde er über SSH verbunden, um gleichzeitig weiter an einem PC mit Ubuntu Desktop arbeiten zu können und den Roboter später frei fahren lassen zu können ohne ihn an ein HDMI-Kabel anzuschließen. Dazu gibt es zwei Möglichkeiten: einmal mit einem Programm namens PuTTY oder direkt über die Ubuntu Kommando-Konsole.
SSH auf dem Raspberry Pi Aktivieren
Damit SSH genutzt werden kann muss es auf dem Raspberry Pi zuerst aktiviert werden. Dazu wird die SD-Karte mit einem SD-Karten-Adapter in ein Kartenleseslot an einem PC gesteckt. Anschließend wird auf der SD-Karte im boot-Verzeichnis (in diesem Fall "system-boot") eine leere Textdatei mit dem Namen "ssh.txt" erstellt. Am besten wird einfach über das gewohnte Windows Menü eine leere Datei erstellt. (Abb. 1)
Um die Dateiendung .txt zu entfernen muss im Windows-Explorer unter dem Reiter Ansicht ein Haken bei Dateinamenserweiterungen Gesetz werden. So wird die Dateiendung bei der Umbenennung einer Datei angezeigt und es kann die .txt Endung von ssh.txt entfernt werden. Wurde die Datei umbenannt, wird eine Windows Warnung erscheinen. Diese kann einfach mit Ja bestätigt werden.
Beim Start des Raspberry Pi's ist nun der SSH-Server aktiviert und er kann beispielsweise mit Putty oder der Ubuntu Kommandozeile verbunden werden.
SSH auf dem Raspberry Pi nutzen
Damit der Raspberry Pi über SSH verbunden werden kann, wird die IPv4-Adresse des Raspberry Pi's benötigt. Dafür wird der RPi mit einem HDMI-Kabel an einem Bildschirm angeschlossen. Nach einer kurzen Ladezeit des Raspberry Pi's erscheint ein login Bildschirm, wo nach dem Benutzernamen (ubuntu) und nach dem Passwort (Hshl2021) gefragt wird.
Nach der Anmeldung auf dem Raspberry Pi, kann die IP-Adresse abgelesen werden, wie in Abb. 3 gezeigt:
IPv4 address for wlan0: 192.168.10.108
Für die Verbindung über Ethernet muss nur der RPi und der PC mit einem Lan-Kabel verbunden werden. Damit beides im gleichen Netzwerk ist wird ein Switch zwischengeschaltet. Jetzt kann die SSH-Verbindung mit dem Befehl "ssh username@IP-Adresse" hergestellt werden. Danach wird nach dem RPi Passwort gefragt. Nach der Eingabe des Passworts wird die SSH Verbindung hergestellt.
Für die Wifi-Verbindung muss die Netzwerkkonfiguration geöffnet werden: "sudo nano /etc/netplan/50-cloud-init.yaml"
Der Datei Inhalt ist in Abb. 4 abgebildet.
Hier werden dann die benötigte Wifi-Konfiguration wie in Abb. 4 zusehen ist hinzugefügt.
Der Netzwerk-Name und das Passwort müssen entsprechend Umbenannt werden.
Bei der Wifi-Verbindung über SSH wird es sich um eine andere IP-Adresse handel, wie bei der Ethernet-Verbindung.
PuTTY für die SSH Verbindung
PuTTY ist eine freie Software zur Herstellung von Secure Shell Verbindungen. Auf einem Pc mit Ubuntu wird Putty über die Kommando-Konsole installiert.
sudo apt-get install putty
Nach der Installaltion kann es über den Befehl putty ausgeführt werden und ein neues Fenster öffnet sich. Abb. 1
Microcontroller coding mit der Integration von Ros 2
Da es die Bibliothek wiringPi, welche für die Ansteuerung der GPIO Pins über CPP nicht mehr unterstützt wird, haben wir uns für die Python Bibliothek "RPi.GPIO" entschieden.
- Installieren der Bibliothek um die GPIO-Pins anzusteuern
- dieser Befehl muss zur Installation in einem Terminal unter Ubuntu eingegeben werden:
"pip install RPi.GPIO".
Um zunächst mit der Programmierung zu beginnen wurde ein Ros2 Workspace mit einem source Ordner erstellt.
mkdir ros_ws cd ros_ws mkdir src
In diesem Ordner wurde dann das ros2 Package mit den benötigten Bibliotheksabhängigkeiten erstellt.
ros2 pkg create --build-type ament_python packagename(z.B. sensor_test) --dependencies rclpy std_msgs
In dem Verzeichnis /ros_ws/src/packagename/packagename werden nun die Datei "slave_sonar.py" erstellt.
Demo
Software
Zusammenfassung
Weiterführende Links
→ zurück zum Hauptartikel: Robot Operating System2 (ROS2)