.. note:: Bonjour, bienvenue dans la communauté SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasts sur Facebook ! Approfondissez vos connaissances sur Raspberry Pi, Arduino et ESP32 avec d’autres passionnés. **Pourquoi rejoindre ?** - **Support d’experts** : Résolvez les problèmes après‑vente et les défis techniques avec l’aide de notre communauté et de notre équipe. - **Apprendre et partager** : Échangez des astuces et des tutoriels pour améliorer vos compétences. - **Aperçus exclusifs** : Accédez en avant‑première aux annonces de nouveaux produits et aux aperçus. - **Réductions spéciales** : Profitez de réductions exclusives sur nos tout derniers produits. - **Promotions et cadeaux festifs** : Participez à des concours et promotions spéciales pendant les fêtes. 👉 Prêt à explorer et à créer avec nous ? Cliquez sur [|link_sf_facebook|] et rejoignez‑nous dès aujourd’hui ! .. _2.2.2_c_pi5_mcp3008: 2.2.2 Thermistance (MCP3008) ============================ .. note:: .. image:: ../img/mcp3008_and_adc0834.jpg :width: 25% :align: left Selon la version de votre kit, identifiez si vous disposez d’un **ADC0834** ou d’un **MCP3008** et suivez la section correspondante. Introduction ------------ Tout comme une photorésistance peut détecter la lumière, une thermistance est un composant électronique sensible à la température, pouvant être utilisée pour réaliser des fonctions de contrôle thermique, comme un dispositif d’alarme de surchauffe. Composants requis ----------------- Dans ce projet, nous avons besoin des composants suivants : .. image:: ../img/list2_2.2.2_thermistor.png Il est bien sûr pratique d’acheter un kit complet, voici le lien : .. list-table:: :widths: 20 20 20 :header-rows: 1 * - Nom - ÉLÉMENTS DANS CE KIT - LIEN * - Kit Raphael - 337 - |link_Raphael_kit| Vous pouvez également les acheter séparément via les liens ci‑dessous. .. list-table:: :widths: 30 20 :header-rows: 1 * - INTRODUCTION DU COMPOSANT - LIEN D’ACHAT * - :ref:`cpn_gpio_extension_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` - \- Schéma de câblage ----------------- .. list-table:: :widths: 30 30 30 30 :header-rows: 1 * - Nom T‑Board - Physique - 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 Procédures expérimentales ------------------------- **Étape 1 :** Construisez le circuit. .. image:: ../img/july24_2.2.2_thermistor_mcp3008.png **Étape 2 :** Accédez au dossier du code. .. raw:: html .. code-block:: cd ~/raphael-kit/c/2.2.2-2/ **Étape 3 :** Compilez le code. .. raw:: html .. code-block:: gcc 2.2.2_Thermistor.c -o Thermistor -lwiringPi -lm .. note:: -lm permet de charger la bibliothèque mathématique. Ne l’omettez pas, sinon une erreur se produira. **Étape 4 :** Exécutez le fichier exécutable. .. raw:: html .. code-block:: ./Thermistor Une fois le programme exécuté, la thermistance détecte la température ambiante, qui sera affichée à l’écran après le calcul du programme. .. note:: Si cela ne fonctionne pas après l’exécution ou si un message d’erreur apparaît : « wiringPi.h: No such file or directory », veuillez vous référer à :ref:`install_wiringpi_pi5`. Code ---- .. code-block:: c #include #include #include #include #define SPI_CHANNEL 0 // CE0 #define SPI_SPEED 1000000 // 1 MHz int read_ADC(int channel) { if (channel < 0 || channel > 7) return -1; unsigned char buffer[3]; buffer[0] = 1; // Bit de démarrage buffer[1] = (8 + channel) << 4; // Mode simple + canal 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("Échec de l’initialisation de wiringPi !\n"); return 1; } if (wiringPiSPISetup(SPI_CHANNEL, SPI_SPEED) == -1) { printf("Échec de l’initialisation du SPI !\n"); return 1; } while (1) { analogVal = read_ADC(0); // Lecture depuis CH0 // MCP3008 est un ADC 10 bits (0–1023) Vr = 3.3 * analogVal / 1023.0; // Suppose Vref = 3,3 V Rt = 10000.0 * Vr / (3.3 - Vr); // Diviseur de tension, résistance de 10 kΩ 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; } Explication du code ------------------- .. code-block:: c #include #include #include #include Ces fichiers d’en‑tête incluent les bibliothèques pour le contrôle des GPIO (``wiringPi.h``), la communication SPI (``wiringPiSPI.h``), les opérations d’E/S standard (``stdio.h``) et les fonctions mathématiques (``math.h``) en C. .. code-block:: c #define SPI_CHANNEL 0 #define SPI_SPEED 1000000 Définit les constantes pour le canal SPI et la vitesse de communication. Ici, le canal SPI 0 (CE0) et une fréquence d’horloge de 1 MHz sont utilisés. .. code-block:: c int read_ADC(int channel) Cette fonction lit les données analogiques d’un canal spécifié du convertisseur analogique‑numérique MCP3008. .. code-block:: c buffer[0] = 1; buffer[1] = (8 + channel) << 4; buffer[2] = 0; Ces lignes formatent la commande SPI selon le protocole du MCP3008 : bit de démarrage, configuration en mode simple et numéro de canal. .. code-block:: c wiringPiSPIDataRW(SPI_CHANNEL, buffer, 3); Transfère la commande SPI et reçoit la donnée ADC 10 bits du MCP3008. .. code-block:: c int value = ((buffer[1] & 3) << 8) | buffer[2]; Extrait et combine le résultat 10 bits de la mémoire tampon SPI renvoyée. .. code-block:: c if (wiringPiSetup() == -1) { ... } if (wiringPiSPISetup(SPI_CHANNEL, SPI_SPEED) == -1) { ... } Ces lignes initialisent WiringPi et configurent le SPI. Si l’initialisation échoue, le programme se termine. .. code-block:: c analogVal = read_ADC(0); Lit le signal analogique du canal 0 du MCP3008, où est connecté le pont diviseur avec la thermistance. .. code-block:: c Vr = 3.3 * analogVal / 1023.0; Convertit la valeur numérique ADC en tension analogique. La plage de l’ADC est de 0–1023 avec une tension de référence de 3,3 V. .. code-block:: c Rt = 10000.0 * Vr / (3.3 - Vr); Calcule la résistance de la thermistance en utilisant la formule du diviseur de tension. Une résistance de 10 kΩ est supposée en série avec la thermistance. .. code-block:: c temp = 1 / ((log(Rt / 10000.0) / 3950.0) + (1 / (273.15 + 25.0))); Utilise l’équation B‑paramètre pour convertir la résistance de la thermistance en température (Kelvin). **T(K) = 1 / [ln(Rt/R₀)/B + 1/T₀]**, où - R₀ = 10 kΩ - B = 3950 - T₀ = 25 °C = 298,15 K .. code-block:: c cel = temp - 273.15; Convertit la température de Kelvin en degrés Celsius. .. code-block:: c Fah = cel * 1.8 + 32; Convertit la température Celsius en Fahrenheit. .. code-block:: c printf("Celsius : %.2f °C Fahrenheit : %.2f °F\n", cel, Fah); Affiche la température en Celsius et en Fahrenheit sur le terminal avec une précision de 2 décimales.