.. 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_c_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 ------------ Genauso wie ein Fotowiderstand Licht messen kann, ist ein Thermistor ein temperatursensitives elektronisches Bauteil, das zur Temperaturmessung und für Temperaturregelungsfunktionen wie z. B. Wärmealarm verwendet werden kann. Benötigte Komponenten ------------------------------ Für dieses 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 - 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 Verfahren ------------------------------------------------- **Schritt 1:** Schließen Sie den Stromkreis an. .. image:: ../img/july24_2.2.2_thermistor_mcp3008.png **Schritt 2:** Wechseln Sie in den Code-Ordner. .. raw:: html .. code-block:: cd ~/raphael-kit/c/2.2.2-2/ **Schritt 3:** Kompilieren Sie den Code. .. raw:: html .. code-block:: gcc 2.2.2_Thermistor.c -o Thermistor -lwiringPi -lm .. note:: -lm lädt die Mathematikbibliothek. Nicht weglassen, da sonst ein Fehler auftritt. **Schritt 4:** Führen Sie die ausführbare Datei aus. .. raw:: html .. code-block:: ./Thermistor Nach dem Start des Programms misst der Thermistor die Umgebungstemperatur, die nach der Berechnung auf dem Bildschirm ausgegeben wird. .. note:: Wenn es nach dem Ausführen nicht funktioniert oder die Fehlermeldung „wiringPi.h: No such file or directory“ erscheint, lesen Sie bitte :ref:`install_wiringpi`. **Code** .. code-block:: c #include #include #include #include #define SPI_CHANNEL 0 // CE0 #define SPI_SPEED 1000000 // 1MHz int read_ADC(int channel) { if (channel < 0 || channel > 7) return -1; unsigned char buffer[3]; buffer[0] = 1; // Startbit buffer[1] = (8 + channel) << 4; // Single-Ended-Modus + Kanal buffer[2] = 0; wiringPiSPIDataRW(SPI_CHANNEL, buffer, 3); int value = ((buffer[1] & 3) << 8) | buffer[2]; return value; } int main(void) { int analogVal; double Vr, Rt, temp, cel, Fah; if (wiringPiSetup() == -1) { printf("setup wiringPi failed!\n"); return 1; } if (wiringPiSPISetup(SPI_CHANNEL, SPI_SPEED) == -1) { printf("SPI setup failed!\n"); return 1; } while (1) { analogVal = read_ADC(0); // Lesen von CH0 // MCP3008 ist ein 10-Bit-ADC (0–1023) Vr = 3.3 * analogVal / 1023.0; // Vref = 3.3V Rt = 10000.0 * Vr / (3.3 - Vr); // Spannungsteiler, 10k Widerstand temp = 1 / ((log(Rt / 10000.0) / 3950.0) + (1 / (273.15 + 25.0))); cel = temp - 273.15; Fah = cel * 1.8 + 32; printf("Celsius: %.2f C Fahrenheit: %.2f F\n", cel, Fah); delay(1000); } return 0; } Code-Erklärung -------------------- .. code-block:: c #include #include #include #include Diese Headerdateien binden Bibliotheken für GPIO-Steuerung (``wiringPi.h``), SPI-Kommunikation (``wiringPiSPI.h``), Standard-I/O-Funktionen (``stdio.h``) und mathematische Funktionen (``math.h``) in C ein. .. code-block:: c #define SPI_CHANNEL 0 #define SPI_SPEED 1000000 Definiert Konstanten für den SPI-Kanal und die SPI-Geschwindigkeit. Hier wird SPI-Kanal 0 (CE0) mit einer Taktrate von 1 MHz verwendet. .. code-block:: c int read_ADC(int channel) Diese Funktion liest analoge Daten von einem bestimmten Kanal des MCP3008-ADC aus. .. code-block:: c buffer[0] = 1; buffer[1] = (8 + channel) << 4; buffer[2] = 0; Diese Zeilen formatieren den SPI-Befehl entsprechend dem MCP3008-Protokoll: Startbit, Konfiguration für den Single-Ended-Modus und Kanalnummer. .. code-block:: c wiringPiSPIDataRW(SPI_CHANNEL, buffer, 3); Überträgt den SPI-Befehl und empfängt die 10-Bit-ADC-Daten vom MCP3008. .. code-block:: c int value = ((buffer[1] & 3) << 8) | buffer[2]; Extrahiert und kombiniert das 10-Bit-ADC-Ergebnis aus dem zurückgegebenen SPI-Puffer. .. code-block:: c if (wiringPiSetup() == -1) { ... } if (wiringPiSPISetup(SPI_CHANNEL, SPI_SPEED) == -1) { ... } Diese Zeilen initialisieren WiringPi und konfigurieren SPI. Falls die Initialisierung fehlschlägt, beendet das Programm die Ausführung. .. code-block:: c analogVal = read_ADC(0); Liest das analoge Signal vom MCP3008-Kanal 0, an dem der Thermistor-Spannungsteiler angeschlossen ist. .. code-block:: c Vr = 3.3 * analogVal / 1023.0; Wandelt den digitalen ADC-Wert in eine analoge Spannung um. Der ADC-Bereich ist 0–1023 bei 3,3 V Referenzspannung. .. code-block:: c Rt = 10000.0 * Vr / (3.3 - Vr); Berechnet den Widerstand des Thermistors anhand der Spannungsteiler-Formel. Es wird ein 10kΩ-Widerstand in Reihe mit dem Thermistor angenommen. .. code-block:: c temp = 1 / ((log(Rt / 10000.0) / 3950.0) + (1 / (273.15 + 25.0))); Verwendet die B-Parameter-Gleichung, um den Widerstand des Thermistors in eine Temperatur in Kelvin umzuwandeln. **T(K) = 1 / [ln(Rt/R₀)/B + 1/T₀]**, wobei - R₀ = 10kΩ - B = 3950 - T₀ = 25°C = 298,15K .. code-block:: c cel = temp - 273.15; Wandelt die Temperatur von Kelvin in Grad Celsius um. .. code-block:: c Fah = cel * 1.8 + 32; Wandelt die Celsius-Temperatur in Fahrenheit um. .. code-block:: c printf("Celsius: %.2f C Fahrenheit: %.2f F\n", cel, Fah); Gibt die Temperatur sowohl in Celsius als auch in Fahrenheit mit zwei Nachkommastellen im Terminal aus.