Arduino: Ultraschallsensor entstören: Unterschied zwischen den Versionen

Aus HSHL Mechatronik
Zur Navigation springen Zur Suche springen
(42 dazwischenliegende Versionen desselben Benutzers 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:Inf1P L12.jpg|thumb|rigth|450px|Abb. 1: Glättung der zufälligen Sensorfehler]]
'''Autor:''' [[Benutzer:Ulrich_Schneider| Prof. Dr.-Ing. Schneider]]<br>
{|
'''Modul:''' Praxismodul I<br>
|-
'''Lehrveranstaltung:''' Mechatronik, Informatikpraktikum 1, 1. Semester, Wintersemester
| '''Autor:''' || [[Benutzer:Ulrich_Schneider| Prof. Dr.-Ing. Schneider]]
|-
| '''Modul:''' || Praxismodul I
|-
| '''Lektion 12:''' || Mechatronik, Informatikpraktikum, 1. Semester, Wintersemester
|}


== Inhalt ==
== Inhalt ==
Zeile 20: Zeile 25:


== Lernzielkontrolle ==
== Lernzielkontrolle ==
# Wie bestimmt man die Größe eines Arrays?
# Welchen Messbereich hat Ihr Ultraschallsensor?
# Wie installiert man in der Arduino IDE eine neuen Bibliothek?
# Welche Auflösung (t, s) hat Ihr Sensor?
# Wie nutzt man die Bibliothek <code>ArduinoSort</code>, um ein Array auszugeben und zu sortieren?
# Welche Empfindlichkeit hat Ihr Sensor?
# Was ist ein Median-Filter? Wie wird der Median berechnet?
# Welche Messunsicherheit hat Ihr Sensor bei den Entfernungen 10 cm, 20 cm, 50 cm, 1 m, 2 m, 3 m und 4 m.
# Was ist in C ein Zeiger und wie wird er verwendet?
# Was ist ein gleitendes Mittelwertfilter? Wie wird es berechnet?
# Was ist ein rekursives Tiefpassfilter? Wie wird es berechnet?
# Wurde der Quelltext durch Header und Kommentare aufgewertet?
# Wurde der Quelltext durch Header und Kommentare aufgewertet?
# Wurden jedes Programm mittels PAP geplant?
# 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 [[Medium:Programmierrichtlinie.pdf|Programmierrichtlinie]] eingehalten?
== Tutorials ==
* [https://docs.arduino.cc/software/ide-v2/tutorials/ide-v2-serial-plotter Arduino: Using the Serial Plotter Tool]
* [[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]




== Demos ==
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Arduino/ArduinoLibOrdner/ArduinoUnoR3/examples/DemoGleitenderMittelwert/DemoGleitenderMittelwert.ino SVN: DemoGleitenderMittelwert.ino]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Arduino/ArduinoLibOrdner/ArduinoUnoR3/examples/DemoTiefpassFilter/DemoTiefpassFilter.ino SVN: DemoTiefpassFilter.ino]
== Vorbereitung ==
== Vorbereitung ==
Bereiten Sie sich anhand der nachfolgenden Aufgaben auf den Praktikumstermin vor.
Bereiten Sie sich anhand der nachfolgenden Aufgaben auf den Praktikumstermin vor.
# Legen Sie ein Array an und bestimmen Sie dessen Größe. Nutzen Sie das [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoSizeOfArray/DemoSizeOfArray.ino DemoSizeOfArray.ino].
# Bereiten Sie Anhand der [[Arduino:_Ultraschallsensor_entstören#Tutorials|Tutorials]] und [[Arduino:_Ultraschallsensor_entstören#Demos|Demos]]  Aufgabe 11.1 vor.
# Installieren Sie die Bibliothek [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Arduino/ArduinoLibOrdner/ArduinoSort-master.zip <code>ArduinoSort-master.zip</code>]. [https://docs.arduino.cc/software/ide-v1/tutorials/installing-libraries Hier] finden Sie die Anleitung.
# Schreiben und testen Sie die Funktion <code>GleitendesMittelwertFilter()</code>.
# Machen Sie sich mit dem <code>DemoSortiereArray</code> vertraut.
# Schreiben und testen Sie die Funktion <code>TiefpasstFilter()</code>.
# Geben Sie mit ein Array im seriellen Monitor aus. Machen Sie sich mit der [https://www.c-howto.de/tutorial/zeiger/ Funktion von Zeigern] in C vertraut.
# Planen Sie alle Programme mit PAP.
# Recherchieren Sie [https://lerneprogrammieren.com/call-by-value-und-call-by-reference-bei-der-parameteruebergabe/ hier] die Bezeichnungen "call by value" und "call by reference".
# Sortieren Sie ein Array mit zufälligen Zahlen. Versuchen Sie das Demo [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoSortiereArray/DemoSortiereArray.ino DemoSortiereArray.ino] nachzuvollziehen.
# Schauen Sie sich die Videos zum Median Filter sowie das dazugehörige [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoMedianFilter/DemoMedianFilter.ino DemoMedianFilter] an.
 
'''Arbeitsergebnisse''' in SVN: <code>Lernzielkontrolle_Termin_06.pdf</code>
<!--
# Installieren Sie die [https://www.arduino.cc/reference/en/libraries/quicksortlib/ QuickSort Bibliothek]. Nutzen Sie die [https://docs.arduino.cc/software/ide-v1/tutorials/installing-libraries Anleitung zur Installation von Bibliotheken].
# Sortieren Sie die 5 Zufallswerte nach Größe z.&thinsp;B. <code>2,2,4,1,2</code> wird zu <code>1,2,2,2,4</code>. Nutzen Sie hierfür die Funktionen aus <code>DemoSortiereArray.ino</code>.
-->
<!--
[[Datei:Batterie-Tester.jpg |thumb|rigth|300px|Abb. 2: Batterie-Tester]]
# Studieren Sie das [https://docs.arduino.cc/software/ide-v2/tutorials/ide-v2-serial-plotter Using the Serial Plotter Toolund nutzen Sie das Demo [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoSharpIR/DemoSharpIR.ino DemoSharpIR.ino], um Daten im Seriellen Plotter auszugeben.
# Recherchieren Sie die Funktion des Sensors anhand von Fachliteratur und des [[Medium:GP2Y0A41SK0F.pdf|Datenblatts]] oder [[Sharp_GP2Y0A41SK0F|Wiki-Artikels]].
# Bauen Sie die Schaltungen zur Auswertung der Sensoren auf.
# Nutzen Sie die Abbildung auf Seite 4 des [[Medium:GP2Y0A41SK0F.pdf|Datenblatts]], um eine Tabelle Spannung/Distanz aufzustellen (vgl. Tab. 1).
# Machen Sie sich mit der Funktion der analogen Eingänge vertraut: [https://www.arduino.cc/reference/en/language/functions/analog-io/analogread/ Arduino Referenz: <code>analogRead()</code> ]. Messen Sie gemäß Abb. 2 die Spannung einen AA Batterie in V. (Hinweis: KEINE 9-V-BLOCK nutzen! Spannung von mehr als 5&thinsp;V können den '''Arduino zerstören'''.)
# Nutzen Sie die [https://www.arduino.cc/reference/en/language/functions/analog-io/analogread/ Arduino Referenz: <code>analogRead()</code> ] und erweitern Sie Ihre Tabelle um die Spalte Digitalwert <code>D1</code> (vgl. Tab. 1).
# Planen Sie die Software via PAP.
# Beantworten Sie die Lernzielkontrollfragen.
# Sichern Sie Ihre Unterlagen in SVN.
<div class="mw-collapsible mw-collapsed">
 
'''Musterlösung:''' für den Batterie-Tester
<source line lang="C" style="font-size:small">const unsigned long BAUD_RATE_u32 = 9600;
const unsigned int AUFLOESUNG_u16 = 1023; //2^10-1
const float ARDUINO_SPANNUNG_f32  = 5.0;


void setup() {
'''Arbeitsergebnisse''' in SVN: <code>PAP, charakterisiereUltraschaschallsensor.ino, USMessung.txt, charakterisiereUltraschallSensor.m, Lernzielkontrolle_Termin_11.pdf, GleitendesMittelwertFilter(), TiefpasstFilter()</code>
  Serial.begin(BAUD_RATE);
}
 
void loop() {
  unsigned int Digitalwert_u16 = analogRead(A0); // Quantisierung der Apannung am Analogen Eingang A0
  Serial.print(ARDUINO_SPANNUNG_f32 * AUFLOESUNG_u16/Digitalwert_u16); // Umrechnung Digitalwert in V
  Serial.println("V");
</source>
</div>
{| class="wikitable"
|+ style = "text-align: left"|Tabelle 1: Kennlinie des IR-Distanzsensors
|-
| '''Spannung <code>U1</code> in V'''|| '''Distanz <code>d</code> in cm'''|| '''Digitalwert <code>D1</code>'''
|-
| 3|| 3,6 || 614
|-
| 2.02|| 6 || 413
|-
| 0.82|| 16 || 168
|-
| ..|| .. || ..
|-
|}
'''Tipps:'''
* Nutzen Sie Werte über den gesamten Wertebereich [0.2&thinsp;V .. 3.2&thinsp;V].
* Sie können die Werte auch durch reale Messungen auf ein statisches Ziel ermitteln.
* Umrechnungsformel: <math>D_1 = U_1\cdot \frac{1023}{5\,V}</math>
<iframe key="panopto" path="/Panopto/Pages/Embed.aspx?id=98958e23-9c36-48cf-b912-af3c00601ce1&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>
-->


== Versuchsdurchführung ==
== Versuchsdurchführung ==
=== Aufgabe 11.1: Charakterisierung des Ultraschallsensors ===
=== Aufgabe 12.1: Charakterisierung des Ultraschallsensors ===
* Schreiben Sie die Funktion <code>float messeUltraschallAbstand()</code>, welche eine Messung mit dem Ultraschallsensor durchführt und die Strecke in cm zurück gibt.
* Schreiben Sie die Funktion <code>float messeUltraschallAbstand()</code>, welche eine Messung mit dem Ultraschallsensor durchführt und die Strecke in cm zurück gibt.
* Zeichnen Sie die den Zeitstempel in s, die Signallaufzeit t in s und berechnete Entfernung s in cm in der Datei <code>Ultraschallmessung.txt</code> auf. Nutzen Sie hierzu <code>Putty</code>.
* Zeichnen Sie die den Zeitstempel in s, die Signallaufzeit t in s und berechnete Entfernung s in cm in der Datei <code>Ultraschallmessung.txt</code> auf. Nutzen Sie hierzu <code>Putty</code>.
Zeile 102: Zeile 60:
* Stellen Sie in MATLAB® Entfernung s über der Laufzeit t dar. Beschriften Sie den Graphen.
* Stellen Sie in MATLAB® Entfernung s über der Laufzeit t dar. Beschriften Sie den Graphen.
* Bestimmen Sie messtechnisch die Empfindlichkeit E, die Auflösung von t und die daraus resultierende Auflösung von s.
* Bestimmen Sie messtechnisch die Empfindlichkeit E, die Auflösung von t und die daraus resultierende Auflösung von s.
* Dokumentieren Sie Ihre Ergebnisse <code>Lernzielkontrolle_Termin_11.pdf</code>
* Dokumentieren Sie Ihre Ergebnisse <code>Lernzielkontrolle_Termin_12.pdf</code>


'''Nützlich MATLAB®-Befehle:''' plot, xlabel, ylabel, legend, disp
'''Nützlich MATLAB®-Befehle:''' plot, xlabel, ylabel, legend, disp


'''Arbeitsergebnisse''' in SVN: <code>charakterisiereUltraschaschallsensor.ino, USMessung.txt, charakterisiereUltraschallSensor.m, Lernzielkontrolle_Termin_11.pdf</code>
'''Arbeitsergebnisse''' in SVN: <code>charakterisiereUltraschaschallsensor.ino, USMessung.txt, charakterisiereUltraschallSensor.m, Lernzielkontrolle_Termin_11.pdf</code>
----
=== Aufgabe 12.2: Statische Messunsicherheit ===
# Lesen Sie die Messwerte des Ultraschall-Sensors auf statische Ziele im gesamten Messbereich aus (10 cm, 20 cm, 50 cm, 1 m, 2 m, 3 m, 4 m). Schreiben Sie hierzu ein Arduino-Programm <code>statische Messunsicherheit.ino</code>. Jeder Messsatz sollte >100 Messwerte umfassen.
# Nutzen Sie das Programm <code>Putty</code>, um die Daten der seriellen Schnittstelle in der ASCII-Datei <code>Ultraschallmessung.txt</code> zu speichern.
# Schreiben Sie einmalig als Header die Bezeichnung der Messwerte Zeit in ms und Strecke in cm in die Textdatei.
# Laden und visualisieren Sie die Messdaten in Ultraschallmessung.txt mit MATLAB®.
# Stellen Sie die Messdaten in einem Diagramm in cm über der Zeit dar.
# Berechnen Sie Mittelwert und Standardabweichung und stellen Sie diese dar,
# Beschriften Sie die Graphen.


=== Aufgabe 11.2: Statische Messunsicherheit ===
'''Nützlich MATLAB®-Befehle:''' <code>mean, std, xline</code>
2. Lesen Sie die Messwerte des Ultraschall-Sensors aus auf statische Ziele im gesamten Messbereich
aus. Schreiben Sie hierzu ein Arduino-Programm messeEntfernung.ino. Messen Sie
zyklisch die Zeit mit dem Befehl millis().
3. Nutzen Sie das Programm Putty, um die Daten der seriellen Schnittstelle in der ASCIIDatei
Ultraschallmessung.txt zu speichern. Eine Anleitung finden Sie unter der URL
https://wiki.hshl.de/wiki/index.php/Einrichtung_von_PuTTY.
4. Schreiben Sie einmalig als Header die Bezeichnung der Messwerte Zeit in ms und Strecke in
cm in die Textdatei.
5. Laden und visualisieren Sie die Messdaten in Ultraschallmessung.txt mit MATLAB®.
6. Stellen Sie die Messdaten in einem Diagramm in cm ¨uber der Zeit dar.
7. Stellen Sie die Messdaten in einem Diagramm in cm ¨uber dem Messbereich dar.
8. Stellen Sie die Empfindlichkeit in einem Diagramm in cm ¨uber dem Messbereich dar.
9. Beschriften Sie die Graphen.


'''Arbeitsergebnisse''' in SVN: <code>statische Messunsicherheit.ino, Ultraschallmessung.txt, zeigeUltraschallMessung.m</code>
----
=== Aufgabe 12.3: Gleitendes Mittelwertfilter ===
Ein gleitendes Mittlwertfilter bildet einen Mittelwert über k Messwerte mittels FIFO.
# Schreiben Sie die Funktion <code>GleitendesMittelwertFilter()</code>, welches die Eingangswerte zyklisch filtert. Hier bei wird der Mittelwert über die letzten k Messwerte gebildet.
# Testen Sie Ihre Funktion mit Ultraschallmesswerten mit statischen Zielen.
# Visualisieren Sie Messwerte und Filterergebnis im seriellen Plotter.
# Testen Sie Ihre Funktion mit Ultraschallmesswerten mit dynamischen Zielen.
# Wählen Sie k anhand der Messwerte und diskutieren Sie Ihre Wahl mit Prof. Schneider.


'''Nützlich MATLAB®-Befehle:''' <code>mean, std, min, max</code>
'''Arbeitsergebnisse''' in SVN: <code>testeGleitendesMittelwert.ino</code>


'''Arbeitsergebnisse''' in SVN: <code>zeigeIRMesswerte.ino</code>
'''Hinweis:'''
* Nutzen Sie das FIFO aus Aufgabe 6.4.
* 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
<div class="mw-collapsible mw-collapsed">


=== Aufgabe 11.3: Rekursives gleitendes Mittelwertfilter ===
Eine Einführung zu rekursiven Filtern finden Sie in folgendem Video.<br>
# Zeichnen Sie die gemessene Entfernung im Verhältnis zu einer Referenz auf. Die Referent kann ein Gliedermaßstab sein. Welchen Messbereich hat Ihr IR-Sensor?
* Gleitendes Mittelwertfilter: 19&thinsp;m 52&thinsp;s
# Zeichnen Sie die gemessenen Entfernungsschritte über dem Messbereich auf. Welche Auflösung hat Ihr Sensor?
* Tiefpassfilter: 29&thinsp;m
# Zeichnen Sie die Auflösung über dem Messbereich auf. Welche Empfindlichkeit hat Ihr Sensor?
<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>


'''Nützliche Befehle''': <code>analogRead(), Serial.println()</code>


'''Arbeitsergebnisse''' in SVN: <code>IR_Sensorcharakterisierung.pdf</code>
'''Demo:''' [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoGleitenderMittelwert SVN: DemoGleitenderMittelwert]
</div>
----
=== Aufgabe 12.4: Rekursives Tiefpassfilter ===
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()</code>, welches die Eingangswerte zyklisch filtert. Hier bei wird der Tiefpass berechnet.
# Testen Sie Ihre Funktion mit Ultraschallmesswerten mit statischen Zielen.
# Visualisieren Sie Messwerte und Filterergebnis im seriellen Plotter.
# Testen Sie Ihre Funktion mit Ultraschallmesswerten mit dynamischen Zielen.
# Wählen Sie <math>\alpha</math> anhand der Messwerte und diskutieren Sie Ihre Wahl mit Prof. Schneider.


=== Aufgabe 11.4: Rekursives Tiefpass-Filter ===
'''Arbeitsergebnisse''' in SVN: <code>testeTiefpassFilter.ino</code>
# Ausreißer lassen sich gut mit einem Median-Filter entfernen. Ein Beispielvideo finden Sie in diesem [[Sharp_GP2Y0A41SK0F#Median-Filter_f%C3%BCr_die_St%C3%B6rungen|Artikel]].
# Schreiben Sie die Funktion <code>int MedianFilter(int Messwert_s16)</code>. Diese Funktion soll über einen statischen 5 Werte Ringspeicher ([https://de.wikipedia.org/wiki/First_In_%E2%80%93_First_Out first in first out, FIFO]) verfügen. Der erste Wert wird gelöscht, die nachfolgenden Werte rutschen einen auf und der neue Messwert (</code>Messwert_s32</code>) nimmt Platz 5 ein.
# Sortieren Sie die 5 Werte nach Größe z.&thinsp;B. <code>2,2,4,1,2</code> wird zu <code>1,2,2,2,4</code>. Nutzen Sie hierfür die Funktionen aus <code>DemoSortiereArray</code>
# Geben Sie als Rückgabewert die Mitte des Arrays <code>SortiertesArray[3]</code> zurück.
# Testen Sie die Funktion Ihrer Funktion mit Zufallszahlen im <code>void loop()</code>


'''Nützliche Befehle''': <code>random(), Serial.println(), analogRead(), LookupTable(), analogRead()</code>
'''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>.
'''Arbeitsergebnisse''' in SVN: <code>testeMedianFilter.ino</code>
* <math>\alpha</math> ist hierbei ein Filterparameter <math>0<\alpha<1</math>.
<div class="mw-collapsible mw-collapsed">
<div class="mw-collapsible mw-collapsed">


'''Lösungsansatz:''' [[Sharp_GP2Y0A41SK0F#Median-Filter_f%C3%BCr_die_St%C3%B6rungen| Median-Filter für die Störung]]
'''Demo:''' [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoTiefpassFilter/DemoTiefpassFilter.ino SVN: DemoTiefpassFilter.ino]
{{#ev:youtube|https://youtu.be/6Nn4JlWXW0g | 720 | | Median - einfach erklärt - Lehrerschmidt |frame}}
 
Ein '''Demo''' für die Implementierung eines Median-Filters finden Sie in [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoMedianFilter/DemoMedianFilter.ino SVN].<br>
 
<iframe key="panopto" path="/Panopto/Pages/Embed.aspx?id=9a191917-b30a-4c06-a62c-af4300a369d4&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>
</div>
</div>
 
----
=== Aufgabe 11.5: Dynamische Messunsicherheit ===
=== Aufgabe 12.5: Dynamische Messunsicherheit ===
# Zeigen Sie das ungefilterte und das Tiefpass-gefilterte Signal in MATLAB® an.
* Zeigen Sie das ungefilterte und das Tiefpass-gefilterte Signal in MATLAB<sup>®</sup> an. Messen Sie auf ein Ziel im gesamten Messbereich (2 cm - 4 m - 2 cm). 
# Wurde das Signalrauschen geglättet?
* Wurde das Signalrauschen geglättet?
# Sichern Sie alle Ergebnisse mit beschreibendem Text (<code>message</code>) in SVN.
* Sichern Sie alle Ergebnisse mit beschreibendem Text (<code>message</code>) in SVN.
* Wurden die Regeln für den Umgang mit SVN eingehalten?
* Wurden die Regeln für den Umgang mit SVN eingehalten?
* Wurde die [[Medium:Programmierrichtlinie.pdf|Programmierrichtlinie]]  eingehalten?
* Wurde die [[Medium:Programmierrichtlinie.pdf|Programmierrichtlinie]]  eingehalten?
Zeile 170: Zeile 134:
'''Arbeitsergebnis''' in SVN: <code>SVN Log</code>, <code>USTiefpassFilter.ino</code>, <code>Ergebnisbewertung.pdf</code>
'''Arbeitsergebnis''' in SVN: <code>SVN Log</code>, <code>USTiefpassFilter.ino</code>, <code>Ergebnisbewertung.pdf</code>


== Bewertung ==
{| class="wikitable"
|-
| '''Aufgabe'''|| '''Punkte'''
|-
| 11.1|| 2
|-
| 11.2|| 2
|-
| 11.3|| 2
|-
| 11.4|| 2
|-
| 11.5|| 2
|-
|}


== Tutorials ==
* [https://docs.arduino.cc/software/ide-v2/tutorials/ide-v2-serial-plotter Arduino: Using the Serial Plotter Tool]
* [[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]


== Demos ==
<!--
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoSharpIR/DemoSharpIR.ino DemoSharpIR.ino]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoSharpIR/DemoSharpIR.ino DemoSharpIR.ino]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoLookupTable/DemoLookupTable.ino DemoLookupTable.ino]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoLookupTable/DemoLookupTable.ino DemoLookupTable.ino]
Zeile 200: Zeile 144:
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoSortiereArray/DemoSortiereArray.ino DemoSortiereArray.ino]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoSortiereArray/DemoSortiereArray.ino DemoSortiereArray.ino]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoMedianFilter/DemoMedianFilter.ino DemoMedianFilter]
* [https://svn.hshl.de/svn/Informatikpraktikum_1/trunk/Demos/Arduino/DemoMedianFilter/DemoMedianFilter.ino DemoMedianFilter]
-->


== Literatur ==
== Literatur ==
Zeile 206: Zeile 151:
# Snieders, R.: ''ARDUINO lernen''. Nordhorn: 8. Auflage 2022. URL: [https://funduino.de/vorwort https://funduino.de/vorwort]
# 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)]]
# Sharp: ''GP2Y0A41SK0F''. URL: [https://de.farnell.com/sharp/gp2y0a41sk0f/distanzmesssensor/dp/1618431]. [[Medium:GP2Y0A41SK0F.pdf|Datenblatt (858&thinsp;kb)]]
 
 


----
----
→ zurück zum Hauptartikel: [[Arduino_Praxiseinstieg|Arduino Praxiseinstieg]]
→ Termine [[Einführungsveranstaltung Informatikpraktikum 1|0]] [[Einarbeitung_in_die_Versionsverwaltung_SVN|1]] [[Einstieg_in_die_Welt_des_Arduino|2]]  [[Arduino: Taster auswerten und LEDs ansteuern|3]] [[Arduino:_Sensoren_einlesen|4]]  [[Arduino:_Infrarotsensor_einlesen|5]] [[Arduino:_Infrarotsensor_entstören|6]] [[Arduino:_Programmier-Challenge_I_WS_23/24|7]] [[Arduino:_IR-Theremin|8]] [[Arduino:_Aktoren|9]] [[Arduino:_LCD_Display_mit_I2C_Schnittstelle|10]] [[Arduino:_Ultraschall_Entfernungsmessung|11]] [[Arduino:_Ultraschallsensor_entstören|12]] [[Arduino:_Temperaturmessung_mit_NTC_und_PTC|13]] [[Arduino:_Programmier-Challenge_II_WS_23/24|14]]<br>
→ zurück zum Hauptartikel: [[Arduino_Praxiseinstieg_WS_23/24|Arduino Praxiseinstieg]]

Version vom 11. Dezember 2023, 12:27 Uhr

Abb. 1: Glättung der zufälligen Sensorfehler
Autor: Prof. Dr.-Ing. Schneider
Modul: Praxismodul I
Lektion 12: Mechatronik, Informatikpraktikum, 1. Semester, Wintersemester

Inhalt

  • Statische und dynamische Messung
  • Kennlinienuntersuchung und Filterung
  • Programmierung und Anwendung eines gleitenden Mittelwertfilters
  • Programmierung und Anwendung eines gleitenden Tiefpassfilters

Lernziele

Nach Durchführung dieser Lektion

  • können Sie die zufällige Sensorfehler erkennen und behandeln.
  • können die Messwerte vergleichend anzeigen und bewerten.
  • können Sie die Messwerte charakterisieren.
  • können Sie ein gleitendes Mittelwertfilters erläutern und anwenden.
  • können Sie ein Tiefpassfilter erläutern und anwenden.

Lernzielkontrolle

  1. Welchen Messbereich hat Ihr Ultraschallsensor?
  2. Welche Auflösung (t, s) hat Ihr Sensor?
  3. Welche Empfindlichkeit hat Ihr Sensor?
  4. Welche Messunsicherheit hat Ihr Sensor bei den Entfernungen 10 cm, 20 cm, 50 cm, 1 m, 2 m, 3 m und 4 m.
  5. Was ist ein gleitendes Mittelwertfilter? Wie wird es berechnet?
  6. Was ist ein rekursives Tiefpassfilter? Wie wird es berechnet?
  7. Wurde der Quelltext durch Header und Kommentare aufgewertet?
  8. Wurden jedes Programm mittels PAP geplant?
  9. Wurde auf magic numbers verzichtet?
  10. Wurde die Programmierrichtlinie eingehalten?

Tutorials


Demos

Vorbereitung

Bereiten Sie sich anhand der nachfolgenden Aufgaben auf den Praktikumstermin vor.

  1. Bereiten Sie Anhand der Tutorials und Demos Aufgabe 11.1 vor.
  2. Schreiben und testen Sie die Funktion GleitendesMittelwertFilter().
  3. Schreiben und testen Sie die Funktion TiefpasstFilter().
  4. Planen Sie alle Programme mit PAP.

Arbeitsergebnisse in SVN: PAP, charakterisiereUltraschaschallsensor.ino, USMessung.txt, charakterisiereUltraschallSensor.m, Lernzielkontrolle_Termin_11.pdf, GleitendesMittelwertFilter(), TiefpasstFilter()

Versuchsdurchführung

Aufgabe 12.1: Charakterisierung des Ultraschallsensors

  • Schreiben Sie die Funktion float messeUltraschallAbstand(), welche eine Messung mit dem Ultraschallsensor durchführt und die Strecke in cm zurück gibt.
  • Zeichnen Sie die den Zeitstempel in s, die Signallaufzeit t in s und berechnete Entfernung s in cm in der Datei Ultraschallmessung.txt auf. Nutzen Sie hierzu Putty.
  • Laden und visualisieren Sie die Messdaten in Ultraschallmessung.txt mit MATLAB®.
  • Stellen Sie in MATLAB® Entfernung s über der Laufzeit t dar. Beschriften Sie den Graphen.
  • Bestimmen Sie messtechnisch die Empfindlichkeit E, die Auflösung von t und die daraus resultierende Auflösung von s.
  • Dokumentieren Sie Ihre Ergebnisse Lernzielkontrolle_Termin_12.pdf

Nützlich MATLAB®-Befehle: plot, xlabel, ylabel, legend, disp

Arbeitsergebnisse in SVN: charakterisiereUltraschaschallsensor.ino, USMessung.txt, charakterisiereUltraschallSensor.m, Lernzielkontrolle_Termin_11.pdf


Aufgabe 12.2: Statische Messunsicherheit

  1. Lesen Sie die Messwerte des Ultraschall-Sensors auf statische Ziele im gesamten Messbereich aus (10 cm, 20 cm, 50 cm, 1 m, 2 m, 3 m, 4 m). Schreiben Sie hierzu ein Arduino-Programm statische Messunsicherheit.ino. Jeder Messsatz sollte >100 Messwerte umfassen.
  2. Nutzen Sie das Programm Putty, um die Daten der seriellen Schnittstelle in der ASCII-Datei Ultraschallmessung.txt zu speichern.
  3. Schreiben Sie einmalig als Header die Bezeichnung der Messwerte Zeit in ms und Strecke in cm in die Textdatei.
  4. Laden und visualisieren Sie die Messdaten in Ultraschallmessung.txt mit MATLAB®.
  5. Stellen Sie die Messdaten in einem Diagramm in cm über der Zeit dar.
  6. Berechnen Sie Mittelwert und Standardabweichung und stellen Sie diese dar,
  7. Beschriften Sie die Graphen.

Nützlich MATLAB®-Befehle: mean, std, xline

Arbeitsergebnisse in SVN: statische Messunsicherheit.ino, Ultraschallmessung.txt, zeigeUltraschallMessung.m


Aufgabe 12.3: Gleitendes Mittelwertfilter

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

  1. Schreiben Sie die Funktion GleitendesMittelwertFilter(), 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.
  3. Visualisieren Sie Messwerte und Filterergebnis im seriellen Plotter.
  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.

Arbeitsergebnisse in SVN: testeGleitendesMittelwert.ino

Hinweis:

  • Nutzen Sie das FIFO aus Aufgabe 6.4.
  • Die Formel für das gleitende Mittelwertfilter lautet: für k Messwerte

Eine Einführung zu rekursiven Filtern finden Sie in folgendem Video.

  • Gleitendes Mittelwertfilter: 19 m 52 s
  • Tiefpassfilter: 29 m


Demo: SVN: DemoGleitenderMittelwert


Aufgabe 12.4: 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(), welches die Eingangswerte zyklisch filtert. Hier bei wird der Tiefpass berechnet.
  2. Testen Sie Ihre Funktion mit Ultraschallmesswerten mit statischen Zielen.
  3. Visualisieren Sie Messwerte und Filterergebnis im seriellen Plotter.
  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: testeTiefpassFilter.ino

Hinweis:

  • Die Formel für das Tiefpassfilter lautet: für den aktuellen Messwert .
  • ist hierbei ein Filterparameter .

Aufgabe 12.5: Dynamische Messunsicherheit

  • Zeigen Sie das ungefilterte und das Tiefpass-gefilterte Signal in MATLAB® an. Messen Sie auf ein Ziel im gesamten Messbereich (2 cm - 4 m - 2 cm). 
  • Wurde das Signalrauschen geglättet?
  • Sichern Sie alle Ergebnisse mit beschreibendem Text (message) in SVN.
  • Wurden die Regeln für den Umgang mit SVN eingehalten?
  • Wurde die Programmierrichtlinie eingehalten?
  • Wurde nachhaltig dokumentiert?
  • Haben die Programme einen Header?
  • Wurden der Quelltext umfangreich kommentiert?
  • Wurden die PAPs erstellt und abgelegt? Passen die PAPs 100% zum Programm?

Arbeitsergebnis in SVN: SVN Log, USTiefpassFilter.ino, Ergebnisbewertung.pdf



Literatur

  1. Brühlmann, T.: Arduino Praxiseinstieg. Heidelberg: mitp, 4. Auflage 2019. ISBN 978-3-7475-0056-9. URL: HSHL-Bib, O'Reilly-URL
  2. Brühlmann, T.: Sensoren im Einsatz mit Arduino. Frechen: mitp Verlag, 1. Auflage 2017. ISBN: 9783958451520. URL: HSHL-Bib, O'Reilly
  3. Snieders, R.: ARDUINO lernen. Nordhorn: 8. Auflage 2022. URL: https://funduino.de/vorwort
  4. Schneider, U.: Programmierrichtlinie für für die Erstellung von Software in C. Lippstadt: 1. Auflage 2022. PDF-Dokument (212 kb)



→ Termine 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
→ zurück zum Hauptartikel: Arduino Praxiseinstieg