AlphaBot: Messdatenverarbeitung mit MATLAB: Unterschied zwischen den Versionen

Aus HSHL Mechatronik
Zur Navigation springen Zur Suche springen
Keine Bearbeitungszusammenfassung
Keine Bearbeitungszusammenfassung
 
(39 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
[[Kategorie:Arduino]]
[[Kategorie:Arduino]]
[[Datei:Lernset - Einsteiger Kit für Arduino.jpg|thumb|rigth|450px|Abb. 1: Lernset - Einsteiger Kit für Arduino]]
[[Datei:TesteFilterVergleich.jpg|thumb|rigth|450px|Abb. 1: Vergleich rauschunterdrückender Filter]]
'''Autor:''' [[Benutzer:Ulrich_Schneider| Prof. Dr.-Ing. Schneider]]<br>
{|class="wikitable"
'''Modul:''' Praxismodul I<br>
|-
'''Lehrveranstaltung:''' Mechatronik, Informatik Praktikum 2, 2. Semester<br>
| '''Autor:''' || [[Benutzer:Ulrich_Schneider| Prof. Dr.-Ing. Schneider]]
'''Aufgabenstatus:''' In Bearbeitung
|-
| '''Modul:''' || Praxismodul II
|-
| '''Lehrveranstaltung:''' || Mechatronik, Informatik Praktikum 2, 2. Semester
|}


== Inhalt ==
== Inhalt ==
* Einarbeitung in MATLAB<sup>®</sup>
* Einarbeitung in MATLAB<sup>®</sup>
* Statische und dynamische Messung mit dem Ultraschallsensor
* Programmierung und Anwendung eines gleitenden Mittelwertfilters
* 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==
== Lernziele==
Nach Durchführung dieser Lektion
Nach Durchführung dieser Lektion
* können Sie Debug-Daten speichern und via MATLAB® visualisieren.
* können Sie reale Messwerte speichern und via MATLAB<sup>®</sup> zyklisch visualisieren.
* können Sie direkt MATLAB® als seriellen Monitor nutzen.
* haben Sie ein gleitendes Mittelwertfilter programmiert.
* können Sie ein Signal differenzieren und kennen die Gefahren dieser Berechnung.
* haben Sie ein rekursives rekursiven Tiefpassfilter programmiert.
* kennen Sie die Funktion und Kennwerte des Ultraschall-Sensors.
* können Sie die Filter parametrieren.
* können Sie Entfernungen mit dem Ultraschall-Sensor messen.
* haben Sie die Filter zyklisch auf Ultraschallmesswerte angewendet und das Filterverhalten analysiert.
* können Sie Software mit einem PAP planen.
* können Sie eine Funktion in MATLAB<sup>®</sup> programmieren und aufrufen.
<!--
 
== Lernzielkontrolle ==
== Lernzielkontrolle ==
# Welchen Messbereich hat Ihr Ultraschallsensor?
# Wozu werden rekursive Filter benötigt?
# Welche Auflösung (t, s) hat Ihr Sensor?
# Nennen Sie die Formel für ein gl. Mittelwertfilter.
# Welche Empfindlichkeit hat Ihr Sensor?
# Welche Parameter hat ein gl. Mittelwertfilter? Was bedeuten die Parameter?
# Welche Messunsicherheit hat Ihr Sensor bei den Entfernungen 10 cm, 20 cm, 50 cm, 1 m, 2 m, 3 m und 4 m.
# Nennen Sie die rekursive Formel für ein Tiefpassfilter.
# Was ist ein gleitendes Mittelwertfilter? Wie wird es berechnet?
# Welche Parameter hat ein Tiefpassfilter? Was bedeuten die Parameter?
# Was ist ein rekursives Tiefpassfilter? Wie wird es berechnet?
# Vergleichen Sie die zwei rekursiven Filter. Nennen Sie Vor- und Nachteile.
# Wurde der Quelltext durch Header und Kommentare aufgewertet?
# Wurde der Quelltext durch Header und Kommentare aufgewertet?
# Wurden jedes Programm mittels PAP geplant?
# Wurde auf <code>magic numbers</code> verzichtet?
# Wurde auf <code>magic numbers</code> verzichtet?
# Wurde die [[Medium:Programmierrichtlinie.pdf|Programmierrichtlinie]] eingehalten?
# Wurde die Programmierrichtlinie eingehalten?
-->
 
== Vorbereitung ==
== Vorbereitung ==
Fürhren Sie als Vorbereitung den [https://www.mathworks.com/learn/tutorials/matlab-onramp.html MATLAB<sup>®</sup> Onramp Kurs] durch.
Führen Sie als Vorbereitung den [https://www.mathworks.com/learn/tutorials/matlab-onramp.html MATLAB<sup>®</sup> Onramp Kurs] durch.




'''Arbeitsergebnis''' in SVN: Kurszertifikat<code>
'''Arbeitsergebnis''' in SVN: MATLAB<sup>®</sup> Kurszertifikat


== Versuchsdurchführung ==
== Versuchsdurchführung ==
=== Aufgabe 2.1: Gleitendes Mittelwertfilter ===
=== Aufgabe 1.1: Positionserfassung mit Ultraschall ===
# Lesen Sie die Messwerte des Ultraschall-Sensors auf ein statisches Ziele aus. Schreiben Sie hierzu ein Arduino-Programm <code>messeEntfernung.ino</code>. Messen Sie zyklisch die Zeit mit dem Befehl <code>millis()</code>.
# Messen Sie 10&thinsp;s auf ein statisches Ziel (z.&thinsp;B. einen Karton) in 30&thinsp;cm Entfernung.
# Nutzen Sie das Programm Putty, um die Daten der seriellen Schnittstelle in der ASCII-Datei <code>UltraschallMessung.txt</code> zu speichern. Eine Anleitung finden Sie unter der URL [[Einrichtung von PuTTY]].
# Schreiben Sie einmalig als Header die Bezeichnung der Messwerte Zeit in ms und Strecke in cm in die Textdatei.
 
'''Nützliche Befehle''': <code>pinMode(), digitalWrite(), pulseIn(), delayMicroseconds(), millis()</code>
 
'''Arbeitsergebnisse''' in SVN: <code>UltraschallMessung.txt, messeEntfernung.ino</code>
 
<div class="mw-collapsible mw-collapsed">
'''Tipp:''' Nutzen Sie das Demoprogramm [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoUltraschallHCSR04 DemoUltraschallHCSR04] als Programmierstart.
</div>
----
=== 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.
# Laden und visualisieren Sie die Messdaten in <code>Ultraschallmessung.txt</code> mit MATLAB<sup>®</sup>.
# Sichern Sie die Achsenbeschriftung im 2x1 Cell-Array <code>stTitel</code>.
# Stellen Sie die Messdaten in einem Diagramm in cm über der Zeit in s dar.
# Beschriften Sie die Graphen.
# Speichern Sie die Messung in der Datei <code>UltraschallMessung.mat</code>.
 
'''Nützliche Befehle''': <code>plot, xlabel, ylabel, save</code>
 
'''Arbeitsergebnisse''' in SVN: <code>zeigeUltraschallMessung.m, UltraschallMessung.mat</code>
 
<div class="mw-collapsible mw-collapsed">
Gegeben (vgl. Abb. 1):
* <code>fZeit</code>: 1x100 Messwertarray der Zeit in s
* <code>fMesswerte</code>: 1x100 Messwertarray der Ultraschallwerte in cm
 
<code>save('UltraschallMessung.mat','fZeit',fMesswerte','stTitel')</code>
</div>
----
=== 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>.
# Laden Sie darin <code>UltraschallMessung.mat</code> einmalig nur bei ersten Durchlauf und speichern Sie <code>fZeit, fEntfernung</code> als persistente Variablen.
# <code>(fZeit, fEntfernung)=LeseUltraschall(k)</code> gibt zwei Werte fZeit(k) und fEntfernung(k) zurück (z.&thinsp;B. [0 30] für 0&thinsp;s und 30&thinsp;m).
# Schreiben Sie das Rahmenprogramm <code>zeigeZyklischUltraschallMessung.m</code>, welches <code>LeseUltraschall</code> zyklisch aufruft.
# Stellen Sie im Rahmenprogramm die Messdaten in einem Diagramm in cm über der Zeit in s dar.
# Beschriften Sie den Graphen entsprechend Abb. 1.
 
'''Nützliche Befehle''': <code>plot, xlabel, ylabel, load, global, persistent, isempty, for, function</code>
 
'''Arbeitsergebnisse''' in SVN: <code>zeigeZyklischUltraschallMessung.m, LeseUltraschall.m</code>
 
 
<div class="mw-collapsible mw-collapsed">
[[Datei:PAP_Aufgabe_1_4.jpg|thumb|left|450px|Abb. 2: PAP für die zyklische Messdatenverarbeitung]]
</div>
----
=== 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.
# Schreiben Sie die Funktion <code>GleitendesMittelwertFilter.m</code>, welches die Eingangswerte zyklisch filtert. Hier bei wird der Mittelwert über die letzten k Messwerte gebildet.
# Schreiben Sie die Funktion <code>GleitendesMittelwertFilter.m</code>, welches die Eingangswerte zyklisch filtert. Hier bei wird der Mittelwert über die letzten k Messwerte gebildet.
Zeile 48: Zeile 104:
# Wählen Sie k anhand der Messwerte und diskutieren Sie Ihre Wahl mit Prof. Schneider.
# Wählen Sie k anhand der Messwerte und diskutieren Sie Ihre Wahl mit Prof. Schneider.


'''Arbeitsergebnisse''' in SVN: <code>testeGleitendesMittelwert.m</code>
'''Nützliche Befehle''': <code>plot, xlabel, ylabel, legend, persistent, isempty, isnan, function</code>
 
'''Arbeitsergebnisse''' in SVN: <code>GleitendesMittelwertFilter.m, testeGleitendesMittelwertFilter.m</code>


'''Hinweis:'''
'''Hinweise:'''
* Nutzen Sie das FIFO aus Aufgabe 6.4.
* Nutzen Sie ein Array als FIFO.
* Die Formel für das gleitende Mittelwertfilter lautet: <math>\bar{x}(k)=\frac{x(1)+x(2)+\ldots+x(k)}{k}</math> für k Messwerte
* Die Formel für das gleitende Mittelwertfilter lautet: <math>\bar{x}_{GM}(k)=\frac{x(1)+x(2)+\ldots+x(k)}{k}</math> für k Messwerte
<div class="mw-collapsible mw-collapsed">


Eine Einführung zu rekursiven Filtern finden Sie in folgendem Video.<br>
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
| <strong>Einführung zu rekursiven Filtern&thinsp;</strong>
|-
| Eine Einführung zu rekursiven Filtern finden Sie in folgendem Video.<br>
* Gleitendes Mittelwertfilter: 19&thinsp;m 52&thinsp;s
* Gleitendes Mittelwertfilter: 19&thinsp;m 52&thinsp;s
* Tiefpassfilter: 29&thinsp;m
* Tiefpassfilter: 29&thinsp;m
[[Datei:RekursiveFilter.mp4|start=0|800px|Eine Einführung zu rekursiven Filtern]]
<!--
<iframe key="panopto" path="/Panopto/Pages/Viewer.aspx?id=fce4a806-dcbf-4e92-b10d-ac69013d7cb1&autoplay=false&offerviewer=true&showtitle=true&showbrand=true&captions=false&interactivity=all" height="405" width="720" style="border: 1px solid #464646;" allowfullscreen allow="autoplay"></iframe>
<iframe key="panopto" path="/Panopto/Pages/Viewer.aspx?id=fce4a806-dcbf-4e92-b10d-ac69013d7cb1&autoplay=false&offerviewer=true&showtitle=true&showbrand=true&captions=false&interactivity=all" height="405" width="720" style="border: 1px solid #464646;" allowfullscreen allow="autoplay"></iframe>
-->
|}


 
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
'''Demo:''' [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoGleitenderMittelwert SVN: DemoGleitenderMittelwert]  
| <strong>Demo&thinsp;</strong>
</div>
|-
 
|
=== Aufgabe 2.2: Rekursives Tiefpassfilter ===
[https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoGleitenderMittelwert SVN: DemoGleitenderMittelwert] <br>
Eine ausführliche Beschreibung mit Musterlösung finden Sie in [1, S.&thinsp;11&thinsp;ff.].
|}
----
=== 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.
# Schreiben Sie die Funktion <code>TiefpassFilter.m</code>, welches die Eingangswerte zyklisch filtert. Hierbei wird der Tiefpass berechnet.
# Schreiben Sie die Funktion <code>TiefpassFilter.m</code>, welches die Eingangswerte zyklisch filtert. Hierbei wird der Tiefpass berechnet.
Zeile 72: Zeile 140:
# Wählen Sie <math>\alpha</math> anhand der Messwerte und diskutieren Sie Ihre Wahl mit Prof. Schneider.
# Wählen Sie <math>\alpha</math> anhand der Messwerte und diskutieren Sie Ihre Wahl mit Prof. Schneider.


'''Arbeitsergebnisse''' in SVN: <code>testeTiefpassFilter.m</code>
'''Arbeitsergebnisse''' in SVN: <code>TiefpassFilter.m, testeTiefpassFilter.m</code>


'''Hinweis:'''
'''Hinweis:'''
* Die Formel für das Tiefpassfilter lautet: <math>\bar{x}(k)=\alpha \cdot \bar{x}(k-1)+ (1-\alpha)\cdot x(k)</math> für den aktuellen Messwert <math>x(k)</math>.
* Die Formel für das Tiefpassfilter lautet: <math>\bar{x}_{TP}(k)=\alpha \cdot \bar{x}(k-1)+ (1-\alpha)\cdot x(k)</math> für den aktuellen Messwert <math>x(k)</math>.
* <math>\alpha</math> ist hierbei ein Filterparameter <math>0<\alpha<1</math>.
* <math>\alpha</math> ist hierbei ein Filterparameter <math>0<\alpha<1</math>.
<div class="mw-collapsible mw-collapsed">
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
 
| <strong>Demo&thinsp;</strong>
'''Demo:''' [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoTiefpassFilter/DemoTiefpassFilter.ino SVN: DemoTiefpassFilter.ino]
|-
</div>
| [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoTiefpassFilter/DemoTiefpassFilter.ino SVN: DemoTiefpassFilter.ino]<br>
 
Eine ausführliche Beschreibung mit Musterlösung finden Sie in [1, S.&thinsp;11&thinsp;ff.19].
=== Aufgabe 2.3: Filtervergleich ===
|}
# Vergleichen Sie die Ergebnisse dies Tiefpasses mit denen des gleitenden Mittelwertfilters.
----
# Zeigen Sie das ungefilterte und die gefilterten Signal in MATLAB<sup>®</sup> in einem Plot vergleichend an.  
=== Aufgabe 1.6: Filtervergleich ===
# Vergleichen Sie die Ergebnisse des Tiefpasses mit denen des gleitenden Mittelwertfilters.
# Zeigen Sie das ungefilterte und die gefilterten Signal in MATLAB<sup>®</sup> in einem Plot vergleichend an (vgl. Abb.1).  
# Beschriften Sie die Achsen und nutzen Sie eine Legende.
# Beschriften Sie die Achsen und nutzen Sie eine Legende.
# Beantworten Sie die nachfolgenden Fragen
## Wurde das Signalrauschen geglättet?
## Ist das gefilterte Signal verzögert?
## Welchen Einfluss haben die Filterparameter?
## Wie verhalten sich die gefilterten Signal bei Ausreißern?


=== Aufgabe 2.4: Nachhaltige Doku ===
'''Lernzielkontrollfragen:'''
Sichern Sie alle Ergebnisse mit beschreibendem Text (<code>message</code>) in SVN.
# Wurde das Signalrauschen geglättet?
* Halten Sie die Regeln für den [[Software_Versionsverwaltung_mit_SVN|Umgang mit SVN]] ein.
# Ist das gefilterte Signal verzögert?
* Halten Sie die [[Medium:Programmierrichtlinie.pdf|Programmierrichtlinie für C]] und die [[Medium:Programmierrichtlinien_für_Matlab.pdf|Programmierrichtlinien für MATLAB<sup>®</sup>]] ein.
# Welchen Einfluss haben die Filterparameter?
* Versehen Sie jedes Programm mit einem Header ([[Header Beispiel für MATLAB]], [[Header Beispiel für C]]).
# Wie verhalten sich die gefilterten Signal bei Ausreißern?
* Kommentiere Sie den Quelltext umfangreich.


'''Arbeitsergebnis''' in SVN: <code>SVN Log</code>
'''Arbeitsergebnisse''' in SVN: <code>testeFilterVergleich.m</code>
{| role="presentation" class="wikitable mw-collapsible mw-collapsed"
| <strong>Musterlösung&thinsp;</strong>
|-
| Eine ausführliche Beschreibung mit Musterlösung finden Sie in [1, S.&thinsp;27&thinsp;ff.].
|}


== Tutorials ==
== Tutorial zum Einstieg ==
* [[Software_Plagiat| Was ist ein Plagiat?]]
* [[Einarbeitung_in_die_Versionsverwaltung_SVN|Einarbeitung in die Versionsverwaltung SVN]]
* [[Software Planung| Software Planung mit PAP]]
* [[Arduino|Einstieg in die Welt des Arduino]]
* [[Einführung_in_MATLAB|Einführung in MATLAB<sup>®</sup>]]
* [[MATLAB-Befehle|MATLAB<sup>®</sup> Befehlsübersicht]]
* [[Einrichtung von PuTTY]]
* [[Einrichtung von PuTTY]]
* [[Ultraschallsensor_HC-SR04| HSHL-Wiki: Ultraschallsensor HC-SR04]]
* [[Ultraschallsensor_HC-SR04| HSHL-Wiki: Ultraschallsensor HC-SR04]]
* [https://funduino.de/nr-10-entfernung-messen Funduino: Entfernungen mit einem HC-SR04 Ultraschallsensor am Arduino messen]
* [https://funduino.de/nr-10-entfernung-messen Funduino: Entfernungen mit einem HC-SR04 Ultraschallsensor am Arduino messen]
* [https://www.arduino.cc/reference/de/ Arduino Befehlsübersicht]
* [[Medium:Programmierrichtlinie.pdf|Programmierrichtlinie für C]]
* [[Medium:Programmierrichtlinien_für_Matlab.pdf|Programmierrichtlinien für MATLAB<sup>®</sup>]]


== Demos ==
== Demos ==
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Arduino/ArduinoLibOrdner/ArduinoUnoR3/examples/DemoUltraschallHCSR04 SVN: <code>DemoUltraschallHCSR04</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Arduino/ArduinoLibOrdner/ArduinoUnoR3/examples/DemoDebugTxt2MATLAB/ SVN: <code>DemoDebugTxt2MATLAB</code>]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoUltraschallHCSR04 SVN: DemoUltraschallHCSR04]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoUltraschallHCSR04 SVN: DemoUltraschallHCSR04]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoDebug2MATLAB SVN: DemoDebug2MATLAB]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoDebug2MATLAB SVN: DemoDebug2MATLAB]
Zeile 114: Zeile 193:


== Literatur ==
== Literatur ==
#  
# Kim, P.: Kalman-Filter für Einsteiger: mit MATLAB Beispielen. CreateSpace Independent Publishing: 2016. ISBN-13: 978-1502723789
# Brühlmann, T.: ''Arduino Praxiseinstieg''. Heidelberg: mitp, 4. Auflage 2019. ISBN 978-3-7475-0056-9. URL: [https://hshl.bsz-bw.de/cgi-bin/koha/opac-detail.pl?biblionumber=125816&query_desc=kw%2Cwrdl%3A%20arduino HSHL-Bib], [https://learning.oreilly.com/library/view/arduino-praxiseinstieg/9783747500569/ O'Reilly-URL]
# Brühlmann, T.: ''Sensoren im Einsatz mit Arduino''. Frechen: mitp Verlag, 1. Auflage 2017. ISBN: 9783958451520. URL: [https://hshl.bsz-bw.de/cgi-bin/koha/opac-detail.pl?biblionumber=130719&query_desc=kw%2Cwrdl%3A%20Br%C3%BChlmann HSHL-Bib], [https://learning.oreilly.com/library/view/sensoren-im-einsatz/9783958451520/?ar O'Reilly]
# Snieders, R.: ''ARDUINO lernen''. Nordhorn: 8. Auflage 2022. URL: [https://funduino.de/vorwort https://funduino.de/vorwort]
# Schneider, U.: ''Programmierrichtlinie für für die Erstellung von Software in C.'' Lippstadt: 1. Auflage 2022. [[Medium:Programmierrichtlinie.pdf|PDF-Dokument (212&thinsp;kb)]]
# Schneider, U.: ''Programmierrichtlinie für für die Erstellung von Software in C.'' Lippstadt: 1. Auflage 2022. [[Medium:Programmierrichtlinie.pdf|PDF-Dokument (212&thinsp;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 [[Software_Plagiat|Plagiat]] und wird als Täuschungsversuch gewertet.'''


----
----
→ zurück zum Hauptartikel: [[AlphaBot_SoSe23|Informatik Praktikum 2]]
→ Termine [[Einführungsveranstaltung_Informatikpraktikum_2_im_SoSe_2025|1]] [[AlphaBot:_Messdatenverarbeitung_mit_MATLAB|2]] [[AlphaBot:_MATLAB_als_serieller_Monitor|3]] [[AlphaBot: Servo ansteuern|4]] [[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 SoSe25|11]]<br>
→ zurück zum Hauptartikel: [[AlphaBot_SoSe25|Informatik Praktikum 2]]

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