• Skip to primary navigation
  • Skip to main content
  • Skip to primary sidebar
  • Skip to secondary sidebar
  • Skip to footer

У Павла!

  • Контроллеры
    • Arduino
      • Приборы
      • Музыка
      • Проекты Arduino
      • Уроки Arduino
      • Игры на Arduino
      • Роботы на Ардуино
      • FLProg
    • Одноплатные ПК
      • Orange pi
      • Raspberry pi
        • Raspberry pi pico
        • Raspberry pi server
        • Проекты Raspberry pi
    • ESP
      • ESP8266
        • NodeMCU
      • ESP32
      • M5stack
    • Другие контроллеры
      • STM32
  • Умный дом
    • Home Assistant
      • Автоматизации
    • Tuya
    • Bluetooth
    • ESPHome
    • Frigate
    • Telegram
    • Яндекс
  • ЧПУ
  • 3d печать
  • Об авторе

Athom 6CH Energy Meter – Энергомонитор на 6 каналов с ESP32C3 и ESPHome

24 марта, 2025

6 каналов ESPHome: https://alii.pub/765ll4?erid=2SDnjf18aGc

6 каналов Tasmota: https://alii.pub/765llp?erid=2SDnjbqJSon

2 канала: https://alii.pub/765lmh?erid=2SDnjc3AM4Y

Интересный модуль мне тут попался в руки. Это модуль на ESP32C3, который может измерять электроэнергию по 6ти каналам.

Измеряет электроэнергию там буквально одна микросхема BL0906. Она умеет измерять напряжение, силу тока, частоту и температуру у себя внутри.

Вот так выглядит плата внутри. Ракурса полного не получилось  поймать из видео, но думаю тут все видно.

А вот большой ракурс микросхемы BL0906, которая собственно и управляет всем этим делом (я имею ввиду измерением электроэнергии).

Эта микросхема общается с контроллером ESP32C3 по уарт интерфейсу и подключается к gpio7 и gpio8 контроллера esp32c3.

 

Подключение тут  очень простое, на вход подаётся 220 вольт, а к каждому каналу подключается токовый трансформатор DBKCT-10 2000/1:

У такого токового трансформатора всего 2 провода. И подключается он ими на специальную колодку CT головного модуля.

Причем если поменять полярность, то считать будет в минус, тем самым мы можем  сделать мониторинг как потребления, так и отдачи, если например у Вас аккумулятор или солнечная батарея.

Каждый такой канал может измерять ток от 0.1 Ампера до 97 амер.

 

Прошивка на это устройство основана на ESPHome.

Кстати работа с микросхемой описана прям официально на странице ESPHome: https://esphome.io/components/sensor/bl0906.html

Но там предоставлено только 2 девайса Athom 6CH и 2CH. Да и вообще микросхему BL0906 я нашёл только в чип и дип, а на али что-то не продают.

Так-же есть готовый код для ESPHome этого модуля на DIn рейку:

https://github.com/athom-tech/esp32-configs/blob/main/athom-energy-monitor-x6.yaml

И Выглядит он следующим образом:


substitutions:
  name: "athom-em-6"
  friendly_name: "Athom Energy Meter"
  # Allows ESP device to be automatically lined to an 'Area' in Home Assistant. Typically used for areas such as 'Lounge Room', 'Kitchen' etc
  room: ""
  device_description: "athom bl0906 energy meter (6 channels)"
  project_name: "Athom Technology.Athom Energy Meter(6 Channels)"
  project_version: "2.0.5"
  update_interval: 5s
  # Define a domain for this device to use. i.e. iot.home.lan (so device will appear as athom-smart-plug-v2.iot.home.lan in DNS/DHCP logs)
  dns_domain: ".local"
  # Set timezone of the smart plug. Useful if the plug is in a location different to the HA server. Can be entered in unix Country/Area format (i.e. "Australia/Sydney")
  timezone: ""
  # Set the duration between the sntp service polling ntp.org servers for an update
  sntp_update_interval: 6h
  # Network time servers for your region, enter from lowest to highest priority. To use local servers update as per zones or countries at: https://www.ntppool.org/zone/@
  sntp_server_1: "0.pool.ntp.org"
  sntp_server_2: "1.pool.ntp.org"
  sntp_server_3: "2.pool.ntp.org"  
  # Enables faster network connections, with last connected SSID being connected to and no full scan for SSID being undertaken
  wifi_fast_connect: "false"
  # Define logging level: NONE, ERROR, WARN, INFO, DEBUG (Default), VERBOSE, VERY_VERBOSE
  log_level: "DEBUG"
  # Enable or disable the use of IPv6 networking on the device
  ipv6_enable: "false"

#############################ESP32C3###########################
  bl0906_tx_pin: GPIO7
  bl0906_rx_pin: GPIO8
  button_pin:    GPIO9
  led_pin:       GPIO10
  clk_pin:       GPIO2
  mosi_pin:      GPIO3
  backlight_pin: GPIO18
  reset_pin:     GPIO4
  dc_pin:        GPIO5
  cs_pin:        GPIO6
#############################ESP32C3###########################

#############################ESP32-WROOM-32D###########################
  # bl0906_tx_pin: GPIO12
  # bl0906_rx_pin: GPIO14
  # button_pin:    GPIO0
  # led_pin:       GPIO15
  # backlight_pin: GPIO33
  # clk_pin:       GPIO16
  # mosi_pin:      GPIO17
  # reset_pin:     GPIO5
  # dc_pin:        GPIO18
  # cs_pin:        GPIO19
#############################ESP32-WROOM-32D###########################
esphome:
  name: "${name}"
  friendly_name: "${friendly_name}"
  area: "${room}"
  name_add_mac_suffix: true
  min_version: 2024.9.2
  project:
    name: "${project_name}"
    version: "${project_version}"

esp32:
  board: esp32-c3-devkitm-1
  flash_size: 4MB
  variant: ESP32C3
  framework:
    type: arduino
    version: recommended

# esp32:
#   board: esp32dev
#   flash_size: 4MB
#   variant: ESP32
#   framework:
#     type: arduino
#     version: recommended

preferences:
  flash_write_interval: 5min

api:
  # reboot_timeout: 0s

ota:
  - platform: esphome

logger:
  baud_rate: 115200
  level: ${log_level}
  hardware_uart: UART0

mdns:
  disabled: false

web_server:
  port: 80

network:
  enable_ipv6: ${ipv6_enable}

wifi:
  ap: {}
  fast_connect: "${wifi_fast_connect}"
  domain: "${dns_domain}"

captive_portal:

improv_serial:

esp32_improv:
  authorizer: none

dashboard_import:
  package_import_url: github://athom-tech/esp32-configs/athom-energy-monitor-x6.yaml

globals:
  - id: id_Energy_sum_persist
    type: float
    restore_value: yes
    initial_value: '0.0'
  - id: id_Energy_sum_lastvalue
    type: float
    restore_value: no
    initial_value: '0.0'

  - id: id_Energy_1_persist
    type: float
    restore_value: yes
    initial_value: '0.0'
  - id: id_Energy_1_lastvalue
    type: float
    restore_value: no
    initial_value: '0.0'

  - id: id_Energy_2_persist
    type: float
    restore_value: yes
    initial_value: '0.0'
  - id: id_Energy_2_lastvalue
    type: float
    restore_value: no
    initial_value: '0.0'

  - id: id_Energy_3_persist
    type: float
    restore_value: yes
    initial_value: '0.0'
  - id: id_Energy_3_lastvalue
    type: float
    restore_value: no
    initial_value: '0.0'

  - id: id_Energy_4_persist
    type: float
    restore_value: yes
    initial_value: '0.0'
  - id: id_Energy_4_lastvalue
    type: float
    restore_value: no
    initial_value: '0.0'

  - id: id_Energy_5_persist
    type: float
    restore_value: yes
    initial_value: '0.0'
  - id: id_Energy_5_lastvalue
    type: float
    restore_value: no
    initial_value: '0.0'

  - id: id_Energy_6_persist
    type: float
    restore_value: yes
    initial_value: '0.0'
  - id: id_Energy_6_lastvalue
    type: float
    restore_value: no
    initial_value: '0.0'

uart:
  tx_pin: "$bl0906_tx_pin"
  rx_pin: "$bl0906_rx_pin"
  baud_rate: 19200
  id: uart_bl0906

light:
  - platform: status_led
    name: "Status LED"
    id: blue_led
    disabled_by_default: true
    pin: $led_pin

binary_sensor:
  - platform: status
    name: "Status"
    entity_category: diagnostic

  - platform: gpio
    pin:
      number: "$button_pin"
      mode: INPUT_PULLUP
      inverted: true
    name: "Power Button"
    disabled_by_default: true
    on_multi_click:
      - timing:
        - ON for at least 4s
        then:
          - button.press: Reset

sensor:
  - platform: uptime
    name: "Uptime Sensor"
    id: uptime_sensor
    entity_category: diagnostic
    internal: true

  - platform: wifi_signal
    name: "WiFi Signal dB"
    id: wifi_signal_db
    update_interval: 60s
    entity_category: "diagnostic"

  - platform: copy
    source_id: wifi_signal_db
    name: "WiFi Signal Percent"
    filters:
      - lambda: return min(max(2 * (x + 100.0), 0.0), 100.0);
    unit_of_measurement: "Signal %"
    entity_category: "diagnostic"
    device_class: ""

  - platform: bl0906
    id: id_bl0906
    update_interval: "${update_interval}"
    frequency:
      name: 'Frequency'
      id: 'Frequency'
    temperature:
      name: 'Temperature'
      id: 'Temperature'
    voltage:
      name: 'Voltage'
      id: 'Voltage'
    channel_1:
      current:
        name: 'Current_1'
        id: 'Current_1'
      power:
        name: 'Power_1'
        id: 'Power_1'
      energy:
        id: 'Energy_1'
        name: 'Energy_1_Internal'
        internal: true
    channel_2:
      current:
        name: 'Current_2'
        id: 'Current_2'
      power:
        name: 'Power_2'
        id: 'Power_2'
      energy:
        id: 'Energy_2'
        name: 'Energy_2_Internal'
        internal: true
    channel_3:
      current:
        name: 'Current_3'
        id: 'Current_3'
      power:
        name: 'Power_3'
        id: 'Power_3'
      energy:
        id: 'Energy_3'
        name: 'Energy_3_Internal'
        internal: true
    channel_4:
      current:
        name: 'Current_4'
        id: 'Current_4'
      power:
        name: 'Power_4'
        id: 'Power_4'
      energy:
        id: 'Energy_4'
        name: 'Energy_4_Internal'
        internal: true
    channel_5:
      current:
        name: 'Current_5'
        id: 'Current_5'
      power:
        name: 'Power_5'
        id: 'Power_5'
      energy:
        id: 'Energy_5'
        name: 'Energy_5_Internal'
        internal: true
    channel_6:
      current:
        name: 'Current_6'
        id: 'Current_6'
      power:
        name: 'Power_6'
        id: 'Power_6'
      energy:
        id: 'Energy_6'
        name: 'Energy_6_Internal'
        internal: true
    total_energy:
      name: 'Total_Energy'
      id: 'Energy_sum'
      internal: true
    total_power:
      name: 'Total_Power'
      id: 'Total_Power'

  - platform: copy
    name: 'Total_Energy'
    id: Energy_sum_persist
    source_id: Energy_sum
    filters:
      - lambda: |-
          if(id(id_Energy_sum_lastvalue) == 0.0  )
          {
            id(id_Energy_sum_lastvalue) = id(Energy_sum).state;
          }
          if(x < id(id_Energy_sum_persist))
          {
            float delta =  x - id(id_Energy_sum_lastvalue);
            id(id_Energy_sum_persist) += delta;
            id(id_Energy_sum_lastvalue) = x;
          }
          else
          {
            id(id_Energy_sum_persist) = x;
          }
          return id(id_Energy_sum_persist);

  - platform: copy
    name: 'Energy_1'
    id: Energy_1_persist
    source_id: Energy_1
    filters:
      - lambda: |-
          if(id(id_Energy_1_lastvalue) == 0.0  )
          {
            id(id_Energy_1_lastvalue) = id(Energy_1).state;
          }
          if(x < id(id_Energy_1_persist))
          {
            float delta =  x - id(id_Energy_1_lastvalue);
            id(id_Energy_1_persist) += delta;
            id(id_Energy_1_lastvalue) = x;
          }
          else
          {
            id(id_Energy_1_persist) = x;
          }
          return id(id_Energy_1_persist);

  - platform: copy
    name: 'Energy_2'
    id: Energy_2_persist
    source_id: Energy_2
    filters:
      - lambda: |-
          if(id(id_Energy_2_lastvalue) == 0.0  )
          {
            id(id_Energy_2_lastvalue) = id(Energy_2).state;
          }
          if(x < id(id_Energy_2_persist))
          {
            float delta =  x - id(id_Energy_2_lastvalue);
            id(id_Energy_2_persist) += delta;
            id(id_Energy_2_lastvalue) = x;
          }
          else
          {
            id(id_Energy_2_persist) = x;
          }
          return id(id_Energy_2_persist);

  - platform: copy
    name: 'Energy_3'
    id: Energy_3_persist
    source_id: Energy_3
    filters:
      - lambda: |-
          if(id(id_Energy_3_lastvalue) == 0.0  )
          {
            id(id_Energy_3_lastvalue) = id(Energy_3).state;
          }
          if(x < id(id_Energy_3_persist))
          {
            float delta =  x - id(id_Energy_3_lastvalue);
            id(id_Energy_3_persist) += delta;
            id(id_Energy_3_lastvalue) = x;
          }
          else
          {
            id(id_Energy_3_persist) = x;
          }
          return id(id_Energy_3_persist);

  - platform: copy
    name: 'Energy_4'
    id: Energy_4_persist
    source_id: Energy_4
    filters:
      - lambda: |-
          if(id(id_Energy_4_lastvalue) == 0.0  )
          {
            id(id_Energy_4_lastvalue) = id(Energy_4).state;
          }
          if(x < id(id_Energy_4_persist))
          {
            float delta =  x - id(id_Energy_4_lastvalue);
            id(id_Energy_4_persist) += delta;
            id(id_Energy_4_lastvalue) = x;
          }
          else
          {
            id(id_Energy_4_persist) = x;
          }
          return id(id_Energy_4_persist);

  - platform: copy
    name: 'Energy_5'
    id: Energy_5_persist
    source_id: Energy_5
    filters:
      - lambda: |-
          if(id(id_Energy_5_lastvalue) == 0.0  )
          {
            id(id_Energy_5_lastvalue) = id(Energy_5).state;
          }
          if(x < id(id_Energy_5_persist))
          {
            float delta =  x - id(id_Energy_5_lastvalue);
            id(id_Energy_5_persist) += delta;
            id(id_Energy_5_lastvalue) = x;
          }
          else
          {
            id(id_Energy_5_persist) = x;
          }
          return id(id_Energy_5_persist);

  - platform: copy
    name: 'Energy_6'
    id: Energy_6_persist
    source_id: Energy_6
    filters:
      - lambda: |-
          if(id(id_Energy_6_lastvalue) == 0.0  )
          {
            id(id_Energy_6_lastvalue) = id(Energy_6).state;
          }
          if(x < id(id_Energy_6_persist)) { float delta = x - id(id_Energy_6_lastvalue); id(id_Energy_6_persist) += delta; id(id_Energy_6_lastvalue) = x; } else { id(id_Energy_6_persist) = x; } return id(id_Energy_6_persist); button: - platform: restart name: "Restart" entity_category: config - platform: factory_reset name: "Factory Reset" id: Reset entity_category: config - platform: safe_mode name: "Safe Mode" internal: false entity_category: config - platform: template name: Reset Energy entity_category: config on_press: then: - globals.set: id: id_Energy_1_persist value: '0.0' - globals.set: id: id_Energy_2_persist value: '0.0' - globals.set: id: id_Energy_3_persist value: '0.0' - globals.set: id: id_Energy_4_persist value: '0.0' - globals.set: id: id_Energy_5_persist value: '0.0' - globals.set: id: id_Energy_6_persist value: '0.0' - globals.set: id: id_Energy_sum_persist value: '0.0' - bl0906.reset_energy: id_bl0906 text_sensor: - platform: wifi_info ip_address: name: "IP Address" id: ip_address entity_category: diagnostic ssid: name: "Connected SSID" id: ssid entity_category: diagnostic mac_address: name: "Mac Address" id: mac_address entity_category: diagnostic - platform: template name: "Last Restart" id: device_last_restart icon: mdi:clock entity_category: diagnostic device_class: timestamp - platform: template name: "Uptime" id: uptimes icon: mdi:clock-start entity_category: diagnostic lambda: |- int seconds = (id(uptime_sensor).state); int days = seconds / (24 * 3600); seconds = seconds % (24 * 3600); int hours = seconds / 3600; seconds = seconds % 3600; int minutes = seconds / 60; seconds = seconds % 60; if ( days > 3650 ) {
        return { "Starting up" };
      } else if ( days ) {
        return { (String(days) +"d " + String(hours) +"h " + String(minutes) +"m "+ String(seconds) +"s").c_str() };
      } else if ( hours ) {
        return { (String(hours) +"h " + String(minutes) +"m "+ String(seconds) +"s").c_str() };
      } else if ( minutes ) {
        return { (String(minutes) +"m "+ String(seconds) +"s").c_str() };
      } else {
        return { (String(seconds) +"s").c_str() };
      }

time:
  - platform: sntp
    id: sntp_time
  # Define the timezone of the device
    timezone: "${timezone}"
  # Change sync interval from default 5min to 6 hours (or as set in substitutions)
    update_interval: ${sntp_update_interval}
  # Set specific sntp servers to use
    servers:
      - "${sntp_server_1}"
      - "${sntp_server_2}"
      - "${sntp_server_3}"
  # Publish the time the device was last restarted
    on_time_sync:
      then:
        # Update last restart time, but only once.
        - if:
            condition:
              lambda: 'return id(device_last_restart).state == "";'
            then:
              - text_sensor.template.publish:
                  id: device_last_restart
                  state: !lambda 'return id(sntp_time).now().strftime("%a %d %b %Y - %I:%M:%S %p");'
 

Можно просто брать этот код и вставлять в ESPhome и он будет работать. Единственное только, что если залить этот код не изменяя, то он создаст свою точку доступа к которой надо будет подключиться, зайти по адресу 192.168.4.1 и там выбрать вашу wifi сеть, чтоб подключился модуль туда.

Ну а далее, после подключения модуля к вашей локальной сети. Home Assistant сам найдёт интеграцией ESPHome новое устройство и останется только нажать кнопку “Добавить”.

 

Ну и вот так выглядят все сенсоры в ESPHome:

Тут есть показания силы тока, напряжения, частоты, потребляемой мощности, израсходованной энергии.

Причем Потребляемую мощность показывает как по каждому из 6сти каналов, так и общую. И так-же потребляемую энергию по каждому каналу, так и общую.

Сенсоры энергии они накопительные и копят в себе суммарное количество израсходованной энергии в kWh. И есть кнопка которая сбрасывает эту энергию в 0.

Это удобно, если например нам хочется считать показания раз в месяц и потом их сбрасывать.

Primary Sidebar

Поиск

Новые записи

  • Автоматизация перезагрузки устройства по команде Ping.
  • Разблокирование и добавление шлюза Xiaomi gateway 3 в Home Assistant для управления Bluetooth устройствами из экосистемы Xiaomi Home (mihome)
  • Интеграция для локального управления (без интернета) ик пультом Tuya работающим по wifi из Home Assistant
  • Транслируем показания с Уличного Bluetooth Датчика температуры по BTHome на дисплей датчика температуры XIaomi LYWSD03MMC
  • Заставляем Bluetooth датчики температуры tuya и xiaomi отправлять данные по Zigbee в Home Assistant.

Официальный YouTube Канал M5Stack:

Подписывайтесь на Телеграм канал

https://t.me/ypavla

Подписаться на YouTube!

Secondary Sidebar




Подписывайтесь на Telegram Канал!

У Павла!

Footer

Copyright_У Павла! © 2025 ·