.. note::
Hallo und willkommen in der SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasten-Community auf Facebook! Tauche tiefer in Raspberry Pi, Arduino und ESP32 mit anderen Enthusiasten ein.
**Warum beitreten?**
- **Expertenunterstützung**: Löse Probleme nach dem Kauf und technische Herausforderungen mit Hilfe unserer Community und unseres Teams.
- **Lernen & Teilen**: Tausche Tipps und Tutorials aus, um deine Fähigkeiten zu verbessern.
- **Exklusive Vorschauen**: Erhalte frühzeitigen Zugang zu neuen Produktankündigungen und Vorschauen.
- **Sonderrabatte**: Genieße exklusive Rabatte auf unsere neuesten Produkte.
- **Festliche Aktionen und Verlosungen**: Nimm an Verlosungen und Feiertagsaktionen teil.
👉 Bereit, mit uns zu entdecken und zu erschaffen? Klicke auf [|link_sf_facebook|] und tritt noch heute bei!
.. _2.2.2_js_pi5_mcp3008:
2.2.2 Thermistor (MCP3008)
==========================
.. note::
.. image:: ../img/mcp3008_and_adc0834.jpg
:width: 25%
:align: left
Je nach Kit-Version bitte prüfen, ob **ADC0834** oder **MCP3008** enthalten ist, und mit dem entsprechenden Abschnitt fortfahren.
Einführung
----------
Genau wie ein Fotowiderstand Licht erfassen kann, ist ein Thermistor ein temperaturabhängiges elektronisches Bauteil, das zur Realisierung von Temperaturregelungsfunktionen wie z. B. einer Hitze-Alarmfunktion eingesetzt werden kann.
Benötigte Komponenten
---------------------
In diesem Projekt benötigen wir die folgenden Komponenten.
.. image:: ../img/list2_2.2.2_thermistor.png
Schaltplan
----------
.. list-table::
:widths: 30 30 30 30
:header-rows: 1
* - T-Board-Name
- Physical
- WiringPi
- BCM
* - SPICE0
- pin24
- 10
- 8
* - SPIMOSI
- pin19
- 12
- 10
* - SPIMISO
- pin21
- 13
- 9
* - SPISCLK
- pin23
- 14
- 11
.. image:: ../img/schematic_2.2.2_thermistor_mcp3008.png
Experimentelle Schritte
-----------------------
**Schritt 1:** Baue die Schaltung auf.
.. image:: ../img/2.2.2_Thermistor_bb.png
**Schritt 2:** Gehe in den Code-Ordner.
.. raw:: html
.. code-block::
cd ~/davinci-kit-for-raspberry-pi/nodejs/
**Schritt 3:** Führe den Code aus.
.. raw:: html
.. code-block::
sudo node thermistor-2.js
Wenn der Code ausgeführt wird, misst der Thermistor die Umgebungstemperatur,
die nach Abschluss der Berechnung auf dem Bildschirm ausgegeben wird.
**Code**
.. code-block:: js
const mcpadc = require('mcp-spi-adc');
// Öffne MCP3008-Kanal 0 (CH0), analoger Eingang vom Thermistor-Spannungsteiler
const adc = mcpadc.openMcp3008(0, { speedHz: 1350000 }, (err) => {
if (err) {
console.error('Fehler beim Öffnen des MCP3008-Kanals:', err);
process.exit(1);
}
console.log('MCP3008-Thermistor-Kanal geöffnet.');
setInterval(() => {
adc.read((err, reading) => {
if (err) {
console.error('Fehler beim Lesen vom ADC:', err);
return;
}
const adcValue = reading.value; // Float: 0.0–1.0
const raw = Math.round(adcValue * 1023); // 10-Bit-Integerwert
const Vr = 3.3 * raw / 1023; // In Spannung umrechnen (bei 3,3 V Referenz)
const R0 = 10000; // Festwiderstand: 10 kΩ
const B = 3950; // B-Konstante
const Rt = R0 * Vr / (3.3 - Vr); // Thermistor-Widerstand
const tempK = 1 / ((Math.log(Rt / R0) / B) + (1 / (273.15 + 25))); // Kelvin
const tempC = tempK - 273.15; // Celsius
const tempF = tempC * 1.8 + 32; // Fahrenheit
console.log(`Celsius: ${tempC.toFixed(2)} °C | Fahrenheit: ${tempF.toFixed(2)} °F`);
});
}, 1000);
});
**Code-Erklärung**
.. code-block:: js
setInterval(() => {
adc.read((err, reading) => {
...
});
}, 1000);
Richtet eine Schleife ein, die alle 1000 ms (1 Sekunde) vom MCP3008-Kanal 0 liest.
Die Funktion `read` gibt einen analogen Wert zwischen 0,0 und 1,0 zurück.
.. code-block:: js
const raw = Math.round(reading.value * 1023);
Wandelt den normalisierten Float-ADC-Wert in einen rohen 10-Bit-Integerwert (0–1023) um.
.. code-block:: js
const Vr = 3.3 * raw / 1023;
Berechnet die Spannung am Thermistor (``Vr``) basierend auf der ADC-Messung.
Es wird angenommen, dass die Referenzspannung des MCP3008 3,3 V beträgt.
.. code-block:: js
const Rt = R0 * Vr / (3.3 - Vr);
Verwendet die Spannungsteilerformel zur Berechnung des Thermistorwiderstands ``Rt``,
wobei ``R0`` der feste Serienwiderstand (10 kΩ) ist.
.. code-block:: js
const tempK = 1 / ((Math.log(Rt / R0) / B) + (1 / (273.15 + 25)));
Wendet die **B-Parameter-Gleichung** (eine vereinfachte Form der Steinhart-Hart-Gleichung) an,
um die Temperatur in Kelvin zu schätzen.
.. code-block:: js
const tempC = tempK - 273.15;
const tempF = tempC * 1.8 + 32;
Wandelt die Temperatur in Kelvin zunächst in Celsius und anschließend in Fahrenheit um.
.. code-block:: js
console.log(`Celsius: ${tempC.toFixed(2)} °C | Fahrenheit: ${tempF.toFixed(2)} °F`);
Gibt die Temperaturwerte in Celsius und Fahrenheit mit zwei Nachkommastellen in der Konsole aus.