AlphaBot: Messdatenverarbeitung mit MATLAB: Unterschied zwischen den Versionen

Aus HSHL Mechatronik
Zur Navigation springen Zur Suche springen
Keine Bearbeitungszusammenfassung
Keine Bearbeitungszusammenfassung
 
(Eine dazwischenliegende Version desselben Benutzers wird nicht angezeigt)
Zeile 58: Zeile 58:
'''Tipp:''' Nutzen Sie das Demoprogramm [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoUltraschallHCSR04 DemoUltraschallHCSR04] als Programmierstart.
'''Tipp:''' Nutzen Sie das Demoprogramm [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoUltraschallHCSR04 DemoUltraschallHCSR04] als Programmierstart.
</div>
</div>
 
----
=== Aufgabe 1.2: Darstellung und Speicherung in MATLAB<sup>®</sup> ===
=== Aufgabe 1.2: Darstellung und Speicherung in MATLAB<sup>®</sup> ===
# Kopieren Sie das Demo [https://svn.hshl.de/usvn/project/Informatikpraktikum_1/show/trunk/Arduino/ArduinoLibOrdner/AlphaBot/examples/E32_DebugTxt2MATLAB/E32_DebugTxt2MATLAB.ino|<code>DemoDebugTxt2MATLAB.ino</code>] in Ihr Arbeitsverzeichnis und passen Sie es an.
# Kopieren Sie das Demo [https://svn.hshl.de/usvn/project/Informatikpraktikum_1/show/trunk/Arduino/ArduinoLibOrdner/AlphaBot/examples/E32_DebugTxt2MATLAB/E32_DebugTxt2MATLAB.ino|<code>DemoDebugTxt2MATLAB.ino</code>] in Ihr Arbeitsverzeichnis und passen Sie es an.
Zeile 78: Zeile 78:
<code>save('UltraschallMessung.mat','fZeit',fMesswerte','stTitel')</code>
<code>save('UltraschallMessung.mat','fZeit',fMesswerte','stTitel')</code>
</div>
</div>
 
----
=== Aufgabe 1.3: Zyklische Messdatenverarbeitung in MATLAB<sup>®</sup> ===
=== Aufgabe 1.3: Zyklische Messdatenverarbeitung in MATLAB<sup>®</sup> ===
# Schreiben Sie die Funktion <code>(fZeit, fEntfernung)=LeseUltraschall(k)</code> und speichern Sie diese in der Datei <code>LeseUltraschall.m</code>.
# Schreiben Sie die Funktion <code>(fZeit, fEntfernung)=LeseUltraschall(k)</code> und speichern Sie diese in der Datei <code>LeseUltraschall.m</code>.
Zeile 95: Zeile 95:
[[Datei:PAP_Aufgabe_1_4.jpg|thumb|left|450px|Abb. 2: PAP für die zyklische Messdatenverarbeitung]]
[[Datei:PAP_Aufgabe_1_4.jpg|thumb|left|450px|Abb. 2: PAP für die zyklische Messdatenverarbeitung]]
</div>
</div>
 
----
=== Aufgabe 1.4: Gleitendes Mittelwertfilter ===
=== Aufgabe 1.4: Gleitendes Mittelwertfilter ===
Ein gleitendes Mittlwertfilter bildet einen Mittelwert über k Messwerte mittels FIFO.
Ein gleitendes Mittlwertfilter bildet einen Mittelwert über k Messwerte mittels FIFO.
Zeile 131: Zeile 131:
Eine ausführliche Beschreibung mit Musterlösung finden Sie in [1, S.&thinsp;11&thinsp;ff.].
Eine ausführliche Beschreibung mit Musterlösung finden Sie in [1, S.&thinsp;11&thinsp;ff.].
|}
|}
 
----
=== Aufgabe 1.5: Rekursives Tiefpassfilter ===
=== Aufgabe 1.5: Rekursives Tiefpassfilter ===
Ein rekursives Filter kann Messwerte in Echtzeit während der Laufzeit filtern. Nutzen Sie ein Tiefpassfilter, um die Messwerte zu filtern.
Ein rekursives Filter kann Messwerte in Echtzeit während der Laufzeit filtern. Nutzen Sie ein Tiefpassfilter, um die Messwerte zu filtern.
Zeile 151: Zeile 151:
Eine ausführliche Beschreibung mit Musterlösung finden Sie in [1, S.&thinsp;11&thinsp;ff.19].
Eine ausführliche Beschreibung mit Musterlösung finden Sie in [1, S.&thinsp;11&thinsp;ff.19].
|}
|}
 
----
=== Aufgabe 1.6: Filtervergleich ===
=== Aufgabe 1.6: Filtervergleich ===
# Vergleichen Sie die Ergebnisse des Tiefpasses mit denen des gleitenden Mittelwertfilters.
# Vergleichen Sie die Ergebnisse des Tiefpasses mit denen des gleitenden Mittelwertfilters.
Zeile 169: Zeile 169:
| Eine ausführliche Beschreibung mit Musterlösung finden Sie in [1, S.&thinsp;27&thinsp;ff.].
| Eine ausführliche Beschreibung mit Musterlösung finden Sie in [1, S.&thinsp;27&thinsp;ff.].
|}
|}
== Tutorial zum Einstieg ==
== Tutorial zum Einstieg ==
* [[Software_Plagiat| Was ist ein Plagiat?]]
* [[Software_Plagiat| Was ist ein Plagiat?]]

Aktuelle Version vom 26. März 2025, 13:37 Uhr

Abb. 1: Vergleich rauschunterdrückender Filter
Autor: Prof. Dr.-Ing. Schneider
Modul: Praxismodul II
Lehrveranstaltung: Mechatronik, Informatik Praktikum 2, 2. Semester

Inhalt

  • Einarbeitung in MATLAB®
  • Programmierung und Anwendung eines gleitenden Mittelwertfilters
  • Programmierung und Anwendung eines rekursiven Tiefpassfilters
  • Auslegung von Filterparameter
  • Anwendung der Filter auf eine Ultraschallmessung
  • Vergleich der Filter anhand technischer Kriterien

Lernziele

Nach Durchführung dieser Lektion

  • können Sie reale Messwerte speichern und via MATLAB® zyklisch visualisieren.
  • haben Sie ein gleitendes Mittelwertfilter programmiert.
  • haben Sie ein rekursives rekursiven Tiefpassfilter programmiert.
  • können Sie die Filter parametrieren.
  • haben Sie die Filter zyklisch auf Ultraschallmesswerte angewendet und das Filterverhalten analysiert.
  • können Sie eine Funktion in MATLAB® programmieren und aufrufen.

Lernzielkontrolle

  1. Wozu werden rekursive Filter benötigt?
  2. Nennen Sie die Formel für ein gl. Mittelwertfilter.
  3. Welche Parameter hat ein gl. Mittelwertfilter? Was bedeuten die Parameter?
  4. Nennen Sie die rekursive Formel für ein Tiefpassfilter.
  5. Welche Parameter hat ein Tiefpassfilter? Was bedeuten die Parameter?
  6. Vergleichen Sie die zwei rekursiven Filter. Nennen Sie Vor- und Nachteile.
  7. Wurde der Quelltext durch Header und Kommentare aufgewertet?
  8. Wurde auf magic numbers verzichtet?
  9. Wurde die Programmierrichtlinie eingehalten?

Vorbereitung

Führen Sie als Vorbereitung den MATLAB® Onramp Kurs durch.


Arbeitsergebnis in SVN: MATLAB® Kurszertifikat

Versuchsdurchführung

Aufgabe 1.1: Positionserfassung mit Ultraschall

  1. Lesen Sie die Messwerte des Ultraschall-Sensors auf ein statisches Ziele aus. Schreiben Sie hierzu ein Arduino-Programm messeEntfernung.ino. Messen Sie zyklisch die Zeit mit dem Befehl millis().
  2. Messen Sie 10 s auf ein statisches Ziel (z. B. einen Karton) in 30 cm Entfernung.
  3. Nutzen Sie das Programm Putty, um die Daten der seriellen Schnittstelle in der ASCII-Datei UltraschallMessung.txt zu speichern. Eine Anleitung finden Sie unter der URL Einrichtung von PuTTY.
  4. Schreiben Sie einmalig als Header die Bezeichnung der Messwerte Zeit in ms und Strecke in cm in die Textdatei.

Nützliche Befehle: pinMode(), digitalWrite(), pulseIn(), delayMicroseconds(), millis()

Arbeitsergebnisse in SVN: UltraschallMessung.txt, messeEntfernung.ino

Tipp: Nutzen Sie das Demoprogramm DemoUltraschallHCSR04 als Programmierstart.


Aufgabe 1.2: Darstellung und Speicherung in MATLAB®

  1. Kopieren Sie das Demo DemoDebugTxt2MATLAB.ino in Ihr Arbeitsverzeichnis und passen Sie es an.
  2. Laden und visualisieren Sie die Messdaten in Ultraschallmessung.txt mit MATLAB®.
  3. Sichern Sie die Achsenbeschriftung im 2x1 Cell-Array stTitel.
  4. Stellen Sie die Messdaten in einem Diagramm in cm über der Zeit in s dar.
  5. Beschriften Sie die Graphen.
  6. Speichern Sie die Messung in der Datei UltraschallMessung.mat.

Nützliche Befehle: plot, xlabel, ylabel, save

Arbeitsergebnisse in SVN: zeigeUltraschallMessung.m, UltraschallMessung.mat

Gegeben (vgl. Abb. 1):

  • fZeit: 1x100 Messwertarray der Zeit in s
  • fMesswerte: 1x100 Messwertarray der Ultraschallwerte in cm

save('UltraschallMessung.mat','fZeit',fMesswerte','stTitel')


Aufgabe 1.3: Zyklische Messdatenverarbeitung in MATLAB®

  1. Schreiben Sie die Funktion (fZeit, fEntfernung)=LeseUltraschall(k) und speichern Sie diese in der Datei LeseUltraschall.m.
  2. Laden Sie darin UltraschallMessung.mat einmalig nur bei ersten Durchlauf und speichern Sie fZeit, fEntfernung als persistente Variablen.
  3. (fZeit, fEntfernung)=LeseUltraschall(k) gibt zwei Werte fZeit(k) und fEntfernung(k) zurück (z. B. [0 30] für 0 s und 30 m).
  4. Schreiben Sie das Rahmenprogramm zeigeZyklischUltraschallMessung.m, welches LeseUltraschall zyklisch aufruft.
  5. Stellen Sie im Rahmenprogramm die Messdaten in einem Diagramm in cm über der Zeit in s dar.
  6. Beschriften Sie den Graphen entsprechend Abb. 1.

Nützliche Befehle: plot, xlabel, ylabel, load, global, persistent, isempty, for, function

Arbeitsergebnisse in SVN: zeigeZyklischUltraschallMessung.m, LeseUltraschall.m


Abb. 2: PAP für die zyklische Messdatenverarbeitung

Aufgabe 1.4: Gleitendes Mittelwertfilter

Ein gleitendes Mittlwertfilter bildet einen Mittelwert über k Messwerte mittels FIFO.

  1. Schreiben Sie die Funktion GleitendesMittelwertFilter.m, welches die Eingangswerte zyklisch filtert. Hier bei wird der Mittelwert über die letzten k Messwerte gebildet.
  2. Testen Sie Ihre Funktion mit Ultraschallmesswerten mit statischen Zielen mit Ihrem Framework zeigeZyklischUltraschallMessung.m und UltraschallMessung.mat Aus den Aufgaben 1.3 und 1.4.
  3. Visualisieren Sie Messwerte und Filterergebnis in einem Plot mit Achsenbeschriftung und Legende.
  4. Testen Sie Ihre Funktion mit Ultraschallmesswerten mit dynamischen Zielen.
  5. Wählen Sie k anhand der Messwerte und diskutieren Sie Ihre Wahl mit Prof. Schneider.

Nützliche Befehle: plot, xlabel, ylabel, legend, persistent, isempty, isnan, function

Arbeitsergebnisse in SVN: GleitendesMittelwertFilter.m, testeGleitendesMittelwertFilter.m

Hinweise:

  • Nutzen Sie ein Array als FIFO.
  • Die Formel für das gleitende Mittelwertfilter lautet: x¯GM(k)=x(1)+x(2)++x(k)k für k Messwerte

Aufgabe 1.5: Rekursives Tiefpassfilter

Ein rekursives Filter kann Messwerte in Echtzeit während der Laufzeit filtern. Nutzen Sie ein Tiefpassfilter, um die Messwerte zu filtern.

  1. Schreiben Sie die Funktion TiefpassFilter.m, welches die Eingangswerte zyklisch filtert. Hierbei wird der Tiefpass berechnet.
  2. Testen Sie Ihre Funktion mit Ultraschallmesswerten mit statischen Zielen mit Ihrem Framework zeigeZyklischUltraschallMessung.m und UltraschallMessung.mat Aus den Aufgaben 1.3 und 1.4.
  3. Visualisieren Sie Messwerte und Filterergebnis in einem Plot mit Achsenbeschriftung und Legende.
  4. Testen Sie Ihre Funktion mit Ultraschallmesswerten mit dynamischen Zielen.
  5. Wählen Sie α anhand der Messwerte und diskutieren Sie Ihre Wahl mit Prof. Schneider.

Arbeitsergebnisse in SVN: TiefpassFilter.m, testeTiefpassFilter.m

Hinweis:

  • Die Formel für das Tiefpassfilter lautet: x¯TP(k)=αx¯(k1)+(1α)x(k) für den aktuellen Messwert x(k).
  • α ist hierbei ein Filterparameter 0<α<1.

Aufgabe 1.6: Filtervergleich

  1. Vergleichen Sie die Ergebnisse des Tiefpasses mit denen des gleitenden Mittelwertfilters.
  2. Zeigen Sie das ungefilterte und die gefilterten Signal in MATLAB® in einem Plot vergleichend an (vgl. Abb.1).
  3. Beschriften Sie die Achsen und nutzen Sie eine Legende.

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?

Arbeitsergebnisse in SVN: testeFilterVergleich.m

Tutorial zum Einstieg

Demos

Literatur

  1. Kim, P.: Kalman-Filter für Einsteiger: mit MATLAB Beispielen. CreateSpace Independent Publishing: 2016. ISBN-13: 978-1502723789
  2. Schneider, U.: Programmierrichtlinie für für die Erstellung von Software in C. Lippstadt: 1. Auflage 2022. PDF-Dokument (212 kb)

FAQ

  • Muss ich die Lösungen selbst programmieren? Ja, nur Eigenleistung wird bewertet.
  • Darf ich die Musterlösung 1:1 kopieren und als meine Leistung ausgeben? Nein, das ist ein Plagiat und wird als Täuschungsversuch gewertet.

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