|
|
(39 dazwischenliegende Versionen von 6 Benutzern werden nicht angezeigt) |
Zeile 1: |
Zeile 1: |
| [[Kategorie:Robotik]]
| |
| [[Kategorie:Autonome Systeme]] | | [[Kategorie:Autonome Systeme]] |
| [[Datei:AlphaBot.png|thumb|rigth|550px|Abb. 1: AlphaBot von Waveshare]] | | [[Datei:AlphaBot.png|thumb|rigth|550px|Abb. 1: AlphaBot von Waveshare]] |
| '''Betreuer:''' | | '''Betreuer:''' |
|
| |
|
| [[Benutzer:Prof._Mirek_Göbel| Prof. Dr.-Ing. M. Göbel]]; [[Benutzer:Ulrich_Schneider| Prof. Dr.-Ing. U. Schneider]]; [[Benutzer:Gerrit_Wurth| B.Eng. G. Wurth]] | | [[Benutzer:Prof._Mirek_Göbel| Prof. Dr.-Ing. M. Göbel]]; [[Benutzer:Ulrich_Schneider| Prof. Dr.-Ing. U. Schneider]] |
|
| |
|
| '''Teilnehmer:''' | | '''Teilnehmer:''' |
Zeile 11: |
Zeile 10: |
|
| |
|
| == Einleitung == | | == Einleitung == |
| Bitte Leiten Sie hier in das Thema ein.
| | Autor: Armel Talovic |
|
| |
|
| == Übersicht ==
| | Im Wintersemester 21/22 beschäftigte sich das Team mit dem autonomen Fahren des Alphabots. Das Team bestand aus Fawad Murad, Jonas Gerken, Arfat Kamal, Armel Talovic und Sefa Hasan Demiröz. In diesem Praxissemester soll das Fundament gelegt werden für nachkommende Studierende, um ein besseren Einstieg in die grundlegende Thematik zu ermöglichen. Aus diesem Grund wurde diese Wikipedia Seite erstellt. Das Praxissemester fand an der Hochschule Hamm-Lippstadt am Standort Lippstadt statt. Materialien wie den Alphabot, Pc, Raspberry Pi oder einen Lidar Sensor wurden von der Hochschule zur Verfügung gestellt. |
| === Dokumentation ===
| |
| * [[Robot Operating System 2|Robot Operating System 2 (ROS2)]]
| |
| * [[Webots|Webots]]
| |
| * [[3D_Modellierung_eines_AlphaBot|3D-Modellierung eines AlphaBot]]
| |
| | |
| === Demo ===
| |
| | |
| === Software ===
| |
| | |
| == Weiterführende Links ==
| |
| | |
| | |
| | |
| | |
| <br clear = all>
| |
| | |
| | |
| | |
| == Installation von dem Roboter Operating System 2 ==
| |
| | |
| <br clear = all>
| |
| | |
| == Roboter Operating System 2 Tutorials ==
| |
| | |
| | |
| <br clear = all>
| |
|
| |
|
| == 3-D Model in Solidworks ==
| | Die konkrete Aufgabenstellung für das Team war es den Alphabot so zu modifizieren, dass er selbständig Hindernisse erkennen kann und diese umfährt, um von A nach B zu kommen. Dabei war es wichtig, dass man den Alphabot mittels dem Roboter Operating System 2 ansteuert. |
|
| |
|
| '''Autor:''' Sefa Hasan Demiröz
| |
|
| |
|
| === Ziel des Modells ===
| | Um dieses Ziel zu erreichen haben wir versucht die große Aufgabe in mehrere kleinere Aufgaben zu unterteilen. Die Hauptsächlichen Aufgaben lagen in der Einarbeitung mit dem Roboter Operating Systems 2 und dem Simulationsprogramm Webots mittels Tutorials, Modellierung des Alphabots in Solidworks, Simulation des Modells in Webots und Programmieren der Codes. |
|
| |
|
| Ziel des Modells ist eine repräsentative Veranschaulichung der Realität . Das Modell soll im vollen Maße funktionsfähig ( beweglich ) sein, um später auf einem Simulationsprogramm wie in unserem Falle Webots laufen zu können. Das zu modellierende Objekt ist der Alphabot.
| |
|
| |
|
| | [[Datei:3D-Modell_in_Webots.png|left|mini|500px|Abb.2 3-D Modell in Webots <nowiki></nowiki>]] |
|
| |
|
| [[Datei:Alphabot_Modell.png|left|mini|500px|Abb.1 Alphabot Solid Works <nowiki></nowiki>]]
| | <br clear=all> |
| <br clear=all>
| |
|
| |
|
| === Notwendige Eigenschaften des Modells === | | == [[AlphaBot_Projektteam_WS2021|Team]] == |
|
| |
|
| Für das Modell ist es essenziel mit den genauen geometrischen Maßen zu zeichnen, da ansonsten hinterher in der Realität es zu Fehlern kommen kann, die in der Simulation nicht angezeigt werden. Ebenso wichtig für das Modell ist es beweglich zu sein . Die beiden Räder müssen eine klare Drehbewegung ausführen können und der Sensor muss um 180° drehbar sein. Außerdem ist zu beachten dass man ein Modellierungsprogramm in Betracht zieht welches kompatibel mit dem Simulationsprogramm ist.
| |
|
| |
|
| === Realisierungsmöglichkeiten === | | == [[AlphaBot_Projektplanung_WS2021|Projektplanung]] == |
|
| |
|
| Eine Realisierungsmöglichkeit ist den Alphabot abzumessen und dementsprechend in Solidworks zu verwirklichen. Dadurch, dass der Alphabot eine recht komplexe Geometrie besitzt kann man auch über eine andere Realisierungsmöglichkkeit nachdenken. Eine andere Realisierungsmöglichkeit wäre es wenn man den "Boden" des Alphabot abschraubt und davon ein Foto macht. Dieses Foto kann man in Solidworks mithilfe der Funktion Autotrace nachzeichnen. Mithilfe dieser Funktion kann man ein viele realistischere Abbildung des Alphabot erreichen und zu einem besseren Ergebnis gelangen. Um das Modell auch funktionsfähig zu machen, lassen sich Motoren "implantieren", um die jeweiligen Teile beweglich beziehungsweise drehbar zu machen.
| | [[Datei:ProjectPlan_AlphaBot.png|1200px|Gantt-Chart]] |
| | |
| [[Datei:Alphabot_Grundfläche.jpg|right|mini|300px|Abb.2 Alphabot Grundfläche <nowiki></nowiki>]]
| |
| | |
| === Tutorials und Grundlagen für das Arbeiten mit Solidworks ===
| |
| | |
| Um das Modell zu verwirklichen ist es wichtig sich immerhin mit den Grundlagen von Solidworks vertraut zu machen. Wir haben die Version Solidworks 2019/2020 genutzt.
| |
| | |
| ==== Grundlagen Solidworks ====
| |
| | |
| Wenn man das Programm öffnet wird man als erstes gefragt ob man ein Modell zu einem " Teil " oder eine ganze " Baugruppe" erstellen möchte. Ein Teil ist nur Element von vielen aus einer ganzen Baugruppe. Eine Baugruppe ist ein Zusammenschluss von mehreren Teilen.
| |
| | |
| Am Anfang des Modellierens stellt sich die Frage ob man das Modell in mehrere Teile unterteilen möchte oder ob man direkt eine in sich geschlossene Baugruppe erstellen möchte. In vielen Fällen ist es leichter die Baugruppe in mehrere Teile zu unterteilen da man auch in Funktionen von verschiedenen Teilen unterscheiden kann. In unserem Fall hat es mehr Sinn gemacht die Die Baugruppe zu unterteilen, da die Räder eine andere Drehbewegung haben als die Der Sensor.
| |
| | |
| | |
| [[Datei:Teil_Baugruppe_Abbildung.png|left|mini|300px|Abb.3 Teil oder Baugruppe Ansicht <nowiki></nowiki>]]
| |
| | |
| | |
| <br clear = all>
| |
| | |
| Nachdem man sich nun entschieden hat ein Teil oder eine Baugruppe zu erstellen öffnet sich ein neues Fenster. In der Mitte des Fensters ist der Arbeitsplatz wo das Modell erstellt wird. Dieser Arbeitsplatz ist eingeteilt in verschiedenen Bereichen. Der größte Bereich befindet sich in der Mitte und dient dem Visualisieren der Zeichnung.
| |
| | |
| | |
| [[Datei:Solidworks_Arbeitsplatz_Graphikbereich.png|left|mini|300px|Abb.4 Graphikbereich <nowiki></nowiki>]]
| |
| | |
| <br clear = all>
| |
| | |
| Überhalb des Graphikbereichs befinden sich die Werkzeuge für das Erstellen des Modells. Die Werkzeuge werden in verschiedenen Anwendungen unterschieden welche man über die Registerkarten erreichen kann. Die Hauptsächlich relevanten Anwendungen sind die "Skizze" , "Features" und "Solidworks Zusatzanwendungen".
| |
| | |
| [[Datei:Solidworks_Arbeitsplatz_Anwendungszentrale.png|left|mini|300px|Abb.5 Anwendungszentrale <nowiki></nowiki>]] | |
| | |
| <br clear = all>
| |
| | |
| Um nun die Zeichnung zu starten, muss man eine Ebene auswählen in der die Zeichnung sich befinden soll. Typischerweise bevorzugt man die Ebene vorne, da man hinterher einen besseren Blick auf die Zeichnung hat. Die Ebene wird auf der linken Seite des Bildschirmes ausgewählt. Nachdem die Ebene ausgewählt wurde, kann man über das Werkzeug "Skizze" auf elementare Geometrieen wie zum Beispiel Linie oder Viereck zu greifen. Wichtig ist, dass man in Solidworks alle relevanten Längen bemaßt. Ohne eine präzise Bemaßung der Zeichnung lassen sich zukünftige Features nicht anwenden. Das Bemaßen findet man ebenso unter dem Werkzeug "Skizze" als "Intilligente Bemaßung". Man erkennt eine richtig bemaßte Zeichnung anhand der Beschreibung als "voll definiert" unten rechts. Ebenso werden die Kanten der Zeichnung schwarz gefärbt.
| |
| | |
| [[Datei:Voll_definierte_Zeichnung.png|left|mini|300px|Abb.6 Voll definierte Zeichnung <nowiki></nowiki>]]
| |
| | |
| <br clear = all>
| |
| | |
| Mithilfe des Features "linear ausgetragener Aufsatz" lassen sich zwei dimensionale Zeichnungen in 3 dimensionale Körper überführen. Die Dicke kann man links im Menü daraufhin einstellen.
| |
| [[Datei:Körper_Ausgetragen.PNG|left|mini|300px|Abb.7 Körper austragen <nowiki></nowiki>]]
| |
| | |
| <br clear = all>
| |
| | |
| ==== Autotrace ====
| |
| | |
| ==== Motor ====
| |
| | |
| === Modell mit Webots verknüpfen ===
| |
| | |
| === Bericht unseres Modells ===
| |
| | |
| ==== Schritt für Schritt Erklärung zu dem fertigen Modell ====
| |
| | |
| Vor dem Arbeiten mit dem Programm ist es empfehlenswert eine handschriftliche Skizze der Zeichnung anzufertigen, um einen besseren Überblick zu bekommen. Für diesen Schritt ist es notwendig alle Maße des Alphabots präzise abzumessen und ordnungsgerecht einzutragen. In unserem Fall haben wir jeweils eine Skizze für die Grundfläche, für die Räder und den Sensor erstellt. Dementsprechend haben wir auch 3 verschiedene Bauteile gehabt die wir hinterher zu einer Baugruppe definiert haben. Die Folgende Anleitung beschreibt Schritt für Schritt wie wir von unserer Skizze zu dem späteren Modell gelangt sind.
| |
| | |
| 1. Grundfläche skizzieren und bemaßen
| |
| <br clear=all>
| |
| 2. Das Werkzeug " Linear ausgetragener Aufsatz" verwenden
| |
| <br clear=all>
| |
| 3.Räder skizzieren und austragen
| |
| <br clear=all>
| |
| 4. Sensor skizzieren und austragen
| |
| <br clear=all>
| |
| 5. Baugruppe erstellen und alle Teile miteinander verknüpfen
| |
| <br clear=all>
| |
| 6. Bewegliche Teile bestimmen und Motor integrieren
| |
| <br clear=all>
| |
| 7. Checken ob der Bewegungsablauf wie gewünscht ist
| |
| <br clear=all> | | <br clear=all> |
|
| |
|
| ==== Motor und Drehbewegungen des Modells ==== | | == Übersicht == |
| | === Dokumentation === |
| | * [[AlphaBot_ROS2_System| Systembeschreibung]] |
| | * [[Robot Operating System 2|Robot Operating System 2 (ROS2)]] |
| | * [[Webots|Webots]] |
| | * [[3D_Modellierung_eines_AlphaBot|3D-Modellierung eines AlphaBot]] |
| | * [[AlphaBot|AlphaBot]] |
| | * [[Integration of Raspberry Pi with Alphabot|Integration of Raspberry Pi with Alphabot]] |
| | * [[Modellsimulation_in_Webots_und_Simulationen_mit_ROS2|Modellsimulation in Webots und Simulationen mit ROS2]] |
|
| |
|
| ==== Erfahrungen mit dem Modell in Webots ==== | | === Demo === |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| <br clear = all>
| |
| | |
| == Model Simulation in Webots ==
| |
| | |
| | |
| | |
| | |
| <br clear = all>
| |
| | |
| == Alphabot , Raspberry Pi / Arduino und andere Komponenten ==
| |
| | |
| | |
| <br clear = all>
| |
| | |
| == Microcontroller coding mit der Integration von Ros 2 ==
| |
| | |
| <br clear = all>
| |
| '''Autor:''' [[Benutzer:Jonas_Gerken| Jonas Gerken]]
| |
| | |
| Um den Microcontroller anzusteuern wurde er über SSH verbunden, um gleichzeitig weiter im normalen Ubuntu OS weiterarbeiten kann.
| |
| | |
| === Raspberry Pi mit SSH(Secure Shell) verbinden ===
| |
| | |
| SSH wird verwendet, um den Raspberry Pi ohne eine HDMI-Verbindung zu nutzen zukönnen.
| |
| 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, und die lokalen Tastatureingaben werden an den entfernten Rechner gesendet.
| |
| | |
| So kann später in diesem Fall der Roboter über eine Ethernet oder Wifi-Verbindung gesteuert werden.
| |
| | |
| Um SSH zu aktivieren muss auf der SD-Karte im boot-Verzeichnis eine lehre Text-Datei mit dem Namen "ssh" erstellt werden. (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 einer Umbennung angezeigt und es kann die .txt Endung entfernt werden.
| |
| | |
| Für die SSH-Verbindung wird die IP-Adresse des Raspberry Pi's benötigt.
| |
| Dafür muss er mit einem HDMI Kabel an einen Bildschirm angeschlossen werden.
| |
| Nach der Anmeldung auf dem Raspberry Pi, kann die IP-Adresse abgelesen werden. Abb. 2)
| |
| | |
| [[Datei:StartBild_Ubuntu_Server.png|left|mini|300px|Abb 2: Beispiel <nowiki>IP-Adresse</nowiki>]]
| |
| <br clear=all>
| |
| | |
| 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.
| |
| [[Datei:Ethernet.png|left|mini|500px|Abb 4: Beispiel <nowiki>Ethernet-Konfiguration</nowiki>]]
| |
| <br clear=all>
| |
| | |
| Hier werden dann die benötigte Wifi-Konfiguration wie in Abb. 4 zusehen ist hinzugefügt.
| |
| [[Datei:Wifi-Konfiguration.png|left|mini|200px|Abb 4: Beispiel <nowiki>Wifi-Konfiguration</nowiki>]]
| |
| <br clear=all>
| |
| | |
| 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.
| |
| | |
| === ROS2 Code auf RPi===
| |
| | |
| 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.
| |
| | |
| === Testing ===
| |
| | |
| == Projekt Hanning ==
| |
| | |
| | |
| <br clear = all>
| |
| | |
| == Ros 2 Navigation ==
| |
| | |
| | |
| <br clear = all>
| |
| | |
| == Installation von Ros 2 auf den Raspberry Pi ==
| |
| | |
| | |
| <br clear = all>
| |
|
| |
|
| | === Software === |
|
| |
|
| | == Weiterführende Links == |
| | *[[Wiki-Artikel_schreiben | Tipps zum Schreiben eines Wiki-Artikels]] |
| | *[[ArduMower:_Simulation_der_Kinematik_eines_Fahrzeugs_mit_drei_R%C3%A4dern|Beispiel-Artikel von Prof. Göbel]] |
| | *[[ArduMower:_Kartierung_in_Matlab/Simulink|Beispiel-Artikel von Prof. Schneider]] |
| | *[[Studentische_Arbeiten_bei_Prof._Schneider|Studentische Arbeiten bei Prof. Schneider]] |
| | *[[Anforderungen_an_eine_wissenschaftlich_Arbeit| Anforderungen an eine wissenschaftlich Arbeit]] |
|
| |
|
| == Matlab ==
| |
|
| |
|
| ---- | | ---- |
| → zurück zum Hauptartikel: [[Robotik_und_autonome_Systeme|Robotik und autonome Systeme]] | | → zurück zum Hauptartikel: [[Robotik_und_autonome_Systeme|Robotik und autonome Systeme]] |