Mesure de la température et de l'humidité avec HDC1000 et Raspberry Pi : 4 étapes
Mesure de la température et de l'humidité avec HDC1000 et Raspberry Pi : 4 étapes
Anonim
Image
Image

Le HDC1000 est un capteur d'humidité numérique avec capteur de température intégré qui offre une excellente précision de mesure à très faible puissance. L'appareil mesure l'humidité sur la base d'un nouveau capteur capacitif. Les capteurs d'humidité et de température sont étalonnés en usine. Il est fonctionnel dans toute la plage de température de -40°C à +125°C.

Dans ce tutoriel, l'interfaçage du module capteur HDC1000 avec raspberry pi est démontré et sa programmation en langage python a également été illustrée. Pour lire les valeurs de température et d'humidité, nous avons utilisé raspberry pi avec un adaptateur I2C. Cet adaptateur I2C rend la connexion au module capteur facile et plus fiable.

Étape 1: Matériel requis:

Matériel requis
Matériel requis
Matériel requis
Matériel requis
Matériel requis
Matériel requis

Les matériaux dont nous avons besoin pour atteindre notre objectif comprennent les composants matériels suivants:

1. HDC1000

2. Framboise Pi

3. Câble I2C

4. Bouclier I2C pour framboise pi

5. Câble Ethernet

Étape 2: connexion matérielle:

Raccordement matériel
Raccordement matériel
Raccordement matériel
Raccordement matériel

La section de raccordement matériel explique essentiellement les connexions de câblage requises entre le capteur et le raspberry pi. Assurer des connexions correctes est la nécessité de base tout en travaillant sur n'importe quel système pour la sortie souhaitée. Ainsi, les connexions requises sont les suivantes:

Le HDC1000 fonctionnera sur I2C. Voici l'exemple de schéma de câblage, montrant comment câbler chaque interface du capteur.

Prête à l'emploi, la carte est configurée pour une interface I2C, en tant que telle, nous vous recommandons d'utiliser cette connexion si vous êtes par ailleurs agnostique.

Tout ce dont vous avez besoin, c'est de quatre fils ! Seules quatre connexions sont nécessaires pour les broches Vcc, Gnd, SCL et SDA et celles-ci sont connectées à l'aide d'un câble I2C.

Ces connexions sont illustrées dans les images ci-dessus.

Étape 3: Code pour la mesure de la température et de l'humidité:

Code pour la mesure de la température et de l'humidité
Code pour la mesure de la température et de l'humidité

L'avantage d'utiliser raspberry pi est qu'il vous offre la flexibilité du langage de programmation dans lequel vous souhaitez programmer la carte afin d'interfacer le capteur avec elle. En exploitant cet avantage de cette carte, nous démontrons ici sa programmation en python. Le code python pour HDC1000 peut être téléchargé depuis notre communauté GitHub qui est Dcube Store.

En plus de la facilité des utilisateurs, nous expliquons le code ici également:

Comme première étape de codage, vous devez télécharger la bibliothèque SMBus dans le cas de python, car cette bibliothèque prend en charge les fonctions utilisées dans le code. Donc, pour télécharger la bibliothèque, vous pouvez visiter le lien suivant:

pypi.python.org/pypi/smbus-cffi/0.5.1

Vous pouvez également copier le code python fonctionnel de ce capteur à partir d'ici:

importer smbus

heure d'importation

# Obtenez le bus I2C

bus = smbus. SMbus(1)

# Adresse HDC1000, 0x40(64)

# Sélectionnez le registre de configuration, 0x02(02)

# 0x30(48) Température, Humidité activée, Résolution = 14 bits, Chauffage allumé

bus.write_byte_data (0x40, 0x02, 0x30)

# Adresse HDC1000, 0x40(64)

# Envoyer la commande de mesure de température, 0x00(00)

bus.write_byte (0x40, 0x00)

temps.sommeil (0,5)

# Adresse HDC1000, 0x40(64)

# Relire les données, 2 octets

# temp MSB, temp LSB

data0 = bus.read_byte (0x40)

data1 = bus.read_byte (0x40)

# Convertir les données

temp = (données0 * 256) + données1

cTemp = (temp / 65536.0) * 165.0 - 40

fTemp = cTemp * 1,8 + 32

# Adresse HDC1000, 0x40(64)

# Envoyer la commande de mesure d'humidité, 0x01(01)

bus.write_byte (0x40, 0x01)

temps.sommeil (0,5)

# Adresse HDC1000, 0x40(64)

# Relire les données, 2 octets

# humidité MSB, humidité LSB

data0 = bus.read_byte (0x40)

data1 = bus.read_byte (0x40)

# Convertir les données

humidité = (données0 * 256) + données1

humidité = (humidité / 65536.0) * 100.0

# Données de sortie à l'écran

print "Humidité relative: %.2f %%" %humidité

print "Température en Celsius: %.2f C" %cTemp

print "Température en Fahrenheit: %.2f F" %fTemp

La partie de code mentionnée ci-dessous comprend les bibliothèques nécessaires à la bonne exécution des codes python.

importer smbus

heure d'importation

Le code peut être exécuté en tapant la commande mentionnée ci-dessous dans l'invite de commande.

$> python HDC1000.py gt; python HDC1000.py

La sortie du capteur est également indiquée dans l'image ci-dessus pour la référence de l'utilisateur.

Étape 4: Candidatures:

Applications
Applications

HDC1000 peut être utilisé dans le chauffage, la ventilation et la climatisation (CVC), les thermostats intelligents et les moniteurs de pièce. Ce capteur trouve également son application dans les imprimantes, les compteurs portables, les dispositifs médicaux, l'expédition de fret ainsi que le désembuage de pare-brise automobile.