snipplets.dev/projects/MicroPython/DTH11/README.md

300 lines
8.8 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# Работа с DHT11 и DHT22 на Wemos D1 Mini (и других)
## Подготовка платы и прошивка
### Предисловие о файле прошивки
По состоянию на 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
```
## Обеспечиваем удобство взаимодействия
D1 Mini имеет на борту UART преобразователь на чипе `CH34x`.
Подключиться к устройству можно с помощью утилит `screen` или `minicon` (и ещё сотню других),
но более удобней будет работать с помощью `mpremote`.
```shell
pip3 install mpremote
```
### mpremote
`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` закрывает соединение.
### rshell
Советую ещё установить `rshell`.
```shell
pip3 install rshell
```
С помощью `rshell` можно работать с платой через привычные команды,
такие как `ls`, `cat`, `cp` и так далее.
Небольшой пример
```shell
rshell --port /dev/ttyUSB0 # команда для подключения к плате
ls /pyboard/ # вывести список файлов на плате
boot.py # непосредственно сами файлы
```
`/pyboard/` - это путь к памяти устройста. **Автодополнение работает**.
## Проверка работоспособности
Подключимся к плате и проверим некоторые детали.
```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 адрес
```
### Синхронизация времени
P.S. Не уверен, но кажется `mpremote` самостоятельно синхронизирует время при подключении.
Проверить можно вызвав `rtc.datetime()`.
```python
from machine import RTC
rtc = RTC()
rtc.datetime() # (2024, 5, 21, 1, 21, 50, 6, 824)
```
## Работаем с датчиками 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).
### Подключение
В [технической документации](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
```
Я подключил датчик к **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 сети
...
## Передача данных
...