AlphaBot: Servo mit MATLAB ansteuern: Unterschied zwischen den Versionen

Aus HSHL Mechatronik
Zur Navigation springen Zur Suche springen
 
(12 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 27: Zeile 27:




== Versuchsdurchführung ==
= Versuchsdurchführung =


=== Aufgabe 3.1: Ultraschall als Umfeldscanner ===
== Aufgabe 3.1: Ultraschall als Umfeldscanner ==
# '''Voreinstellungen am AlphaBot''': Entfernen Sie am AlphaBot am F-Port die Brücke D11 & D12.
# '''Voreinstellungen am AlphaBot''': Entfernen Sie am AlphaBot am F-Port die Brücke D11 & D12.
# Machen Sie sich mit dem Demo [https://de.mathworks.com/help/matlab/supportpkg/arduinoio-rotate-a-servo-motor.html Rotate a servo motor] vertraut, so dass Sie jede Zeile erläutern können.
# Machen Sie sich mit dem Demo [https://de.mathworks.com/help/matlab/supportpkg/arduinoio-rotate-a-servo-motor.html Rotate a servo motor] vertraut, so dass Sie jede Zeile erläutern können.
# Kopieren Sie das Beispiel in Ihren Ordner und erweitern Sie es.
# Steuern Sie den Servo schrittweise von 0°..180° an und fahren Sie schrittweise zurück auf 0°.
# Steuern Sie den Servo schrittweise von 0°..180° an und fahren Sie schrittweise zurück auf 0°.
# Messen Sie pro 5 ° die Ultraschallentfernung.  
# Messen Sie pro 5 ° die Ultraschallentfernung.  
Zeile 44: Zeile 43:


'''Arbeitsergebnisse''' in SVN: <code>UltraschallScanner.m</code>
'''Arbeitsergebnisse''' in SVN: <code>UltraschallScanner.m</code>
<!--
 
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
| <strong>Tipp 1&thinsp;</strong>
|-
| Nutzen Sie das Demo [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E25_Servo_Sweep SVN: E25_Servo_Sweep].
|}
-->
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
| <strong>Tipp 1&thinsp;</strong>
| <strong>Tipp 1&thinsp;</strong>
Zeile 56: Zeile 49:
|Umrechnung der Koordinaten polar→kartesisch:<br> <math> x = r\cdot cos(\alpha)</math> <br><math> y = r\cdot sin(\alpha)</math>
|Umrechnung der Koordinaten polar→kartesisch:<br> <math> x = r\cdot cos(\alpha)</math> <br><math> y = r\cdot sin(\alpha)</math>
|}
|}
----
<!--
=== Aufgabe 3.1: Servo ansteuern ===
In dieser Aufgabe soll der Ultraschallkopf mittles Servomotor und Potentiometer geschwenkt werden und die Messwerte des Ultraschall-Sensors übergeben werden.
# Voreinstellungen am AlphaBot nicht alle Sensoren funktionieren [https://wiki.hshl.de/wiki/index.php/AlphaBot_Sensorbr%C3%BCcken#Sensor_Pinbelegung_Kolisionsliste gleichzeitig], da sie den gleichen Arduino Pin benutzen. Entfernen Sie bitte dazu am AlphaBot einzelne gelbe Brücken.  Am F-Port die Brücke D10 und das Dual-Mode Bluetooth Modul auf dem Sensor-Shield.
# Aktualisieren Sie die Arduino Bibliothek.
# Machen Sie sich mit dem Demo <code>E24_Servo_Poti</code> vertraut, so dass Sie jede Zeile erläutern können.
# Kopieren Sie das Beispiel in Ihren Ordner und erweitern Sie es.
# Lesen Sie die Stellung des Potentiometers aus.
# Steuern Sie den Servomotor mit dem Potentiometer an. Nutzen Sie hierzu den <code>map</code>-Befehl.
# 0% ist ganz links und 100% ganz rechts.
# Lagern Sie die Ansteuerung in eine Funktion <code>dreheUltraschall(Wert)</code> aus.
# Nutzen Sie MATLAB<sup>®</sup> um die Messdaten direkt (live) darzustellen.
Übertragen Sie folgende Parameter:
* <code>fZeit</code>: Zeit
* <code>fEntfernung</code>: Entfernung in cm
* <code>fWinkel</code>: Winkel des Servo-Motors in deg
'''Hardwarevorbereitung:'''
Die Multisensorerweiterung verursacht gelegentlich Probleme. Nutzen Sie für den Ultraschallsensor ggf. andere Digital-IO (z.&thinsp;B. <code>D7, D8</code>).
'''Lernzielkontrollfragen:'''
* Wie funktioniert ein Potentiometer (Poti)?
* An welchem Arduino-Pins ist das Poti angeschlossen? Welche Spannungsversorgung hat das Poti? Welchen Widerstand hat das Poti?
* Welche theoretischen Werte liefert das Potentiometer an A0? Welche Werte messen Sie praktisch? Nutzen sie die realen minimal und Maximalwerte in Ihrem Quelltext.
* An welchem Arduino-Pins ist der Servo angeschlossen?
'''Arbeitsergebnisse''' in SVN: <code>dreheServoMotor.ino</code>, <code>zeigeUltraschallMesswerte.m</code>
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
| <strong>Tipp 1&thinsp;</strong>
|-
| Nutzen Sie das Demo [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E24_Servo_Poti SVN: E24_Servo_Poti].
|-
| Sie können den Potentiometerwinkel mit <code>read()</code> auslesen.
|-
| Je nachdem, ob Akkus eingelegt sind oder nicht, hat das Poti leicht andere Werte.
|-
| Die Multisensorerweiterung verursacht gelegentlich Probleme. Nutzen Sie für den Ultraschallsensor ggf. andere Digital-IO (z.&thinsp;B. <code>D7, D8</code>).
|-
| Den Schaltplan für die Multisensorerweiterung finden Sie [[Medium:Accessory-Shield-Schematic.pdf|hier]].


|}
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
| <strong>Tipp 2&thinsp;</strong>
| <strong>Musterlösung&thinsp;</strong>
|-
|-
| Ergebnisplot:<br>[[Datei:Inf2P_4_1.jpg|left|350px|Abb. 4: Ergebnisdarstellung CNTL vs. CNTR]]<br> Abb. 2: Entfernung und Winkel über der Zeit
| <source line lang="matlab" style="font-size:medium">close all; clc; % Initialisierung
|}
if ~exist('hArduino') % Besteht die Verbindung zum Arduino bereits?
----
    hArduino    = arduino('COM5','Uno','Libraries',{'Ultrasonic','Servo'}); % Arduino Objekt erzeugen
 
    hUltraschall = ultrasonic(hArduino,'D7','D8','OutputFormat','double')
 
    hServo      = servo(hArduino, 'D9', 'MinPulseDuration', 1e-3, 'MaxPulseDuration', 2e-3);
----
else
    clear x y % Darstellung löschen
end
%% Variablen initialisieren
Winkel = 0; % Winkel in deg
j=0;
%% Ergebnisdarstellung vorbereiten
figure;
hold on
hPlot = plot(0,0,'r.');
xlabel('x in cm')
ylabel('y in cm')
%% Messung
while 1 % Endlosschleife
    writePosition(hServo, Winkel/180);          % Servo drehen
    Distanz = inf;
    while isinf(Distanz)
        pause(0.5)                              % Zeit zum Drehung/Messen
        Distanz = readDistance(hUltraschall)*100 % Messung in cm
    end
    j=j+1;
    x(j) = Distanz*cosd(Winkel);                % Umrechnung in kartesische Koordinaten
    y(j) = Distanz*sind(Winkel);
    set(hPlot,'XData',x,'YData',y);              % Darstellung


=== Aufgabe 3.3: Joystick einlesen ===
    if Winkel <=0                                % Drehrichtung anpassen
# Voreinstellungen am AlphaBot: Legen Sie keine Akkus ein (Betrieb am USB-Kabel).
        nInkrement = 5;
# Machen Sie sich mit dem Demo <code>E20_Joystick</code> vertraut, so dass Sie jede Zeile erläutern können.
    elseif Winkel >=180
# Kopieren Sie das Beispiel in Ihren Ordner und erweitern Sie es.
        nInkrement = -5;
# Lesen Sie den Joystick mit der Funktion int <code>leseJoystickStatus()</code> ein.
    end
# Entprellen Sie darin das Joystick-Signal.
    Winkel = Winkel + nInkrement                % Winkel errechnen
# Steuert den US-Servo mit dem Joystick im Bereich 0°-180° an.
end
# LINKS: Drehung nach Links (180°).
</source>
# RECHTS: Drehung nach Rechts (0°).
# EINGABE: Drehung auf die Mitte (90°).
# Geben Sie den Joystick-Status im seriellen Monitor aus. Nutzen Sie hierzu die <code>switch..case</code>-Verzweigung.
 
'''Lernzielkontrollfragen:'''
* An welchen Arduino-Pins ist der Joystick angeschlossen?
* Werden diese Pins noch von einem anderen System genutzt?
* Kann der Joystick via Interrupt entprellt werden?
 
'''Arbeitsergebnisse''' in SVN: <code>leseJoystick.ino</code>
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
| <strong>Tipp 1&thinsp;</strong>
|-
| Nutzen Sie das Demo für den Joystick E20 und den Servo E25 und kombinieren Sie beide.
|}
|}
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
| <strong>Tipp 2&thinsp;</strong>
|-
|
* Lesen Die die notwendigen Joystick-Bewegungen aus (L, R, Eingabe).
* Initialisiere einen <code>static</code> Variable für die Position des Servo <code>ServoPosition_s16</code>.
* Inkrementiere bei Joystick-Eingabe <code>LINKS</code> um 5°.
* Dekrementiere bei Joystick-Eingabe <code>RECHTS</code> um -5°.
* Initialisiere <code>ServoPosition_s16</code> bei Joystick-Eingabe <code>EINGABE</code> mit 90°.
* Sende <code>ServoPosition_s16</code>  an den Servo (<code>usServo.write(ServoPosition_s16);</code>).
|-
| '''ACHTUNG:''' Begrenze <code>ServoPosition_s16</code> auf 0°...180° vor dem Senden.
|}
-->


=== Aufgabe 3.2: Nachhaltige Doku ===
== Aufgabe 3.2: Nachhaltige Doku ==
Sichern Sie alle Ergebnisse mit beschreibendem Text (<code>message</code>) in SVN.
Sichern Sie alle Ergebnisse mit beschreibendem Text (<code>message</code>) in SVN.
* Halten Sie die Regeln für den [[Software_Versionsverwaltung_mit_SVN|Umgang mit SVN]] ein.
* Halten Sie die Regeln für den [[Software_Versionsverwaltung_mit_SVN|Umgang mit SVN]] ein.
Zeile 158: Zeile 102:
'''Arbeitsergebnis''' in SVN: <code>SVN Log</code>
'''Arbeitsergebnis''' in SVN: <code>SVN Log</code>


== Tutorials ==
= Tutorials =
* [[AlphaBot|Erste Schritte mit dem AlphaBot]]
* [[AlphaBot|Erste Schritte mit dem AlphaBot]]
* [[Erste_Schritte_mit_der_Arduino_IDE|Erste Schritte mit der Arduino IDE]]
* [[Erste_Schritte_mit_der_Arduino_IDE|Erste Schritte mit der Arduino IDE]]
Zeile 166: Zeile 110:
* [[AlphaBot_Accessory_Shield| HSHL-Wiki: AlphaBot Multisensorerweiterung]]
* [[AlphaBot_Accessory_Shield| HSHL-Wiki: AlphaBot Multisensorerweiterung]]
* [[AlphaBot Uno Plus| HSHL-Wiki: Übersicht des AlphaBot Uno Plus]]
* [[AlphaBot Uno Plus| HSHL-Wiki: Übersicht des AlphaBot Uno Plus]]
== Demos ==
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E05_Ultraschall_Entfernungsmessung SVN: <code>E05_Ultraschall_Entfernungsmessung</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E18b_spieleTon  SVN: <code>E18b_spieleTon</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E20_Joystick  SVN: <code>E20_Joystick</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E23_RGB_LED  SVN: <code>E23_RGB_LED</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E24_Servo_Poti  SVN: <code>E24_Servo_Poti</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E25_Servo_Sweep  SVN: <code>E25_Servo_Sweep</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E31_Debug2MATLAB SVN: <code>E31_Debug2MATLAB</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/AlphaBot/ArduinoLibOrdner/AlphaBot/examples/E34_lesePoti SVN: <code>E34_lesePoti</code>]




----
----
→ Termine [[Einführungsveranstaltung_Informatikpraktikum_2_im_SoSe_2023|1]] [[AlphaBot:_Hardware_Support_Package_für_MATLAB|2]] [[AlphaBot: Servo ansteuern|3]] [[AlphaBot:_Motoren_und_Inkrementalgeber|5]] [[AlphaBot: Programmier-Challenge I SoSe23|6]] [[AlphaBot:_Gesteuerte_Fahrt|7]] [[AlphaBot: Geregelte Fahrt mit Linienverfolger|8]] [[AlphaBot: Parklücke suchen|9]] [[AlphaBot: Autonomes Einparken|10]] [[AlphaBot: Programmier-Challenge II SoSe23|11]]<br>
→ Termine [[Einführungsveranstaltung_Informatikpraktikum_2_im_SoSe_2025|1]] [[AlphaBot:_Hardware_Support_Package_für_MATLAB|2]] [[AlphaBot: Servo_mit_MATLAB_ansteuern|3]] [[AlphaBot:_Motoren_und_Inkrementalgeber|4]] [[AlphaBot: Programmier-Challenge I SoSe25|5]] [[AlphaBot:_Gesteuerte_Geradeausfahrt|6]] [[AlphaBot: Geregelte Fahrt mit Linienverfolger|7]] [[AlphaBot: Parklücke suchen|8]] [[AlphaBot: Autonomes Einparken|9]] [[AlphaBot: Programmier-Challenge II SoSe25|10]]<br>
→ zurück zum Hauptartikel: [[AlphaBot_SoSe25|Informatik Praktikum 2]]
→ zurück zum Hauptartikel: [[AlphaBot_SoSe25|Informatik Praktikum 2]]

Aktuelle Version vom 14. Mai 2025, 20:46 Uhr

Abb. 1: Ultraschall zur Objekterkennung
Autor: Prof. Dr.-Ing. Schneider
Modul: Praxismodul II, MTR-B-2-2.11
Lehrveranstaltung: Mechatronik, Informatik Praktikum 2, 2. Semester

Inhalt

  • Nutzung von MATLAB® zur Kommunikation mit dem AlphaBot.
  • Ansteuerung des Servomotors
  • Statische und dynamische Messung mit dem Ultraschallsensor
  • Anwendung rekursiver Filter auf Echtzeitdaten

Lernziele

Nach Durchführung dieser Lektion können Sie

  • Debug-Daten speichern und via MATLAB® visualisieren.
  • direkt MATLAB® als seriellen Monitor nutzen.
  • den AlphaBot sicher in Betrieb nehmen, das Potentiometer auslesen und eine RGB-LED ansteuern.
  • Entfernungen mit dem Ultraschall-Sensor messen.
  • Messwerte in Echtzeit filtern.


Versuchsdurchführung

Aufgabe 3.1: Ultraschall als Umfeldscanner

  1. Voreinstellungen am AlphaBot: Entfernen Sie am AlphaBot am F-Port die Brücke D11 & D12.
  2. Machen Sie sich mit dem Demo Rotate a servo motor vertraut, so dass Sie jede Zeile erläutern können.
  3. Steuern Sie den Servo schrittweise von 0°..180° an und fahren Sie schrittweise zurück auf 0°.
  4. Messen Sie pro 5 ° die Ultraschallentfernung.
  5. Filtern Sie die Ultraschallentfernung mit dem vielversprechendsten Filter aus Aufgabe 2.4.
  6. Nutzen Sie MATLAB® um die Messdaten direkt (live) darzustellen.
  7. Rechnen Sie die Polarkoordinaten (fWinkel, fEntfernung) in kartesische Koordinaten (x, y) um.
  8. Stellen Sie die Messpunkte zyklisch dar (vgl. Abb. 1).

Lernzielkontrollfragen:

  • An welchen Arduino-Pins ist der Servo (S1) angeschlossen?

Arbeitsergebnisse in SVN: UltraschallScanner.m

Aufgabe 3.2: Nachhaltige Doku

Sichern Sie alle Ergebnisse mit beschreibendem Text (message) in SVN.

Arbeitsergebnis in SVN: SVN Log

Tutorials



→ Termine 1 2 3 4 5 6 7 8 9 10
→ zurück zum Hauptartikel: Informatik Praktikum 2