Temperatursensor mit Matlab/Simulink

Aus HSHL Mechatronik
Zur Navigation springen Zur Suche springen

Autor: Sergej Vogel
Betreuer: Prof. Schneider
Sensor: Lego Temperatursensor 9749


Aufgabenstellung


In dem Fach "Signalverarbeitende Systeme" aus dem Studiengang "Business and Systemsengineering" wurde jeder Student damit beauftragt, sich Semester begleitend mit einem Sensor auseinander zu setzen. Genauer gesagt, soll man sich über den Sensor informieren, sowie dessen Signale mittels MATLAB/Simulink verwertbar zu machen.

Primärsensor


In diesem Kapitel soll der LEGO® MINDSTORMS® Temperatursensor (Artikel 9749) vorgestellt und erläutert werden (siehe Abb. 1).
Leider gibt es sehr wenige Informationen zu dem Sensor. Aus diesem Grund habe ich den Kundenservice von Lego Mindstorms kontaktiert und um ein Datenblatt des Sensors gebeten. Nach Aussage des Kundenservice besitzen sie kein Datenblatt zu diesem Sensor (siehe Abb.2). Dennoch war es möglich einige Daten herauszufinden.

Abb. 1: Temperatursensor
Abb. 2: Antwort des Kundenservices
















Es handelt es sich um einen digitalen Sensor, der durch einen LEGO® MINDSTORMS® Education NXT (Software v.2.1) oder LEGO MINDSTORMS Education EV3 (EV3 Software) angesteuert und ausgelesen werden kann. Dabei findet die Kommunikation, zwischen dem Mikrocontroller und dem Sensor, über die I²C Schnittstelle statt. Dafür muss die 7 bit Adresse (0x4C) des Sensors angesprochen werden. Der Einsatz des Sensors liegt in dem Temperaturbereich: -20°C bis 120°C bzw. -4°F - 248°F, wobei dieser erst kalibriert werden muss. Laut inoffiziellen Angaben, ist in dem NXT Gehäuse der Sensor von Typ TMP275 mit einem 12 Bit Analog-Digital-Umsetzer (ADU) oder engl. (analog-digital-converter (ADC)) integriert. Die Temperaturaufnahme erfolgt hierbei mittels einer in dem TMP275 Sensor verbauten Diode und dem Fühlerrohr. Die Art der eingebauten Diode ist nicht bekannt.

I²C Schnittstelle


Der I²C Bus (Inter Integrated Circuit) wurde von Philips konzipiert und stellt heute den Standard für die Systemsteuerung dar. Der Bus basiert auf einem Master-Slave-Prinzip und hat zwei Leitungen zur Verfügung. Die beiden Leitungen heißen Signal Data (SDA) und Signal Clock (SCL). Wie die Namen schon sagen, wird die SDA Leitung für Datenübertragung genutzt, während die SCL Leitung für den Takt zuständig ist. Der Takt wird durch den Master erzeugt, kann aber vom Slave solange auf 0 gehalten werden, bis der Slave wieder bereit ist. Die Daten können in beide Richtungen byteweise übermittelt werden. In diesem Fall stellt der Temperatursensor den Slave dar. Dieser hat eine eindeutige 7-Bit-Adresse, die der Master anspricht.

START-Bedingung


Abb. 3: START-Bedingung








Zu Anfang befinden sich die beiden Leitungen im Leerlauf und werden durch Pullupwiderstände auf hohem Pegel gehalten. Zu diesem Zeitpunkt können keine Daten übertragen werden. Um eine Kommunikation zwischen Master und Slave herzustellen, muss eine Startbedingung erzeugt werden. Diese kommt Zustande, indem die SDA Leitung von HIGH auf LOW wechselt, während die SCL Leitung weiterhin auf HIGH bleibt. Erst dann beginnt die Datenübertragung. Hervorgerufen wird die Startbedingung durch den Master. Ab dem Moment befindet sich der Bus im Modus "beschäftigt".







Adressierung und Read/Write (R/W)


Abb. 4: Temperatursensor



Nach der Startbedingung beginnt die von dem Master ausgehende Kommunikation. Übertragen werden die Informationen byteweise (8-Bit). Damit sich ein Slave angesprochen fühlt, muss der Master die eindeutige Adresse des Slave ansprechen. Somit sendet der Master auf der SDA Leitung eine 7-Bit Adresse, um den Slave anzusprechen, gefolgt vom einem weiteren Bit mit der Information, ob der Master an den Slave eine Information senden (LOW), oder vom Slave Informationen erhalten möchte (HIGH). Dieses wird als Datenrichtungsbit bezeichnet.




Aknowledge (ACK) und Not Aknowledge (NACK)


Abb. 5: Acknowledge/Not Acknoledge


Die Bestätigung ACK erfolgt nach jedem Byte. Dadurch teilt der Empfänger/Slave (in unserem Fall der Temperatursensor) dem Sender/Master mit, dass das Byte erfolgreich empfangen wurde und das nächste Byte gesendet werden kann. Damit es funktioniert, gibt der Master die SDA-Leitung während des Bestätigungstaktimpulses frei und der Slave zieht die SDA-Leitung auf LOW. Diese bleibt während der HIGH-Periode des Taktimpulses weiterhin auf LOW. Es gibt 5 Bedingungen die zu einem NACK führen:

  1. Auf dem Bus ist kein Empfänger mit der übertragenen Adresse vorhanden, so dass kein Gerät mit einer Bestätigung antworten kann.
  2. Der Empfänger kann nicht empfangen oder senden, da er eine Echtzeitfunktion ausführt und nicht bereit ist, die Kommunikation mit dem Master zu starten.
  3. Während der Übertragung erhält der Empfänger Daten oder Befehle, die er nicht versteht.
  4. Während der Übertragung kann der Empfänger keine weiteren Datenbytes mehr empfangen.
  5. Ein Master-Empfänger muss das Ende der Übertragung an den Slave-Sender signalisieren.




STOP-Bedingung


Abb. 6: STOP-Bedingung







Das Gegenstück zu der Start-Bedingung ist die Stop-Bedingung. Diese wird erzeugt, indem die SDA Leitung von LOW auf HIGH wechselt, während sich die SCL Leitung in der HIGH Phase befindet. Diese Bedingung wird ebenfalls durch den Master erzeugt. Eine bestimmte Zeit nach dem STOP befindet sich die Bus-Leitung im freien Zustand.









Herstellung der Kommunikation

Abb. 7: Herstellung der Kommunikation


In diesem Projekt wird der Temperatursensor zunächst durch einen Arduino angesteuert und ausgelesen. Die vorverarbeiteten Daten werden im nächsten Schritt über eine serielle Schnittstelle an Matlab weitergeleitet und dort verarbeitet.






Anschluss an Arduino

Abb. 9: Arduinoanschluss Schaltplan
Abb. 8: Sensor-Arduino-Verbindung


Da der Sensor eine I²C Schnittstelle besitzt und nicht beschädigt werden soll, wird ein Connector Kit for NXT or EV3 genutzt. Mit diesem Connector ist es möglich, den I²C Bus mit dem Arduino zerstörungsfrei zu verbinden. Zur Hilfe wird ein Steckbrett hinzugezogen, wo der Connector reingesteckt wird. Zur Verbindung werden 4 Kabel benötigt.

  1. Das blaue Kabel stellt die SDA-Leitung dar. Dafür wird das Kabel mit dem Port A4 des Arduinos verbunden.
  2. Das gelbe Kabel stellt die SCL-Leitung dar. Dafür wird das Kabel mit dem Port A5 des Arduinos verbunden.
  3. Das rote Kabel liefert die Spannung von 5 Volt und wird somit an die 5V des Arduinos angeschlossen.
  4. Der I²C Bus besitzt zwei Grounds, die miteinander verbunden und über das schwarze Kabel an das GND des Arduinos angeschlossen werden.
  5. Zum Schluss werden zwei Pull-Up Widerstände von 82kOhm benötigt. Einer davon wird zwischen die Spannungsversorgung und der SDA-Leitung und der andere zwischen Spannungsversorgung und der SCL-Leitung geschaltet.







Sensor-Arduino-Kommunikation

Abb. 10: SDA-SCL-Signale





Für die Kommunikation zwischen Arduino und dem I²C Bus gibt es die sogenannte Wire-Bibliothek.

//Bibliothek für die I²C Kommunikation
#include <Wire.h>
//Adresse des Sensors          
#define ADDR 0x4C            

byte msb; //erste Byte ist MSB (höherwertig)
byte lsb; //zweiter Byte ist LSB (niederwertig)
int Rohwert;
int temperatur;

void setup() 
{
  Wire.begin();
  Serial.begin(9600);
}

void loop() 
{
  Wire.requestFrom(ADDR, 2);
  if(Wire.available() >= 2)
  {
    msb = Wire.read(); //erste Byte ist MSB (höherwertig)
    lsb = Wire.read(); //zweiter Byte ist LSB (niederwertig)
 
    Rohwert = ((msb)<<4); //Bitshiften um 4 nach links
    Rohwert |= (lsb>>4);  //Bitshiften um 4 nach rechts und zu dem MSB hinzuaddieren
   
    Serial.println(Rohwert);
    temperatur = Rohwert * 0.0625; //0.0625 ist die Temperaturauflösung
    Serial.println(temperatur);
  }
  delay(1000);
}





















Weiterleitung der Rohdaten an Matlab

→ zurück zum Hauptartikel: Signalverarbeitende Systeme