Barometer mit Matlab/Simulink: Unterschied zwischen den Versionen
Zeile 96: | Zeile 96: | ||
[[Datei:Arduino Ansatz Barometer.jpeg|500px|thumb|left|Arduino Ansatz am Steckbrett]] | [[Datei:Arduino Ansatz Barometer.jpeg|500px|thumb|left|Arduino Ansatz am Steckbrett]] | ||
[[Datei:Theoretische Schaltung.jpeg| | [[Datei:Theoretische Schaltung.jpeg|600px|thumb|right|Anschluss des Barometers an den Arduino]] | ||
Version vom 4. Juli 2018, 20:30 Uhr
Sensor: NXT Barometric Sensor (NBR1036)
Autor: Tobias Wemmer
Einleitung
Dieser Wiki-Artikel beschreibt die Semesterarbeit von Tobias Wemmer im Modul SigSys SoSe2018. In diesem Modul sollte jeder Teilnehmer die Funktionsweise eines jeweils anderen Sensors verstehen und diesen via Matlab/Simulik auslesen und kalibrieren. Gegeben waren neben dem eingentlichen Sensor noch die Tools Matlab und Simulink. Die Funktionsweise des Sensors sowie Datenblätter musste, falls vorhanden bei der Recherche gesichtet werden. Letzteres war für diesen Sensor nicht mehr zugänglich. Es gab jedoch ein Beiblatt zum Sensor, welches sich in erster Line mit dem Auslesen des Sensors via NXT Stein beschäftigte. Daher musste experimentell an der Lösung gearbeitet werden.
Aufgabenstellung
- Lesen Sie den Sensor mit MATLAB/Simulink aus (MATLAB/Simulink Toolbox).
- Beschreiben, untersuchen und verstehen Sie Ihre Signalverarbeitungskette.
NXT Baromitric Sensor (NBR1036)
Vorstellung des Sensors
Bei dem Sensor handelt es sich um den „NXT Baromitric Sensor (NBR1036)". Wie der Name schon sagt, ist dieser Sensor ein Barometer, jedoch kann der Sensor neben dem Druck auch die Temperatur messen. Dadurch eignet sich der Sensor gut als Komponente einer Wetterstation.[1]
Wie Abbildung 1 zu entnehmen ist, lässt sich der Sensor auf den ersten Blick nicht von anderen NXT Sensoren unterscheiden, da er das Standard NXT-Gehäuse besitzt. Zur Unterscheidung der einzelnen Sensoren ist eine Beschriftung auf der Unterseite des Gehäuses vorhanden.
Messgenauigkeit
Der Sensor misst Analoge Werte (Druck und Temperatur). Die Messwerte werden mittels Analog-Digital-Umwandler (ADU) digitalisiert und somit für die Digitale Auswertung via PC verarbeitbar gemacht. Diese Digitalisierung führt zu Messbereichen bzw. Schritten statt unendlichen einzelnen Werten. Der Grund dafür ist ein endlicher Speicher, welcher nicht in der Lage ist unendliche Werte speichern. Daraus resultiert eine Messgenauigkeit bzw. Ungenauigkeit für den Sensor. Diese ist vom ADU abhängig.
Die Messgenauigkeit des Sensors beläuft sich beim Druck auf ein Tausendstel Zoll auf der Quecksilbersäule. Umgerechnet in Pascal ergibt dies 3,386 Pascal pro Schritt.
Die Temperatur wird in 0,1°C Schritten gemessen.[1]
Einstellungsmöglichkeiten für die Einheiten der Messung
Der Sensor lässt sich dahingehend einstellen, dass die Druck-Signale in inHg (Zoll auf der Quecksilbersäule) oder in hPa ausgegeben werden können. Für die Temperatur lassen sich die Signale in °C oder °F ausgeben. Standardmäßig sind die EInheiten inHg und °F eingestellt.[1]
Kommunikation des Sensors
Der Sensor kommuniziert über eine I²C-Schnittstelle.[2]
Anschluss des Sensors
Normalerweise würde der Sensor über einen NXT Stein angesteuert und ausgelesen werden. Das Ganze funktioniert als Plug-and-Play. Zum Einlesen des Sensors in Matlab/Simulink wird eine Toolbox der RWTH Aachen benötigt. Mehr Informationen dazu gibt es unter folgendem Link:
https://de.mathworks.com/hardware-support/lego-mindstorms-matlab.html
Alternative Herangehensweisen
Wenn kein NXT-Stein vorhanden ist oder andere Gründe gegen die Verwendung sprechen, so gibt es mehrere Alternativen den Sensor trotzdem auszulesen. Je nach Durchführung und Möglichkeit kann dazu das NXT-Kabel direkt angeschlossen werden. In machen Fällen lässt es sich jedoch nicht vermeiden, dass Kabel aufzuschneiden und die Litzen einzeln auszulesen. Die Pinbelegung ist in der nachfolgenden Tabelle aufgeführt. In der rechten Abbildung ist ein aufgeschnittenes und umbebautes Kabel für die Verwendung am Arduino/Sigrok nutzbar gemacht worden.
Tabelle 1: Pin-Belegung[3]
# | Farbe | Funktion |
---|---|---|
1 | Weiß | +9V Suplly (Analog) |
2 | Schwarz | GND |
3 | [Rot | GND |
4 | Grün | +4,3V Supply |
5 | Gelb | I²C Clock (SCL) |
6 | Blau | I²C Data (SDA) |
Decoder/Analyser-Ansatz
Es ist möglich den Sensor mittels eines Decoder/Analyser auszulesen. Der Vorteil dabei besteht darin, dass dieser in der Lage ist die Bus-Adresse des Sensors direkt auszulesen. Dies erspart Zeit sofern die Adresse nicht bekannt ist. Weiterhin können die Daten direkt verarbeitet werden.
Ein möglicher Decoder ist der Sigrok. Ein Nachteil bei diesem Ansatz ist die Notwendigkeit des Aufschneidens des Kabels. Ein weiterer Nachteil besteht darin, dass eine Gewisse Vorkenntnis benötigt wird, was Programmierung angeht.[4]
Weitere Informationen zum Sigrok sind unter dem folgenden Link zu erhalten:
https://sigrok.org/wiki/Protocol_decoders
Arduino-Ansätze
Es gibt zwei Ansätze, mit denen der Sensor via Arduino ausgelesen werden kann. Beide Ansätze sind relativ ähnlich, sie unterscheiden sich lediglich in der Art und Weise, wie der Sensor an den Arduino angeschlossen wird.
Beim leichten Ansatz wird der Sensor mit seinem NXT-Kabel über ein Dongle an den Arduino angeschlossen. Dabei müssen lediglich die Spannungsversorgung, GND, Die Clock-Leitung und die Signalleitung richtig angeschlossen werden. Der Vorteil dieses Ansatzes liegt darin, dass der Anschluss leichter ist. Auf der anderen Seite ist die Anschaffung eines solchen Dongles mit Kosten verbunden. Ein solches Dongle ist unter folgendem Link erhältlich:
http://www.mindsensors.com/ev3-and-nxt/58-breadboard-connector-kit-for-nxt-or-ev3
Beim schwierigeren Ansatz wird der Sensor über ein Steckbrett oder eine Platine an den Arduino angeschlossen. Dazu muss allerdings das Kabel des Arduinos aufgeschnitten werden. Anschließend müssen die Litzen einzeln ausgelesen werden.
Der Vorteil bei diesem Ansatz besteht darin, dass kein Dongle gekauft werden muss. Wenn allerdings ein solches Dongle bereits vorhanden ist, macht es wenig Sinn den schwierigeren Ansatz zu verfolgen.
Bei beiden Ansätzen gilt es einige Regeln zu beachten, diese werden im folgenden Kapitel näher erläutert.
Vorgehen beim Arduino-Ansatz
Der Arduino wurde wie in der schematischen Abbildung mit dem Sensor verbunden. Die 2K7 Ohm Pullup-Widerstände waren dabei essenziell, um die Clock und die Datenleitung auf eine positive Gleichspannung zu ziehen. Ohne die Widerstände ist ein Auslesen des Sensors nicht möglich, es sei denn es wird ein Spannungsteiler verwendet, dabei müssen jedoch größere Widerstände verwendet werde. Jeweils ein 100K Ohm Widerstand auf die Masse ist dabei eine mögliche Herangehensweise, mit der es zumindest möglich ist die Adresse des Sensors auszulesen. In wie weit die einen Einfluss auf die Messwerte hat, wurde nicht getestet.
Wichtig: Auch bei der Verwendung des Dongles müssen die Pullups verwendet werde, es sei denn diese sind bereits im Dongle integriert.
Nachdem der Sensor angeschlossen wurde, muss die Bus-Adresse des Sensors ausgelesen werden, um diesen auswerten zu können. Dazu gibt es Arduino Programme, welche die I²C-Adresse herausfinden, alternativ kann auch direkt über Matlab die Adresse ausgelesen werden.
Einen I²C-Scanner gibt es z.B. unter folgendem Link:
https://arduino-projekte.webnode.at/i2c-scanner/
Vorgehen bei der Messung
Da die Messwerte eines Barometers und eines Thermometers eher schwieriger zu ändern sind. Wurden zunächst konstante Werte gemessen und anhand dieser Werte der Mittelwert und die Standardabweichung berechnet.
Für genauere Messungen mit dynamischen Werten wäre ein Klimaschrank nötig gewesen. Für dieses Projekt wurde daher ein improvisierter Klimaschrank gebaut. Dazu wurde ein luftdicht verschließbarer Gefrierbeutel genommen. In diesen wurden zwei Löcher geschnitten, durch die zum einen das Sensor Kabel und zum anderen der Schlauch einer Luftpumpe geführt wurde. Anschließend wurden die Löcher Luftdicht versiegelt. Durch den Zippverschluss wurde anschließend der Sensor an das Sensorkabel angeschlossen. Danach wurde ein Vergleichs-Thermometer (digital) in den Beutel gestellt. Dieses sollte Referenzwerte für die Temperaturmessung liefern. Für die Druck-Referenzwerte wurde das analoge Barometer der Luftpumpe. Beide Referenzmessmittel konnten nicht mit dem PC verbunden werden, daher mussten die Referenzwerte abgelesen werden. Die nachfolgende Tabelle 2 zeigt die verwendeten Materialien. Später im Kapitel „Ausblick“ werden Verbesserungen für diese Konstruktion genannt.
‘‘‘Tabelle 2: Materialliste für den improvisierten Klimaschrank‘‘‘
# | Material |
---|---|
1 | Gefriebeutel mit Zippverschluss |
2 | Luftpumpe mit analog Barometer |
3 | Dichtmaterial (Klebeband) |
4 | Digital Termometer |
Nach der Fertigstellung und Vorbereitung des improvisierten Klimaschranks wurde der Zippbeutel verschlossen und auf Dichtigkeit überprüft. Anschließend konnte die Messung beginnen. Zur Manipulation des Drucks konnte der Druck durch betätigen der Luftpumpe erhöht werden. Die Temperatur konnte durch einen Fön beeinflusst werden. Alternativ kann die Veränderung des Drucks durch Messungen in verschiedenen Höhen (z.B. Stockwerken) erfolgen. Dazu ist es jedoch wichtig die Temperatur und die Tatsächliche Höhe als Referenzwert zu kennen.
Zum Auslesen der Sensorwerte wurde ein kurzes Arduino Programm geschrieben. Dieses Programm arbeitet mit der Wire-Bibliothek (Wire.h), welche es dem Arduino erlaub via I²C zu kommunizieren. Aufgrund der Geschwindigkeit des Prozessors des Arduinos, können die Werte nur im 1000stel Sekundenbereich aufgezeichnet werden.[5]
//Bibliothek zum auslesen der I²C Kommunikation #include <Wire.h> //Zuweisung der Sensor Adresse (aus Scanner) #define Sensor 0x01 //Deklaration Speichervariablen byte msb; //erste Byte ist MSB (höherwertig) byte lsb; //zweiter Byte ist LSB (niederwertig) int Messwert; void setup() { Serial.begin(9600); Wire.begin(); } void loop() { //Jetzt werden 2 Bytes vom Sensor angefordert. Zuerst kommt der MSB (hochwertige Byte) und dann der LSB (der niedrigwertige Byte). Wire.requestFrom(Sensor, 2); if(Wire.available() >= 2) { msb = Wire.read(); //erste Byte ist MSB (höherwertig) lsb = Wire.read(); //zweiter Byte ist LSB (niederwertig) // Umwandeln von 16 Bit auf 12 Bit Messwert = ((msb)<<4); //Verschieben von MSB nach links Messwert |= (lsb>>4); //Verschieben von LSB nach rechts Serial.println(Messwert); } delay(5); }
Auswertung Messergebnisse
Die Aufnahme der Messwerte war auf Grund der Test-Apperatur schiewriger als erwartet.
Die Aufnahme der Messwerte war auf Grund der Test-Apparatur schwieriger als erwartet und wurde aufgrund mehrerer Mängel stark behindert. Das Hauptproblem bestand im fehlen eines Klimaschranks. Der improvisierte Klimaschrank stieß schnell an seine Grenz, was sich dadurch merkbar machte, dass der Druck nicht konstant blieb. Auch Nachbesserungen an den Durchführungen für die Luftpumpe sowie den Sensor reichten nicht aus. Es stellte sich heraus, dass der Zippverschluss bei zunehmendem Druck nicht mehr zu 100% dicht war. Der Maximal Druck im improvisierten Klimaschrank belief sich auf 2 Bar, laut Referenz Barometer. Problematisch war dort, dass der Sensor deutlich niedrigere Druck-Werte anzeigte. Auch nach mehreren Versuchen und Umbauten der Apparatur war es nicht möglich bessere Ergebnisse zu erziele. Auffällig war hier, dass das Referenzbarometer stark Schwankte, was vermutlich auf die Dichtigkeit der Konstruktion zurück zu führen ist.
Die Messung der Temperatur lief ähnlich schlecht bzw. langsam. Der Sensor ändert nur äußerst langsam seine gelieferten Werte. Der Versuch durch höhere Temperaturschwankungen schnellere Ergebnisse zu erzielen schlug fehl. Dabei wurde mit einem Föhn auf niedrigster Stufe der improvisierte Kleiderschrank erhitzt. Der Sensor lieferte nur eine minimale Steigerung der Temperatur. Das Referenzthermometer hingegen reagierte deutlich schneller auf die Temperaturänderung, versagte jedoch nach kurzer Zeit und fiel aus. Dies war zum einen an einer fehlerhaften Ausgabe und zum anderen an einer schwarzen Verfärbung des Displays zu erkennen, welche sich allerdings nach dem Abkühlen wieder normalisierte (siehe Abbildung: Schwachstelle Thermometer). Die Messwerte des Referenzthermometers sind nach dem Abkühlen wieder in normal, sodass weitere Messungen erfolgen konnten (wenn auch mit niedrigeren Temperaturen).
Aufgenommene Messwerte
Die Aufgenommenen Messwerte sind in den folgenden Tabellen aufgeführt:
Matlab-Auswertung
Plot der Temperatur - Konstant (Mit Referenz) und Mit Fön (Ausfall Referenz)
Plot des Drucks - Konstant - Dynamisch nicht möglich (Referenz nicht brauchbar)
Youtube-Video
Die Präsentation der Ergebnisse von diesem Projekt sind in dem Folgenden Video kurz zusammengefasst:
Link
Zusammenfassung
- Das Barometer reagiert nur langsam auf Änderungen
- Keine Abweichung bzw. Schwanken bei konstanten Temperaturen/Druck
- Das Equipment war unzureichend
- Übertragen in Matlab/Simulink aufgrund der Zwischenergebnisse Zecklos (Besseres Equipment wird benötigt)
- Es besteht Potential zur Verbesserung
Ausblick
Für eine genauere Auswertung und eine daraus resultierende bessere Kalibrierung des Sensors ist es nötig, mit besserem Test-Equipment die Werte aufzunehmen. Ein Klimaschrank wäre an der Stelle optimal. Ansonsten bestände eine Verbesserung darin ein Vergleichs-Barometer bzw. Thermometer zu verwenden, welches mindestens eine genau so feine Messgenauigkeit, wie das NXT Barometer aufweist und darüber hinaus an den PC angeschlossen werden kann. Dadurch könnten die Vergleichswerte direkt mit einberechnet werden. Bei den verwendeten Vergleichsgerätschaften waren diese Messgenauigkeit und die Anschlussfunktion nicht gegeben. Das Behältnis sollte zudem 100% dicht sein, auch bei hohem Druck.
Hilfreiche Links
- NXT Barometer: http://www.hitechnic.com/cgi-bin/commerce.cgi?preadd=action&key=NBR1036 (Abgerufen am 03.07.2018)
- Matlab Toolbox: https://de.mathworks.com/hardware-support/lego-mindstorms-matlab.html (Abgerufen am 03.07.2018)
- Sigrok: https://sigrok.org/wiki/Protocol_decoders (Abgerufen am 03.07.2018)
- Arduino Connector: http://www.mindsensors.com/ev3-and-nxt/58-breadboard-connector-kit-for-nxt-or-ev3 (Abgerufen am 03.07.2018)
- I²C Scanner für Arduino: https://arduino-projekte.webnode.at/i2c-scanner/ (Abgerufen am 03.07.2018)
Quellenverzeichnis
- ↑ 1,0 1,1 1,2 NXT_Barometer. Abgerufen am 3. Juli 2018.
- ↑ I²C Sensor. Abgerufen am 3. Juli 2018.
- ↑ Pin Belegung. Abgerufen am 3. Juli 2018.
- ↑ Sigrok. Abgerufen am 3. Juli 2018.
- ↑ Wire.h - I²C auf Arduino. Abgerufen am 3. Juli 2018.
→ zurück zum Hauptartikel: Signalverarbeitende Systeme