====== Датчик температуры и влажности (Troyka-модуль) ====== [[amp>product/troyka-temperature-humidity-sensor-dht11|Датчик температуры и влажности]] способен определять температуру и влажность окружающей среды. {{ :продукты:troyka-dht11:dht11_overview.jpg?nolink&700 |}} ===== Подключение и настройка ===== Датчик общается с управляющей электроникой по трём проводам. При подключении к [[amp>collection/arduino?utm_source=man&utm_campaign=troyka-dht11&utm_medium=wiki|Arduino]] или [[amp>product/iskra-js?utm_source=man&utm_campaign=troyka-dht11&utm_medium=wiki|Iskra JS]] удобно использовать [[amp>/product/arduino-troyka-shield?utm_source=man&utm_campaign=troyka-dht11&utm_medium=wiki|Troyka Shield]]. {{ :продукты:troyka-dht11:troyka-temperature-humidity-sensor-dht11_scheme_troyka-shield.png |}} С [[amp>product/arduino-troyka-slot-shield?utm_source=man&utm_campaign=troyka-dht11&utm_medium=wiki|Troyka Slot Shield]] можно обойтись без лишних проводов.{{ :продукты:troyka-dht11:troyka-temperature-humidity-sensor-dht11_scheme_troyka-slot-shield.png |}} ===== Примеры работы ===== Рассмотрим примеры работы датчика температуры и влажности DHT11 в зависимости от управляющей платформы. ==== Пример для Arduino ==== В качестве примера выведем в Serial-порт текущее значение температуры и влажности. Для запуска примера скачайте и установите библиотеку [[https://github.com/amperka/TroykaDHT|TroykaDHT]]. // библиотека для работы с датчиками серии DHT #include // создаём объект класса DHT // передаём номер пина к которому подключён датчик и тип датчика // типы сенсоров: DHT11, DHT21, DHT22 DHT dht(4, DHT11); void setup() { // открываем последовательный порт для мониторинга действий в программе Serial.begin(9600); dht.begin(); } void loop() { // считывание данных с датчика dht.read(); // проверяем состояние данных switch(dht.getState()) { // всё OK case DHT_OK: // выводим показания влажности и температуры Serial.print("Temperature = "); Serial.print(dht.getTemperatureC()); Serial.println(" C \t"); Serial.print("Temperature = "); Serial.print(dht.getTemperatureK()); Serial.println(" K \t"); Serial.print("Temperature = "); Serial.print(dht.getTemperatureF()); Serial.println(" F \t"); Serial.print("Humidity = "); Serial.print(dht.getHumidity()); Serial.println(" %"); break; // ошибка контрольной суммы case DHT_ERROR_CHECKSUM: Serial.println("Checksum error"); break; // превышение времени ожидания case DHT_ERROR_TIMEOUT: Serial.println("Time out error"); break; // данных нет, датчик не реагирует или отсутствует case DHT_ERROR_NO_REPLY: Serial.println("Sensor not connected"); break; } // ждём две секунды delay(2000); } ==== Пример для Iskra JS ==== Выведем данные температуры и влажности в консоль Espruino Web IDE. // подключаем библиотеку DHT11 и создаём объект для работы с датчиком var dht = require("DHT11").connect(P4); // считываем данные с датчика // выводим показания температуры и влажности в консоль dht.read(function (a) { console.log("Temp is "+a.temp.toString()+" and RH is "+a.rh.toString()); }); ===== Протокол датчика DHT ===== Выходом датчика является [[сенсоры:цифровые|цифровой сигнал]]. Температура и влажность передаются по одному сигнальному проводу (''S''). DHT11 общается с принимающей стороной, такой как [[amp>collection/Platy/product/Arduino-Uno|Arduino]] по собственному протоколу. Коммуникация двунаправлена и в общих чертах выглядит так: - Микроконтроллер говорит о том, что хочет считать показания. Для этого он устанавливает сигнальную линию в 0 на некоторое время, а затем устанавливает её в 1 - Сенсор подтверждает готовность отдать данные. Для этого он аналогично сначала устанавливает сигнальную линию в 0, затем в 1 - После этого сенсор передаёт последовательность 0 и 1, последовательно формирующих 5 байт (40 бит). В первых двух байтах передаётся температура, в третьем-четвёртом — влажность, в пятом — контрольная сумма, чтобы микроконтроллер смог убедиться в отсутствии ошибок считывания Благодаря тому, что сенсор делает измерения только по запросу, достигается энергоэффективность: пока общения нет, датчик потребляет ток 100 мкА. ===== Элементы платы ===== {{ :продукты:troyka-dht11:troyka-temperature-humidity-sensor-dht11_annotation.png |}} ==== Датчик DHT11 ==== Цифровой датчик DHT11 является составным датчиком, который выдаёт калиброванный цифровой сигнал с показаниями температуры и влажности. Сенсор включает в себя резистивный компонент измерения влажности и компонент измерения температуры с отрицательным температурным коэффициентом (NTC), которые подключены к высокопроизводительному 8-битному микроконтроллеру. Каждый датчик DHT11 проходит калибровку на заводе изготовителе. Коэффициенты калибровки хранятся в однократно программируемой энергонезависимой памяти и используются во внутренних процессах обработки сигнала. ==== Контакты подключения 3-проводного шлейфа ==== Модуль подключается к управляющей электронике по [[сенсоры:3-провода|трём проводам]]. Назначение контактов 3-проводного шлейфа: * Питание (''V'') — красный провод. На него должно подаваться напряжение питания от 3,3 до 5 В; * Земля (''G'') — чёрный провод. Должен быть соединён с землёй микроконтроллера; * Сигнальный (''S'') — жёлтый провод. Подключается к цифровому выходу микроконтроллера. Через него сенсор общается с микроконтроллером по собственному протоколу. ===== Характеристики ===== * Напряжение питания: 3,3–5 В * Потребляемый ток: * в режиме запроса данных: 2,5 мА * в режиме покоя: 100 мкА * Диапазон измеряемой температуры: 0–50 °С * Погрешность температуры: ±2 °С * Диапазон влажности: 20–90% * Погрешность влажности: ±5% * Габариты: 25×25 мм