2024-05-21 21:48:35 +03:00
|
|
|
|
# Работа с DHT11 и DHT22 на Wemos D1 Mini (и других)
|
|
|
|
|
|
2024-05-23 23:57:03 +03:00
|
|
|
|
## Подготовка платы и прошивка
|
2024-05-21 21:48:35 +03:00
|
|
|
|
|
|
|
|
|
### Предисловие о файле прошивки
|
|
|
|
|
|
|
|
|
|
По состоянию на 21 мая 2024 года на сайте
|
|
|
|
|
[MicroPython](https://micropython.org/download/?vendor=Wemos)
|
|
|
|
|
в разделе загрузок прошивка для **D1 Mini** отсутствовала.
|
|
|
|
|
|
|
|
|
|
По первой ссылке в поисковике увидел название файла прошивки
|
|
|
|
|
`esp8266-20190125-v1.10.bin` по следующей ссылке
|
|
|
|
|
http://micropython.org/resources/firmware/esp8266-20190125-v1.10.bin
|
|
|
|
|
(http://micropython.org/download#esp8266).
|
|
|
|
|
|
|
|
|
|
Я не стал скачивать предлооженный старый бинарник
|
|
|
|
|
и скачал слежую версию для [ESP8266 GENERIC](https://micropython.org/download/ESP8266_GENERIC/):
|
|
|
|
|
https://micropython.org/resources/firmware/ESP8266_GENERIC-20240222-v1.22.2.bin
|
|
|
|
|
|
|
|
|
|
### Прошивка платы
|
|
|
|
|
|
|
|
|
|
Для манупуляций необходима утилита `esptool.py`.
|
|
|
|
|
В репозиториях Arch Linux она имеется.
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
pacman -Qi esptool
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
```text
|
|
|
|
|
Name : esptool
|
|
|
|
|
Version : 4.7.0-3
|
|
|
|
|
Description : A cute Python utility to communicate with the ROM bootloader in Espressif ESP8266
|
|
|
|
|
Architecture : any
|
|
|
|
|
URL : https://github.com/espressif/esptool
|
|
|
|
|
Licenses : GPL-2.0-only
|
|
|
|
|
...
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
`esptool` также можно установить с помощью **pip**.
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
pip3 install esptool
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Перед прошивкой новой прошивки необходиимо очистить память устройста,
|
|
|
|
|
выполнив следующую команду (`/dev/ttyUSB0` <- порт устройства).
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
esptool.py --port /dev/ttyUSB0 erase_flash
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
По окончанию зашиваем новую прошивку.
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
esptool.py \
|
|
|
|
|
--port /dev/ttyUSB0 \
|
|
|
|
|
--baud 115200 write_flash \
|
|
|
|
|
--flash_size=detect 0 \
|
|
|
|
|
/home/user/Downloads/ESP8266_GENERIC-20240222-v1.22.2.bin
|
|
|
|
|
```
|
|
|
|
|
|
2024-05-23 23:57:03 +03:00
|
|
|
|
## Обеспечиваем удобство взаимодействия
|
2024-05-21 21:48:35 +03:00
|
|
|
|
|
|
|
|
|
D1 Mini имеет на борту UART преобразователь на чипе `CH34x`.
|
|
|
|
|
|
|
|
|
|
Подключиться к устройству можно с помощью утилит `screen` или `minicon` (и ещё сотню других),
|
|
|
|
|
но более удобней будет работать с помощью `mpremote`.
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
pip3 install mpremote
|
|
|
|
|
```
|
|
|
|
|
|
2024-05-23 23:57:03 +03:00
|
|
|
|
### mpremote
|
|
|
|
|
|
2024-05-21 21:48:35 +03:00
|
|
|
|
`mpremote` - это специальная утилита для взаимодействия с платой на MicroPython.
|
|
|
|
|
|
|
|
|
|
Вот неполный листинг справки.
|
|
|
|
|
|
|
|
|
|
```text
|
|
|
|
|
premote --help
|
|
|
|
|
mpremote -- MicroPython remote control
|
|
|
|
|
See https://docs.micropython.org/en/latest/reference/mpremote.html
|
|
|
|
|
|
|
|
|
|
List of commands:
|
|
|
|
|
connect connect to given device
|
|
|
|
|
disconnect disconnect current device
|
|
|
|
|
edit edit files on the device
|
|
|
|
|
eval evaluate and print the string
|
|
|
|
|
exec execute the string
|
|
|
|
|
fs execute filesystem commands on the device
|
|
|
|
|
help print help and exit
|
|
|
|
|
mip install packages from micropython-lib or third-party sources
|
|
|
|
|
mount mount local directory on device
|
|
|
|
|
repl connect to given device
|
|
|
|
|
resume resume a previous mpremote session (will not auto soft-reset)
|
|
|
|
|
rtc get (default) or set the device RTC
|
|
|
|
|
run run the given local script
|
|
|
|
|
sleep sleep before executing next command
|
|
|
|
|
soft-reset perform a soft-reset of the device
|
|
|
|
|
umount unmount the local directory
|
|
|
|
|
version print version and exit
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Сочетание клавиш `Ctrl+D` вызывает мягкую перезагрузку (`MPY: soft reboot`).
|
|
|
|
|
Сочетание клавиш `Ctrl+X` закрывает соединение.
|
|
|
|
|
|
2024-05-23 23:57:03 +03:00
|
|
|
|
### rshell
|
|
|
|
|
|
2024-05-21 21:48:35 +03:00
|
|
|
|
Советую ещё установить `rshell`.
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
pip3 install rshell
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
С помощью `rshell` можно работать с платой через привычные команды,
|
|
|
|
|
такие как `ls`, `cat`, `cp` и так далее.
|
|
|
|
|
|
|
|
|
|
Небольшой пример
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
rshell --port /dev/ttyUSB0 # команда для подключения к плате
|
|
|
|
|
ls /pyboard/ # вывести список файлов на плате
|
|
|
|
|
|
|
|
|
|
boot.py # непосредственно сами файлы
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
`/pyboard/` - это путь к памяти устройста. **Автодополнение работает**.
|
|
|
|
|
|
2024-05-23 23:57:03 +03:00
|
|
|
|
## Проверка работоспособности
|
2024-05-21 21:48:35 +03:00
|
|
|
|
|
|
|
|
|
Подключимся к плате и проверим некоторые детали.
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
mpremote
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Откроется REPL.
|
|
|
|
|
|
|
|
|
|
```python
|
|
|
|
|
import esp
|
|
|
|
|
esp.check_fw()
|
|
|
|
|
|
|
|
|
|
# size: 642064
|
|
|
|
|
# md5: b5c0246d25a48de7dcd4cd4d29a7830f
|
|
|
|
|
# True
|
|
|
|
|
|
|
|
|
|
import os
|
|
|
|
|
print(os.listdir())
|
|
|
|
|
|
|
|
|
|
# ['boot.py']
|
|
|
|
|
|
|
|
|
|
import network
|
|
|
|
|
import ubinascii
|
|
|
|
|
|
|
|
|
|
mac = ubinascii.hexlify(network.WLAN().config('mac'), ':').decode()
|
|
|
|
|
|
|
|
|
|
print(mac) # 48:55:19:e1:35:04 <- у вас соответственно будет другой MAC адрес
|
|
|
|
|
```
|
|
|
|
|
|
2024-05-21 22:38:37 +03:00
|
|
|
|
### Синхронизация времени
|
|
|
|
|
|
|
|
|
|
P.S. Не уверен, но кажется `mpremote` самостоятельно синхронизирует время при подключении.
|
|
|
|
|
|
|
|
|
|
Проверить можно вызвав `rtc.datetime()`.
|
|
|
|
|
|
|
|
|
|
```python
|
|
|
|
|
from machine import RTC
|
|
|
|
|
|
|
|
|
|
rtc = RTC()
|
|
|
|
|
rtc.datetime() # (2024, 5, 21, 1, 21, 50, 6, 824)
|
|
|
|
|
```
|
|
|
|
|
|
2024-05-21 21:48:35 +03:00
|
|
|
|
## Работаем с датчиками DHT
|
|
|
|
|
|
|
|
|
|
Документация находится по следующему адресу
|
|
|
|
|
https://docs.micropython.org/en/latest/esp8266/quickref.html#dht-driver.
|
|
|
|
|
|
|
|
|
|
### Схема Wemos D1 Mini
|
|
|
|
|
|
|
|
|
|
![Схема Wemos D1 Mini](https://cdn.a2s.su/blog/2024/Wemos-D1-Mini.png)
|
|
|
|
|
|
|
|
|
|
Есть ещё один вариант на сайте
|
|
|
|
|
[Wemos](https://www.wemos.cc/en/latest/d1/d1_mini.html).
|
2024-05-21 22:38:37 +03:00
|
|
|
|
|
|
|
|
|
### Подключение
|
|
|
|
|
|
|
|
|
|
В [технической документации](https://image.dfrobot.com/image/data/KIT0003/DHT11%20datasheet.pdf)
|
|
|
|
|
указано, что датчик питается от 3.3 до 5 вольт.
|
|
|
|
|
|
|
|
|
|
```text
|
|
|
|
|
3. Technical Specification:
|
|
|
|
|
Model DHT11
|
|
|
|
|
Power supply 3-5.5V DC
|
|
|
|
|
```
|
2024-05-23 23:57:03 +03:00
|
|
|
|
|
|
|
|
|
Я подключил датчик к **3.3V** и к пину **D3** (`GPIO0`).
|
|
|
|
|
|
|
|
|
|
### Получениие показаний
|
|
|
|
|
|
|
|
|
|
Вот скрипт, который опрашывает датчик каждые 5 секунд.
|
|
|
|
|
|
|
|
|
|
```python
|
|
|
|
|
import dht
|
|
|
|
|
from machine import Pin
|
|
|
|
|
import time
|
|
|
|
|
|
|
|
|
|
sensor = dht.DHT11(Pin(0)) # D3
|
|
|
|
|
|
|
|
|
|
while True:
|
|
|
|
|
print('Measuring', end = '')
|
|
|
|
|
|
|
|
|
|
retry = 0
|
|
|
|
|
while retry < 3:
|
|
|
|
|
try:
|
|
|
|
|
sensor.measure()
|
|
|
|
|
break
|
|
|
|
|
except:
|
|
|
|
|
retry = retry + 1
|
|
|
|
|
print('.', end = '')
|
|
|
|
|
|
|
|
|
|
print('')
|
|
|
|
|
|
|
|
|
|
if retry < 3:
|
|
|
|
|
print('Temperature: %3.1f °C' % sensor.temperature())
|
|
|
|
|
print(' Humidity: %3.1f %% RH' % sensor.humidity())
|
|
|
|
|
|
|
|
|
|
time.sleep(5)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Для тестрованиия достаточно выполнить команду:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
mpremote run ./<script_name>.py
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## Питание и глубокий сон
|
|
|
|
|
|
|
|
|
|
### Глубокий сон
|
|
|
|
|
|
|
|
|
|
Ниже представлен полный листинг программы,
|
|
|
|
|
которая выполняет считывание и вывод информации с сенсора DHT11,
|
|
|
|
|
после чегго переходит в режим глубокого сна,
|
|
|
|
|
пробуждаясь каждые 5 секунд.
|
|
|
|
|
|
|
|
|
|
```python
|
|
|
|
|
import dht
|
|
|
|
|
import machine
|
|
|
|
|
import time
|
|
|
|
|
|
|
|
|
|
WAKE_TIME = 5 # Период в секундах пробуждения устройства
|
|
|
|
|
|
|
|
|
|
sensor = dht.DHT11(machine.Pin(0)) # Пин датчика DHT11
|
|
|
|
|
|
|
|
|
|
# Настравает RTC.ALARM0 для пробуждения устройства
|
|
|
|
|
rtc = machine.RTC()
|
|
|
|
|
rtc.irq(trigger=rtc.ALARM0, wake=machine.DEEPSLEEP)
|
|
|
|
|
|
|
|
|
|
# Проверка пробуждение устройства от глуюокого сна
|
|
|
|
|
if machine.reset_cause() == machine.DEEPSLEEP_RESET:
|
|
|
|
|
time.sleep(2)
|
|
|
|
|
print('Measuring', end = '')
|
|
|
|
|
|
|
|
|
|
retry = 0
|
|
|
|
|
while retry < 3:
|
|
|
|
|
try:
|
|
|
|
|
sensor.measure()
|
|
|
|
|
break
|
|
|
|
|
except:
|
|
|
|
|
retry = retry + 1
|
|
|
|
|
print('.', end = '')
|
|
|
|
|
|
|
|
|
|
print('')
|
|
|
|
|
|
|
|
|
|
if retry < 3:
|
|
|
|
|
print('Temperature: %3.1f °C' % sensor.temperature())
|
|
|
|
|
print(' Humidity: %3.1f %% RH' % sensor.humidity())
|
|
|
|
|
|
|
|
|
|
# Задержка, чтобы успеть подключиться к REPL
|
|
|
|
|
# и обновить скрипт, если что-то пойдёт не так!
|
|
|
|
|
time.sleep(5)
|
|
|
|
|
|
|
|
|
|
# Устанавливает RTC.ALARM0 для активации через указанный период (пробуждение устройства)
|
|
|
|
|
rtc.alarm(rtc.ALARM0, WAKE_TIME * 1000)
|
|
|
|
|
|
|
|
|
|
# Переводиит устройство в спящий режим
|
|
|
|
|
machine.deepsleep()
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### Питание
|
|
|
|
|
|
|
|
|
|
...
|
|
|
|
|
|
|
|
|
|
## Подключениие к Wi-Fi сети
|
|
|
|
|
|
|
|
|
|
...
|
|
|
|
|
|
|
|
|
|
## Передача данных
|
|
|
|
|
|
|
|
|
|
...
|