.. note:: ¡Hola! Bienvenidos a la Comunidad de Entusiastas de SunFounder Raspberry Pi, Arduino y ESP32 en Facebook. Profundiza en Raspberry Pi, Arduino y ESP32 con otros entusiastas. **¿Por qué unirte?** - **Soporte de Expertos**: Resuelve problemas post-venta y desafíos técnicos con la ayuda de nuestra comunidad y equipo. - **Aprende y Comparte**: Intercambia consejos y tutoriales para mejorar tus habilidades. - **Previsualizaciones Exclusivas**: Obtén acceso anticipado a nuevos anuncios de productos y adelantos. - **Descuentos Especiales**: Disfruta de descuentos exclusivos en nuestros productos más recientes. - **Promociones Festivas y Sorteos**: Participa en sorteos y promociones de temporada. 👉 ¿Listo para explorar y crear con nosotros? Haz clic en [|link_sf_facebook|] y únete hoy mismo! .. _2.2.3_c_pi5: 2.2.3 DHT-11 ================== Introducción -------------- El sensor digital de temperatura y humedad DHT11 es un sensor compuesto que contiene una salida de señal digital calibrada de temperatura y humedad. Se aplican la tecnología de módulos digitales dedicados y la tecnología de detección de temperatura y humedad para asegurar que el producto tenga alta fiabilidad y excelente estabilidad. Los sensores incluyen un sensor resistivo de elemento húmedo y un sensor de temperatura NTC y están conectados a un microcontrolador de alto rendimiento de 8 bits. Componentes Necesarios ------------------------------ En este proyecto, necesitamos los siguientes componentes. .. image:: ../img/list_2.2.3_dht-11.png Es definitivamente conveniente comprar un kit completo, aquí está el enlace: .. list-table:: :widths: 20 20 20 :header-rows: 1 * - Nombre - ELEMENTOS EN ESTE KIT - ENLACE * - Kit Raphael - 337 - |link_Raphael_kit| También puedes comprarlos por separado en los siguientes enlaces. .. list-table:: :widths: 30 20 :header-rows: 1 * - INTRODUCCIÓN DEL COMPONENTE - ENLACE DE COMPRA * - :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_humiture_sensor` - |link_humiture_buy| Diagrama Esquemático ------------------------ .. image:: ../img/image326.png Procedimientos Experimentales ----------------------------------- **Paso 1:** Construir el circuito. .. image:: ../img/image207.png **Paso 2:** Ir a la carpeta del código. .. raw:: html .. code-block:: cd ~/raphael-kit/c/2.2.3/ **Paso 3:** Compilar el código. .. raw:: html .. code-block:: gcc 2.2.3_DHT.c -lwiringPi **Paso 4:** Ejecutar el archivo compilado. .. raw:: html .. code-block:: sudo ./a.out Después de ejecutar el código, el programa imprimirá en la pantalla de la computadora la temperatura y humedad detectadas por el DHT11. .. note:: Si no funciona después de ejecutar, o aparece un mensaje de error: "wiringPi.h: No such file or directory", por favor consulta :ref:`install_wiringpi_pi5`. **Código** .. code-block:: c #include #include #include #include #define MAXTIMINGS 85 // Maximum number of timing transitions int dht11_dat[5] = {0, 0, 0, 0, 0}; // Data array to hold sensor values // Function to read data from DHT11 sensor void read_dht11_dat(int GPIOPIN) { uint8_t currState; uint8_t laststate = HIGH; uint8_t counter = 0; uint8_t j = 0; uint8_t i; float f; // Temperature in Fahrenheit // Reset data array before each read dht11_dat[0] = dht11_dat[1] = dht11_dat[2] = dht11_dat[3] = dht11_dat[4] = 0; // Pull pin down for 18 milliseconds to initiate communication pinMode(GPIOPIN, OUTPUT); digitalWrite(GPIOPIN, LOW); delay(18); // Then pull it up for 40 microseconds digitalWrite(GPIOPIN, HIGH); delayMicroseconds(40); // Prepare to read the pin pinMode(GPIOPIN, INPUT); // Detect change and read data for (i = 0; i < MAXTIMINGS; i++) { counter = 0; // Count how long each state lasts while (digitalRead(GPIOPIN) == laststate) { counter++; delayMicroseconds(2); if (counter == 255) { break; } } // Save the current state laststate = digitalRead(GPIOPIN); if (counter == 255) break; // Ignore first 3 transitions (DHT11 response signal) if ((i >= 4) && (i % 2 == 0)) { // Shift bits and store data dht11_dat[j/8] <<= 1; if (counter > 16) { dht11_dat[j/8] |= 1; } j++; } } // Check if we received 40 bits (5 bytes) and verify checksum if ((j >= 40) && (dht11_dat[4] == ((dht11_dat[0] + dht11_dat[1] + dht11_dat[2] + dht11_dat[3]) & 0xFF)) ) { // Convert temperature to Fahrenheit f = dht11_dat[2] * 9.0 / 5.0 + 32; printf("Humidity = %d.%d %% Temperature = %d.%d °C (%.1f °F)\n", dht11_dat[0], dht11_dat[1], dht11_dat[2], dht11_dat[3], f); } else { printf("Data not good, skip\n"); } } int main (void) { printf("Raspberry Pi wiringPi DHT11 Temperature test program\n"); // Initialize wiringPi using BCM GPIO pin numbering if (wiringPiSetupGpio() == -1) { exit(1); } while(1) { // Read data from DHT11 connected to GPIO pin 17 read_dht11_dat(17); delay(1000); // Wait 1 second before next read } return 0; } **Explicación del Código** #. Incluir Cabeceras: El código incluye las cabeceras necesarias para las funciones de wiringPi y de entrada/salida estándar. .. code-block:: C #include #include #include #include #. Definir Constantes: * ``MAXTIMINGS``: El número máximo de transiciones de tiempo esperadas del sensor DHT11 (85). .. code-block:: C #define MAXTIMINGS 85 // Número máximo de transiciones de tiempo #. Arreglo de Datos Global: * ``dht11_dat[5]``: Un arreglo para almacenar los 5 bytes de datos recibidos del sensor DHT11. .. code-block:: C int dht11_dat[5] = {0, 0, 0, 0, 0}; // Arreglo de datos para almacenar los valores del sensor #. Función ``read_dht11_dat(int GPIOPIN)``: Lee los datos del sensor DHT11 conectado al pin GPIO especificado. * Inicialización: Reinicia el arreglo dht11_dat a cero antes de cada lectura. .. code-block:: C dht11_dat[0] = dht11_dat[1] = dht11_dat[2] = dht11_dat[3] = dht11_dat[4] = 0; * Señal de Inicio: Pone el pin GPIO en bajo durante al menos 18 milisegundos para señalar al DHT11 que comience a enviar datos. .. code-block:: C pinMode(GPIOPIN, OUTPUT); digitalWrite(GPIOPIN, LOW); delay(18); // 18 milisegundos * Coloca el pin GPIO en alto durante 40 microsegundos. .. code-block:: C digitalWrite(GPIOPIN, HIGH); delayMicroseconds(40); // 40 microsegundos * Configura el pin GPIO en modo de entrada para leer los datos del sensor. .. code-block:: C pinMode(GPIOPIN, INPUT); * Bucle de Lectura de Datos: El bucle se ejecuta hasta MAXTIMINGS veces para leer los bits de datos. Para cada transición (de alto a bajo o de bajo a alto), mide cuánto tiempo el pin permanece en cada estado. .. code-block:: C for (i = 0; i < MAXTIMINGS; i++) { counter = 0; while (digitalRead(GPIOPIN) == laststate) { counter++; delayMicroseconds(2); if (counter == 255) { break; } } laststate = digitalRead(GPIOPIN); // ... resto del bucle } * Extracción de Bits de Datos: Las primeras 3 transiciones se ignoran ya que son parte de la señal de respuesta inicial del DHT11. Para cada bit de datos, determina si el bit es 0 o 1 según la duración en la que el pin permanece alto. .. code-block:: C if ((i >= 4) && (i % 2 == 0)) { dht11_dat[j/8] <<= 1; if (counter > 16) { dht11_dat[j/8] |= 1; } j++; } * Verificación de la Suma de Verificación: Después de recibir todos los bits, el código verifica la suma de verificación para asegurar la integridad de los datos. .. code-block:: C if ((j >= 40) && (dht11_dat[4] == ((dht11_dat[0] + dht11_dat[1] + dht11_dat[2] + dht11_dat[3]) & 0xFF)) ) * Si la suma de verificación es correcta, muestra los valores de humedad y temperatura. .. code-block:: C f = dht11_dat[2] * 9.0 / 5.0 + 32; printf("Humedad = %d.%d %% Temperatura = %d.%d °C (%.1f °F)\n", dht11_dat[0], dht11_dat[1], dht11_dat[2], dht11_dat[3], f); * Si la suma de verificación falla, imprime un mensaje de error. .. code-block:: C else { printf("Datos incorrectos, omitir\n"); } #. Función Principal (Main): * Imprime un mensaje de inicio. .. code-block:: C printf("Programa de prueba de temperatura DHT11 para Raspberry Pi con wiringPi\n"); * Inicializa wiringPi usando la numeración de pines GPIO de BCM. .. code-block:: C if (wiringPiSetupGpio() == -1) { exit(1); } * Entra en un bucle infinito para leer datos del sensor DHT11 cada segundo. .. code-block:: C while(1) { read_dht11_dat(17); delay(1000); // esperar 1 segundo } Imagen del Fenómeno ------------------------------ .. image:: ../img/image209.jpeg