[[materiels:accueilmateriels|{{ :iconemaison.jpg?nolink&30|Sommaire Matériels}}]] ===== Capteurs - Gaz ===== [Mise à jour le 30/6/2022] ==== 1. Capteurs de CO ==== === 1.1 Généralités === {{ :materiels:capteurs:co.jpg?nolink&80|}} Le **monoxyde de carbone** (**CO**) est un gaz très dangereux qui est inodore, incolore et sans goût. Les symptômes les plus courants de l'intoxication au CO sont les maux de tête, les nausées, les vomissements, les vertiges, la fatigue et une sensation de faiblesse. Les signes neurologiques comprennent la confusion, la désorientation, les troubles visuels, la syncope et les convulsions. Le monoxyde de carbone est produit par l'oxydation partielle de composés contenant du carbone; il se forme lors du fonctionnement d'un poêle ou d'un moteur à combustion interne dans un espace clos. Wikipédia **Ordres de grandeur** ^ ^ ppm ^ |Atmosphère naturelle |0,1 | |Maison |0,5 à 5| |Près d'une gazinière |5 à 15 | |Feu de bois domestique|5000 | ---- === 1.2 Module SEN0132 (MQ7) === {{ :materiels:capteurs:co.png?nolink&150|SEN0132}} * //Source// : wiki Module basé sur le capteur MQ7 permettant de détecter la présence de monoxyde de carbone CO de 20 à 2000 ppm. Haute sensibilité et temps de réponse rapide. La sensibilité est réglable par potentiomètre. * //Distributeur// : Gotronic * //Caractéristiques// * Alimentation: 5 Vcc * Sortie analogique * Temps de réponse rapide et haute sensibilité * Longue durée de vie et bonne stabilité * Dimensions: 37 x 27 x 14 mm {{ :materiels:capteurs:acrobate.gif?nolink&40|}} * //Documentation// * PDF à télécharger ici * Schéma du module {{ :materiels:capteurs:sch_mq-7.png?nolink&400 |}} * //Modèle// {{ :materiels:capteurs:modelemq7.png?nolink |}} {{ :materiels:capteurs:acrobate.gif?nolink&30|}} * //**Aide** pour la **simulation de la chaîne de mesure** // * Les équations de la chaîne de mesure sont téléchargeables ici{{ :materiels:capteurs:excel.png?nolink&30|}} * Le modèle à simuler est téléchargeable ici * L'**Algorithme** du traitement à réaliser est téléchargeable ici * //**Programmation d'une carte Arduino Uno R3**// * //Bibliothèques à installer dans l'IDE// : aucune * //Connexion à un shield// Tinkerkit v2. {{ :materiels:capteurs:mq7.jpg?nolink&600 |}} {{ :materiels:capteurs:distance:arduinoico.png?nolink&50|}} * //Un premier exemple pour tester le capteur// // Arduino Sample Code // Non conforme : A modifier void setup() { Serial.begin(9600); // Set serial baud rate to 9600 bps } void loop() { int val; val=analogRead(0); // Read Gas value from analog 0 Serial.println(val,DEC);// Print the value to serial port delay(100); } ---- ==== 2. Capteurs de CO² ==== * **Ressources** * Why Monitor CO2 Levels in Classrooms ? === 2.1 Généralités === {{ :materiels:capteurs:co2.jpg?nolink&80|}} Le **dioxyde de carbone**, aussi appelé gaz carbonique ou anhydride carbonique, est un composé inorganique dont la formule chimique est CO2, la molécule ayant une structure linéaire de la forme O=C=O. Il se présente, sous les conditions normales de température et de pression, comme un gaz incolore, inodore, à la saveur piquante. Le CO2 est utilisé par l'anabolisme des végétaux pour produire de la biomasse à travers la photosynthèse, processus qui consiste à réduire le dioxyde de carbone par l'eau, grâce à l'énergie lumineuse reçue du soleil et captée par la chlorophylle, en libérant de l'oxygène pour produire des oses, et en premier lieu du glucose par le cycle de Calvin. À partir d'une certaine concentration dans l'air, ce gaz s'avère dangereux, voire mortel. La valeur limite d'exposition est de **3 % sur une durée de 15 minutes**. Cette valeur ne doit jamais être dépassée. Au-delà, les effets sur la santé sont d'autant plus graves que la teneur en CO2 augmente. Près de 87% des émissions de dioxyde de carbone attribuables à l'homme proviennent de la combustion de combustibles fossiles, tels que le charbon, le gaz naturel et le pétrole. Wikipédia Les niveaux de CO2 dans l'air et les problèmes de santé potentiels sont : \\ * **380 - 480 ppm** : taux normal de l'atmosphère * **600 - 800 ppm** : taux correct en lieux fermés * **1000 - 1100 ppm** : taux tolérable en lieux fermés * **1100 - 1400 ppm** : il faut aérer pour assurer une bonne qualité de l'air, si possible. * **2 000 à 5 000 ppm** : niveau associé aux maux de tête, à la somnolence et à l'air stagnant, vicié et étouffant. Une mauvaise concentration, une perte d'attention, une accélération du rythme cardiaque et de légères nausées peuvent également être présentes. * **5000 ppm** : cela indique des conditions atmosphériques inhabituelles où des niveaux élevés d'autres gaz peuvent également être présents. Une toxicité ou une privation d'oxygène pourrait se produire. Il s'agit de la limite d'exposition admissible pour les expositions quotidiennes sur le lieu de travail. * **40 000 ppm** : ce niveau est immédiatement nocif par manque d'oxygène. === 2.2 SEN0159 (MG811) === {{ :materiels:capteurs:mg811.jpg?nolink&150|SEN0159}} * //Source// : wiki Module basé sur le capteur de gaz MG-811 permettant de détecter la présence de CO2. Un booster 6V met le capteur à température permettant une mesure précise. Haute sensibilité et temps de réponse rapide. Le module possède une sortie analogique et une sortie digitale ON/OFF (seuil réglable par potentiomètre). * //Distributeur// : Gotronic * //Caractéristiques// * Alimentation: 5 Vcc * Sorties: une analogique et une digitale * Dimensions: 42 x 32 x 30 mm {{ :materiels:capteurs:acrobate.gif?nolink&40|}} * //Documentation// * PDF à télécharger ici * schéma du module * //Modèle// {{ :materiels:capteurs:modelemg811.png?nolink |}} {{ :materiels:capteurs:acrobate.gif?nolink&30|}} * // **Aide** pour la **simulation de la chaîne de mesure** // * Les équations de la chaîne de mesure sont téléchargeables ici {{ :materiels:capteurs:excel.png?nolink&30|}} * Le modèle à simuler est téléchargeable ici * L'**Algorithme** du traitement à réaliser est téléchargeable ici * //**Programmation d'une carte Arduino Uno R3**// * // Bibliothèques à installer dans l'IDE // : aucune * //Connexion à un shield// Tinkerkit v2. {{ :materiels:capteurs:mg811_2.jpg?nolink&600 |}} {{ :materiels:capteurs:distance:arduinoico.png?nolink&50|}} * // Un premier exemple pour tester le capteur// /*******************Demo for MG-811 Gas Sensor Module V1.1***************************** Author: Tiequan Shao: tiequan.shao@sandboxelectronics.com Peng Wei: peng.wei@sandboxelectronics.com Lisence: Attribution-NonCommercial-ShareAlike 3.0 Unported (CC BY-NC-SA 3.0) Note: This piece of source code is supposed to be used as a demostration ONLY. More sophisticated calibration is required for industrial field application. Sandbox Electronics 2012-05-31 ************************************************************************************/ /************************Hardware Related Macros************************************/ #define MG_PIN (A0) //define which analog input channel you are going to use #define BOOL_PIN (2) #define DC_GAIN (8.5) //define the DC gain of amplifier /***********************Software Related Macros************************************/ #define READ_SAMPLE_INTERVAL (50) //define how many samples you are going to take in normal operation #define READ_SAMPLE_TIMES (5) //define the time interval(in milisecond) between each samples in //normal operation /**********************Application Related Macros**********************************/ //These two values differ from sensor to sensor. user should derermine this value. #define ZERO_POINT_VOLTAGE (0.220) //define the output of the sensor in volts when the concentration of CO2 is 400PPM #define REACTION_VOLTGAE (0.030) //define the voltage drop of the sensor when move the sensor from air into 1000ppm CO2 /*****************************Globals***********************************************/ float CO2Curve[3] = {2.602,ZERO_POINT_VOLTAGE,(REACTION_VOLTGAE/(2.602-3))}; //two points are taken from the curve. //with these two points, a line is formed which is //"approximately equivalent" to the original curve. //data format:{ x, y, slope}; point1: (lg400, 0.324), point2: (lg4000, 0.280) //slope = ( reaction voltage ) / (log400 –log1000) void setup() { Serial.begin(9600); //UART setup, baudrate = 9600bps pinMode(BOOL_PIN, INPUT); //set pin to input digitalWrite(BOOL_PIN, HIGH); //turn on pullup resistors Serial.print("MG-811 Demostration\n"); } void loop() { int percentage; float volts; volts = MGRead(MG_PIN); Serial.print( "SEN0159:" ); Serial.print(volts); Serial.print( "V " ); percentage = MGGetPercentage(volts,CO2Curve); Serial.print("CO2:"); if (percentage == -1) { Serial.print( "<400" ); } else { Serial.print(percentage); } Serial.print( "ppm" ); Serial.print("\n"); if (digitalRead(BOOL_PIN) ){ Serial.print( "=====BOOL is HIGH======" ); } else { Serial.print( "=====BOOL is LOW======" ); } Serial.print("\n"); delay(500); } /***************************** MGRead ********************************************* Input: mg_pin - analog channel Output: output of SEN-000007 Remarks: This function reads the output of SEN-000007 ************************************************************************************/ float MGRead(int mg_pin) { int i; float v=0; for (i=0;i=ZERO_POINT_VOLTAGE) { return -1; } else { return pow(10, ((volts/DC_GAIN)-pcurve[1])/pcurve[2]+pcurve[0]); } } {{ :materiels:capteurs:vscode.png?nolink&40|}} Le projet pour l'IDE **VSCode** de l'exemple ci-dessus est téléchargeable [[https://webge.fr/doc/wikis/code/Arduino/ARD_Uno_CO2_MG811.zip|ici]] === 2.3 Module groove SCD41 - CO², température, pression et humidité === {{ :materiels:capteurs:gaz:183176838.jpg?nolink|}} * //Documentation// : Mouser Le capteur de CO², de température et d'humidité Seeed Studio Grove SCD41 est un capteur multi-fonctions Sensirion qui mesure simultanément la température, la pression, l'humidité et le CO². Le capteur est basé sur le module SCD41 et peut être utilisé dans les appareils GPS, IoT ou tout autre appareil nécessitant quatre paramètres. * //Distributeur// : Mouser * // Caractéristiques // * Alimentation: 2,4V à 5,5 Vcc * Sorties: numérique I2C * Plage de mesure de CO2 : 400 à 5 000 ppm \\ === 2.4 Adafruit SGP30 - Qualité de l'air intérieur === {{ :materiels:capteurs:gaz:sgp30.jpg?nolink&200|}} * //Source// : wiki Le SG30 est capable de détecter une large gamme de composés organiques volatils (COV) et de H2. Il est destiné à la **surveillance de la qualité de l'air intérieur**. * //Distributeur// : Mouser * //Caractéristiques// * Alimentation : 3,3V , 5V * Consommation: < 1,5 mA * Interface : I2C * Connectique : Qwiic * Capteur de Gaz MOX * Plages de mesure * 400 à 60000ppm d'**eCO2** (dioxyde de carbone calculé équivalent, résolution: 11 ppm) * 0 à 60 000ppb de COVT (composé organique volatile total, résolution: 13 ppb) * éthanol: 0 à 1000 ppm (précision: 15%, résolution: 0,2 %) * H2: 0 à 1000 ppm (précision: 10%, résolution: résolution: 0,2 %) * Temps de chauffe: < 15 sec * Interface : I2C * Adresse: 0x58 {{ :materiels:capteurs:acrobate.gif?nolink&40|}} * //Documentation// \\ * PDF à télécharger ici * //Bibliothèque à télécharger dans l'IDE// {{ :materiels:capteurs:gaz:sgp30lib.jpg?nolink |}} {{ :materiels:capteurs:distance:arduinoico.png?nolink&40|}} * **Un premier exemple pour tester le capteur avec l'IDE Arduino** \\ -> Fichier -> Exemples -> Adafruit SGP30 Sensor -> **sgp30test.ino** * **Mise en oeuvre du capteur avec un afficheur OLED** * //Description// : mesure de CO² et COVT à l'aide d'un capteur adafruit SGP30, test des boutons-poussoirs et affichage sur un écran Oled Adafruit SH1107. L'écran et le capteur sont reliés via le système Qwiic de Sparkfun. {{ :materiels:capteurs:gaz:sgp30esp.jpg?nolink&600 |}} * //Matériels// * Carte à microcontrôleur : [[arduino:uc:esp8266|Adafruit Feather Huzzah ESP8266 + Support Particle]] * Afficheur : [[materiels:afficheurs:ada1107|Adafruit OLED SH1107]] * //Code Arduino// {{ :materiels:capteurs:distance:arduinoico.png?nolink&40|}} // Matériels : Adafruit Feather Huzzah ESP8266 + Support Particle, Adafruit OLED SH1107, Adafruit SGP30, câble Qwiic. // Logiciel : Arduino // A ajouter #include #include #include #include #include "Adafruit_SGP30.h" #define BUTTON_A 0 #define BUTTON_B 16 #define BUTTON_C 2 // Constructeurs Adafruit_SH1107 display = Adafruit_SH1107(64, 128, &Wire); Adafruit_SGP30 sgp; void setup() { // Bus I2C Wire.begin(); // Initialisation Wire.setClock(400000); display.begin(0x3C, true); // L'adresse de l'afficheur est 0x3C par défaut // Configuration de l'affichage display.setRotation(1); // Affichage horizontal display.setTextSize(1); display.setTextColor(SH110X_WHITE); display.clearDisplay(); // Pour ne pas afficher le logo Adafruit chargé // automatiquement à la mise sous tension // Test de la communication avec le capteur if (!sgp.begin()) { display.println("Le capteur de repond pas"); while (1) ; } display.print("Numero de serie #"); display.print(sgp.serialnumber[0], HEX); display.print(sgp.serialnumber[1], HEX); display.println(sgp.serialnumber[2], HEX); display.display(); // Transfert du buffer sur l'écran delay(2000); // Connexion des boutons-poussoirs pinMode(BUTTON_A, INPUT_PULLUP); pinMode(BUTTON_B, INPUT_PULLUP); pinMode(BUTTON_C, INPUT_PULLUP); } void loop() { // Efface le buffer display.clearDisplay(); // Test des boutons display.setCursor(0, 0); if (!digitalRead(BUTTON_A)) display.print("[A]"); if (!digitalRead(BUTTON_B)) display.print("[B]"); if (!digitalRead(BUTTON_C)) display.print("[C]"); // Titre display.setCursor(40, 0); display.println("SGP30"); // Numéro de série display.setCursor(0, 12); display.print("Numero : #"); display.print(sgp.serialnumber[0], HEX); display.print(sgp.serialnumber[1], HEX); display.println(sgp.serialnumber[2], HEX); // Mesures if (!sgp.IAQmeasure()) { Serial.println("Measurement failed"); return; } // Mesures et affichage display.print("TVOC : "); display.print(sgp.TVOC); display.println(" ppb"); display.print("eCO2 : "); display.print(sgp.eCO2); display.println(" ppm"); // Infos display.setCursor(5, 52); display.print("Appuyer sur A, B, C"); display.display(); // Transfert du buffer sur l'écran delay(500); } {{ :arduino:uc:platformioico.png?nolink&50|}} Télécharger le projet PlatformIO pour VSCode. ==== Pour aller plus loin ... === * **Exemple de projet** \\ Surveillance des niveaux de CO2 et contrôle du débit d'air à l'aide du terminal Wio