AlphaBot: Hardware Support Package für MATLAB: Unterschied zwischen den Versionen

Aus HSHL Mechatronik
Zur Navigation springen Zur Suche springen
(8 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 58: Zeile 58:
* [[Potentiometer_B_50K| HSHL-Wiki: Potentiometer]]
* [[Potentiometer_B_50K| HSHL-Wiki: Potentiometer]]
* [[Rekursive Filter| HSHL-Wiki: Rekursive Filter]]
* [[Rekursive Filter| HSHL-Wiki: Rekursive Filter]]
* [[Medium:Accessory-Shield-Schematic.pdf|Schaltplan]]
* [[Medium:Accessory-Shield-Schematic.pdf|Schaltplan der Multisensorplatine]]
= Demos =
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/MATLAB/Filter/GleitendesMittelwertFilter MATLAB<sup>®</sup>: <code>GleitendesMittelwertFilter.m</sup></code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/MATLAB/Filter/MedianFilter  MATLAB<sup>®</sup>: <code>MedianFilter.m</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/MATLAB/Filter/MittelwertFilter  MATLAB<sup>®</sup>: <code>MittelwertFilter.m</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/MATLAB/Filter/TiefpassFilter MATLAB<sup>®</sup>: <code>TiefpassFilter.m</code>]


= Warnung =
= Warnung =
Zeile 104: Zeile 109:
# Bei Tasterdruck des Joysticks ertönt der Summer an <code>D11</code>.
# Bei Tasterdruck des Joysticks ertönt der Summer an <code>D11</code>.
# Regeln Sie mit dem Potentiometers die Frequenz des Summertons.
# Regeln Sie mit dem Potentiometers die Frequenz des Summertons.
'''Nützlich MATLAB<sup>®</sup>-Befehle:''' <code>aduino, figure, plot, xlabel, ylabel, tic, toc, readVoltage, set, if..else, playTone</code>


'''Arbeitsergebnisse:''' <code>leseJoystick.m</code>
'''Arbeitsergebnisse:''' <code>leseJoystick.m</code>
Zeile 112: Zeile 119:
|
|
* Messen Sie den Arbeitsbereich des Potis aus.
* Messen Sie den Arbeitsbereich des Potis aus.
* Skalieren Sie die Poti-Werte auf die Lautstärke.
* Skalieren Sie die Poti-Werte auf die Frequenz.
* Nützliche Befehle: <code>aduino, figure, plot, xlabel, ylabel, tic, toc, readVoltage, set, if..else, playTone</code>
|}
|}
-->
-->
Zeile 121: Zeile 127:
# Zeigen Sie die Distanzwerte in cm über der Zeit live während der Messung an.
# Zeigen Sie die Distanzwerte in cm über der Zeit live während der Messung an.
# Fehlmessungen (<code>inf</code>) dürfen nicht angezeigt werden.
# Fehlmessungen (<code>inf</code>) dürfen nicht angezeigt werden.
# Speichern Sie die Aergebnis-Arrays <code>Zeit</code> und <code>Distanz</code> in der Datei <code>Ultraschall.mat</code>.
# Speichern Sie die Ergebnis-Arrays <code>Zeit</code> und <code>Distanz</code> in der Datei <code>Ultraschall.mat</code>.
 
'''Nützlich MATLAB<sup>®</sup>-Befehle:''' <code>aduino, figure, plot, xlabel, ylabel, tic, toc, readDistance, set, if..else, isinf, save, clear</code>


'''Arbeitsergebnisse''' in SVN: <code>leseUltraschall.m, Ultraschall.mat</code>
'''Arbeitsergebnisse''' in SVN: <code>leseUltraschall.m, Ultraschall.mat</code>


* Nützliche Befehle: <code>aduino, figure, plot, xlabel, ylabel, tic, toc, readDistance, set, if..else, isinf, save, clear</code>
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
| <strong>Teillösung&thinsp;</strong>
| <strong>Teillösung&thinsp;</strong>
Zeile 131: Zeile 138:
| <source line lang="matlab" style="font-size:medium">clear all; close all; clc; % Initialisierung
| <source line lang="matlab" style="font-size:medium">clear all; close all; clc; % Initialisierung
hArduino = arduino('COM8','Uno','Libraries','Ultrasonic'); % Arduino Objekt erzeugen
hArduino = arduino('COM8','Uno','Libraries','Ultrasonic'); % Arduino Objekt erzeugen
hUltraschall = ultrasonic(hArduino,'D2','D3','OutputFormat','double')
hUltraschall = ultrasonic(hArduino,'D11','D12','OutputFormat','double')
nMesswerte = 100;
nMesswerte = 100;
%% Messschleife
%% Messschleife
Zeile 147: Zeile 154:
</source>
</source>
|}
|}
== Aufgabe 2.3: Glättung der Ultraschallmessung ==
== Aufgabe 2.3: Glättung der Ultraschallmessung ==
# Nutzen Sie Ihre Ergebnisse aus Aufgabe 2.3 (<code>Ultraschall.mat</code>), um die Messwerte zu glätten.
# Nutzen Sie Ihre Ergebnisse aus Aufgabe 2.3 (<code>Ultraschall.mat</code>), um die Messwerte zu glätten.
Zeile 153: Zeile 161:
# Vergleichen Sie die Ergebnisse der Filter in einem Plot mit Achsenbeschriftung und Legende anhand technischer Kriterien (Rauschunterdrückung, Verzögerung, Ausreisserfilterung, Programmieraufwand).
# Vergleichen Sie die Ergebnisse der Filter in einem Plot mit Achsenbeschriftung und Legende anhand technischer Kriterien (Rauschunterdrückung, Verzögerung, Ausreisserfilterung, Programmieraufwand).


'''Nützlich MATLAB<sup>®</sup>-Befehle:''' <code>addpath</code>


'''Arbeitsergebnisse''' in SVN: <code>filtereUltraschall.m</code>
'''Arbeitsergebnisse''' in SVN: <code>filtereUltraschall.m</code>
Zeile 177: Zeile 187:
'''Arbeitsergebnis''' in SVN: <code>SVN Log</code>
'''Arbeitsergebnis''' in SVN: <code>SVN Log</code>


= Demos =
 
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/MATLAB/Filter <code>Rekursive Filter in MATLAB<sup>®</sup></code>]


== [[Datei:Lektionen.jpg|60px]] Ausblick zur nächsten Lektion ==
== [[Datei:Lektionen.jpg|60px]] Ausblick zur nächsten Lektion ==

Version vom 23. April 2026, 14:28 Uhr

Abb. 1: MATLAB® als serieller Monitor
Autor: Prof. Dr.-Ing. Schneider
Modul: Praxismodul II, MTR-B-2-2.11
Lehrveranstaltung: Mechatronik, Informatik Praktikum 2, 2. Semester

Inhalt

  • Nutzung von MATLAB® als seriellen Monitor.
  • Inbetriebnahme des AlphaBot
  • Einbindung der Bibliotheken für den AlphaBot
  • Auslesen eine Potentiometers
  • Ansteuern eines Lautsprechers
  • 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 Summer ansteuern.
  • Entfernungen mit dem Ultraschall-Sensor messen.
  • Messwerte in Echtzeit filtern.

Lernzielkontrolle

  • Was sind die Gefahren bei der Verwendung eines AlphaBots?
  • Wann muss ich die Akkus verwenden?
  • Was ist das "Plus" am Arduino Plus?
  • Welche Sensoren und Aktoren sind an den Arduino Plus angeschlossen?
  • Wie stecke ich den Ultraschallsensor ein?
  • Was ist ein Medianfilter und wie funktioniert es?

Versuchsvorbereitung

  • Arbeiten Sie sich anhand des Wiki-Artikels in den AlphaBot ein. Beachten Sie besonders die Ausrichtung der Akkus. ACHTUNG BRANDGEFAHR!
  • Machen Sie sich mit der Multisensorerweiterung vertraut.
  • Machen Sie sich mit den MATLAB®-Demos vertraut.
  • Lesen Sie die Artikel zu den verwendeten Sensoren.

MATLAB®-Vorbereitung

  • Das MATLAB Support Package für Arduino Hardware muss unter MATLAB® installiert werden
    • Starten Sie MATLAB®.
    • Wählen Sie unter Add-Ons das Get Hardware Support Packages aus.
    • Installieren Sie das MATLAB Support Package für Arduino Hardware.
  • Verbinden Sie Arduino und PC via USB.
  • Bringen Sie mit dem Geräte-Manager den COM-Port des Arduino in Erfahrung.
  • Testen Sie die Verbindung mit >> h = arduino('COM5','Uno') für Ihren COM-Port.

Tutorials

Demos

Warnung

  • Der AlphaBot verwendet sehr viele Sensoren, daher sind Ports mehrfach verwendet. Es kann somit zu Komplikationen kommen. Entfernen Sie einfach die Steckbrücken der Mehrfachbelegung.
  • Schützen Sie den Ultraschallsensor vor Verpolung! Beachten Sie die Beschriftung.

Versuchsdurchführung

Aufgabe 2.1: MATLAB® als serieller Monitor

  1. Nutzen Sie MATLAB® um die Messdaten direkt (live) darzustellen.
  2. Verbinden Sie den Arduino mit dem PC via USB.
  3. Greifen Sie hierzu auf die serielle Schnittstelle zu.
  4. Stellen Sie sicher, das die Multisensorerweiterung auf dem AlphaBot steckt.
  5. Drehen Sie, während der Messung, am Potentiometer und visualisieren Sie die Spannung über der Zeit an A0.

Nützlich MATLAB®-Befehle: arduino, tic, toc, readVoltage, plot, xlabel, ylabel, legend

Arbeitsergebnisse in SVN: lesePoti.m

Aufgabe 2.2: AlphaBot Ultraschall

  1. Messen Sie auf ein ebenes statisches Ziel in ca. 30 cm Entfernung.
  2. Lesen Sie für 10 s die Messwerte des Ultraschallsensor ein [1].
  3. Zeigen Sie die Distanzwerte in cm über der Zeit live während der Messung an.
  4. Fehlmessungen (inf) dürfen nicht angezeigt werden.
  5. Speichern Sie die Ergebnis-Arrays Zeit und Distanz in der Datei Ultraschall.mat.

Nützlich MATLAB®-Befehle: aduino, figure, plot, xlabel, ylabel, tic, toc, readDistance, set, if..else, isinf, save, clear

Arbeitsergebnisse in SVN: leseUltraschall.m, Ultraschall.mat

Aufgabe 2.3: Glättung der Ultraschallmessung

  1. Nutzen Sie Ihre Ergebnisse aus Aufgabe 2.3 (Ultraschall.mat), um die Messwerte zu glätten.
  2. Lesen Sie zyklisch die Daten aus der Datei Ultraschall.mat.
  3. Filtern Sie die Daten zyklisch mit einem gleitenden Mittelwertfilter, einem rekursiven Medianfilter und einem rekursiven Tiefpassfilter.
  4. Vergleichen Sie die Ergebnisse der Filter in einem Plot mit Achsenbeschriftung und Legende anhand technischer Kriterien (Rauschunterdrückung, Verzögerung, Ausreisserfilterung, Programmieraufwand).


Nützlich MATLAB®-Befehle: addpath

Arbeitsergebnisse in SVN: filtereUltraschall.m

Lernzielkontrollfragen:

  1. Wurde das Signalrauschen geglättet?
  2. Ist das gefilterte Signal verzögert?
  3. Welchen Einfluss haben die Filterparameter?
  4. Wie verhalten sich die gefilterten Signal bei Ausreißern?

Aufgabe 2.4: Nachhaltige Doku

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

Arbeitsergebnis in SVN: SVN Log


Ausblick zur nächsten Lektion

In der nächsten Lektion wird der Servomotor des AlphaBot mit MATLAB® angesteuert.



→ Termine 1 2 3 4 5 6 7 8 10 11 12
→ zurück zum Hauptartikel: Informatik Praktikum 2
→ Haben Sie Fragen? Informatik Praktikum FAQ