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.

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)