.. note:: Hallo, willkommen in der SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasten-Community auf Facebook! Tauchen Sie tiefer in Raspberry Pi, Arduino und ESP32 mit anderen Enthusiasten ein. **Warum beitreten?** - **Expertenunterstützung**: Lösen Sie Probleme nach dem Kauf und technische Herausforderungen mit Hilfe unserer Community und unseres Teams. - **Lernen & Teilen**: Tauschen Sie Tipps und Tutorials aus, um Ihre Fähigkeiten zu verbessern. - **Exklusive Vorschauen**: Erhalten Sie frühzeitigen Zugriff auf neue Produktankündigungen und exklusive Einblicke. - **Spezielle Rabatte**: Genießen Sie exklusive Rabatte auf unsere neuesten Produkte. - **Festliche Aktionen und Giveaways**: Nehmen Sie an Verlosungen und Feiertagsaktionen teil. 👉 Bereit, mit uns zu forschen und zu kreieren? Klicken Sie auf [|link_sf_facebook|] und treten Sie 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 Abhängig von Ihrer Kit-Version identifizieren Sie bitte, ob Sie **ADC0834** oder **MCP3008** haben, und fahren Sie mit dem entsprechenden Abschnitt fort. Einführung ------------ Genau wie ein Fotowiderstand Licht erkennen kann, ist ein Thermistor ein temperaturabhängiges elektronisches Bauelement, das für Temperaturregelungsfunktionen wie z. B. einen Hitzewarnmelder verwendet werden kann. Benötigte Komponenten ------------------------------ In diesem Projekt benötigen wir die folgenden Komponenten: .. image:: ../img/list2_2.2.2_thermistor.png Es ist definitiv bequem, ein komplettes Kit zu kaufen. Hier ist der Link: .. list-table:: :widths: 20 20 20 :header-rows: 1 * - Name - ELEMENTE IN DIESEM KIT - LINK * - Raphael Kit - 337 - |link_Raphael_kit| Sie können die Komponenten auch einzeln über die folgenden Links kaufen: .. list-table:: :widths: 30 20 :header-rows: 1 * - KOMPONENTENBESCHREIBUNG - KAUFLINK * - :ref:`cpn_gpio_board` - |link_gpio_board_buy| * - :ref:`cpn_breadboard` - |link_breadboard_buy| * - :ref:`cpn_wires` - |link_wires_buy| * - :ref:`cpn_resistor` - |link_resistor_buy| * - :ref:`cpn_thermistor` - |link_thermistor_buy| * - :ref:`cpn_mcp3008` - \- Schaltplan ----------------- .. list-table:: :widths: 30 30 30 30 :header-rows: 1 * - T-Board Name - Physikalisch - WiringPi - BCM * - SPICE0 - Pin 24 - 10 - 8 * - SPIMOSI - Pin 19 - 12 - 10 * - SPIMISO - Pin 21 - 13 - 9 * - SPISCLK - Pin 23 - 14 - 11 .. image:: ../img/schematic_2.2.2_thermistor_mcp3008.png Experimentelle Verfahren ------------------------------------ **Schritt 1:** Bauen Sie die Schaltung auf. .. image:: ../img/2.2.2_Thermistor_bb.png **Schritt 2:** Wechseln Sie in den Code-Ordner. .. raw:: html .. code-block:: cd ~/raphael-kit/nodejs/ **Schritt 3:** Führen Sie den Code aus. .. raw:: html .. code-block:: sudo node thermistor-2.js Sobald der Code ausgeführt wird, erkennt der Thermistor die Umgebungstemperatur, die nach der Berechnung des Programms 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('ADC-Lesefehler:', 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; // Spannung (bei 3,3 V Referenz) const R0 = 10000; // Festwiderstand: 10kΩ const B = 3950; // B-Konstante const Rt = R0 * Vr / (3.3 - Vr); // Thermistorwiderstand 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 Millisekunden (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 (Bereich 0–1023) um. .. code-block:: js const Vr = 3.3 * raw / 1023; Berechnet die Spannung am Thermistor (``Vr``) anhand des ADC-Wertes. Es wird eine Referenzspannung des MCP3008 von 3,3 V angenommen. .. code-block:: js const Rt = R0 * Vr / (3.3 - Vr); Verwendet die Spannungsteilerformel, um den Thermistorwiderstand ``Rt`` zu berechnen, wobei ``R0`` ein 10kΩ-Festwiderstand in Reihe 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 berechnen. .. code-block:: js const tempC = tempK - 273.15; const tempF = tempC * 1.8 + 32; Wandelt die Temperatur von Kelvin in Celsius und anschließend in Fahrenheit um. .. code-block:: js console.log(`Celsius: ${tempC.toFixed(2)} °C | Fahrenheit: ${tempF.toFixed(2)} °F`); Gibt sowohl die Celsius- als auch die Fahrenheit-Temperatur mit zwei Dezimalstellen Genauigkeit in der Konsole aus.