projekt:python_projekt_ds18b20_digitaler_temperatursensor
Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
| Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNächste Überarbeitung | Vorhergehende Überarbeitung | ||
| projekt:python_projekt_ds18b20_digitaler_temperatursensor [2026/02/20 14:48] – [Voraussetzungen] torsten.roehl | projekt:python_projekt_ds18b20_digitaler_temperatursensor [2026/02/23 12:09] (aktuell) – [Ausführen des Programms] torsten.roehl | ||
|---|---|---|---|
| Zeile 3: | Zeile 3: | ||
| [[python| ☚ zurück]] | [[python| ☚ zurück]] | ||
| - | FIXME BEITRAG IN ENTSTEHUNG | + | |
| + | //In diesem Projekt wird ein digitaler Temperaturfühler vom Typ DS18B20 am Raspberry Pi per 1-Wire-Schnittstelle betrieben. Nach Aktivierung der 1-Wire-Schnittstelle liefert der Kernel die Messwerte über das // | ||
| + | // | ||
| + | |||
| ====== Überblick ====== | ====== Überblick ====== | ||
| Zeile 17: | Zeile 21: | ||
| ---- | ---- | ||
| - | ====== | + | ====== |
| - | |{{ : | + | ===== Voraussetzungen ===== |
| - | |< | + | |
| + | |{{ : | ||
| + | |< | ||
| + | |||
| + | ===== Hardware ansteuern | ||
| + | |||
| + | Der DS18B20 kommuniziert über die 1-Wire-Schnittstelle. Dabei erfolgt die gesamte Datenübertragung seriell über die DATA-Leitung (**GPIO4**) mit einem Pull-Up-Widerstand gegen <color # | ||
| + | |||
| + | |{{ : | ||
| + | | Für Einsteiger sind die //etwas teureren Fertigmodule// | ||
| + | |||
| + | |||
| + | Verdrahtung: | ||
| - | ====== Details | + | ^ Modul ^ Raspberry Pi GPIO ^ |
| + | | GND | beliebigen GND | | ||
| + | | <color # | ||
| + | | <color # | ||
| + | |||
| + | |||
| + | |||
| + | |||
| + | <note tip> | ||
| + | |||
| + | Es kann nicht jeder beliebige GPIO-Pin verwendet werden. Standardmäßig ist dafür GPIO4 vorgesehen. Andere Pins müssen explizit über das Device-Tree-Overlay konfiguriert werden; dies wird hier nicht behandelt. | ||
| + | </ | ||
| + | |||
| + | Beim DS18B20 gilt: | ||
| + | * Auflösung: 0,0625 °C (12 Bit) | ||
| + | * Genauigkeit: | ||
| + | * Messbereich −55 °C bis +125 °C | ||
| + | ==== Messprinzip | ||
| + | |||
| + | < | ||
| + | |||
| + | **Ein Programm muss lediglich die Datei '' | ||
| + | </ | ||
| + | |||
| + | |{{ : | ||
| + | |Mit '' | ||
| + | |||
| + | ++++ Hintergrund | | ||
| + | |||
| + | Nach Aktivierung von 1-Wire über '' | ||
| + | |||
| + | Der Name '' | ||
| + | |||
| + | Die gesamte 1-Wire-Kommunikation übernimmt der Kernel. | ||
| + | |||
| + | * Bei jedem Lesezugriff auf diese Datei stößt der Kernel automatisch eine neue Temperaturumwandlung an. | ||
| + | * In der ersten Zeile signalisiert „YES“, dass die CRC-Prüfung erfolgreich war. | ||
| + | * In der zweiten Zeile steht der Temperaturwert hinter „t=“ in Milligrad Celsius. | ||
| + | ++++ | ||
| ===== Software ===== | ===== Software ===== | ||
| + | === Programmstruktur === | ||
| + | |{{ : | ||
| + | |Im Projektordner „course_temp_reader“ befinden sich im Verzeichnis '' | ||
| + | |||
| ==== Environment aktivieren ==== | ==== Environment aktivieren ==== | ||
| + | |||
| + | |||
| + | <note important> | ||
| + | **Aktiviere die Python-Environment** | ||
| + | |||
| + | Die Programmierung erfolgt nun immer mit der gewählten Umgebung! | ||
| + | < | ||
| + | source ~/ | ||
| + | </ | ||
| + | |||
| + | </ | ||
| ==== DS18B20 API ==== | ==== DS18B20 API ==== | ||
| + | Unsere Beispiel-API ist bewusst einfach gehalten und unterstützt hier nur einen einzelnen Sensor. Bei Bedarf kann die Implementierung problemlos auf mehrere Sensoren erweitert werden; darauf wird in diesem Projekt jedoch verzichtet. | ||
| + | |||
| <code python hardware.py > | <code python hardware.py > | ||
| Zeile 75: | Zeile 147: | ||
| - | ==== Test ==== | + | ==== Temperature |
| - | <code python | + | <code python |
| + | # | ||
| from hardware import get_temperature | from hardware import get_temperature | ||
| Zeile 91: | Zeile 164: | ||
| main() | main() | ||
| </ | </ | ||
| + | |||
| + | ==== Ausführen des Programms ==== | ||
| + | Nach dem Programmstart wird auf der Kommandozeile die Temperatur in Grad Celsius ausgegeben, sofern der Sensor korrekt erkannt wurde und die Messung erfolgreich war. | ||
| + | |||
| + | <code bash> | ||
| + | cd ~/ | ||
| + | chmod 755 temp_reader.py | ||
| + | ./ | ||
| + | |||
| + | # Beispielausgabe: | ||
| + | Temperatur: 21.25 °C | ||
| + | </ | ||
| + | |||
| + | |||
projekt/python_projekt_ds18b20_digitaler_temperatursensor.1771598917.txt.gz · Zuletzt geändert: von torsten.roehl
