Vai al contenuto

DHT11 e DHT22

Il sensore DHT11 (o DHT22) è un semplicissimo sensore di input per il calcolo di temperatura e umidità. Il sensore va alimentato e collegato a terra (pin VCC e GND) e poi collegato ad un pin dati di tipo seriale (SDA nel disegno). Il pin NC non va collegato a nulla.

DHT11

Ecco un semplice codice per utilizzare il sensore e calcolare temperatura e umidità dell'aria.

salva questo codice nel file dht.py
import esp

class DHTBase:
    def __init__(self, pin):
        self.pin = pin
        self.buf = bytearray(5)

    def measure(self):
        buf = self.buf
        esp.dht_readinto(self.pin, buf)
        if (buf[0] + buf[1] + buf[2] + buf[3]) & 0xff != buf[4]:
            raise Exception("checksum error")

class DHT11(DHTBase):
    def humidity(self):
        return self.buf[0]

    def temperature(self):
        return self.buf[2]

class DHT22(DHTBase):
    def humidity(self):
        return (self.buf[0] << 8 | self.buf[1]) * 0.1

    def temperature(self):
        t = ((self.buf[2] & 0x7f) << 8 | self.buf[3]) * 0.1
        if self.buf[2] & 0x80:
            t = -t
        return t
Esempio di utilizzo di un sensore DHT11 (oppure DHT22)
from machine import Pin
import dht

# questo in caso di sensore DHT11...
d = dht.DHT11( Pin(4) )
d.measure()
d.temperature() # eg. 23 (°C)
d.humidity()    # eg. 41 (% RH)

# questo per il sensore DHT22...
d = dht.DHT22( Pin(4) )
d.measure()
d.temperature() # eg. 23.6 (°C)
d.humidity()    # eg. 41.3 (% RH)