Home assistant Glow project smart elmåler for 150kr.

Home assistant Glow project smart elmåler for 150kr.

Problem

Jeg har en echelon elmåler. som automatisk afgiver sine målinger til mit elselskab. Men de målinger har flere dages forsinkelser. derfor kan jeg ikke se mit øjeblikkellige forbrug.

jeg har hidtil brugt en integration fra eloverblik (Github) som har vist disse forsinkede data.

men da vi gerne ville dykke ned i hvorfor vores forbrug var så stort. så var det ikke nemt at undersøge hvor meget hvert enkelt apperat brugte.

Det ville være nemmere hvis jeg kunne se mit forbrug live.

Overvejelser

Jeg overvejede forskellige løsninger, hvor jeg lagde vægt på pris, sværhedsgrad, måling af totalt forbrug og udbytte.

  1. at købe smarte afbrydere til hvert enkelt stykke elektronik. eller i det mindste til en del af mine apperater. Men det ville blive ret dyrt. og ville ikke tillade mig at måle ALT elforbrug. og evt. afgive en alarm.
  2. En færdig løsning, eks. Shelly-M3 som er den billigste løsning med god integration til home assistant. men den koster også en del penge.
  3. efter en del søgen faldt jeg over Home assistant Glow. og i første omgang så var jeg ikke vild med den ide. da den omfattede ESP32 flashing osv.

Løsning

Løsningen blev dog at prøve den 3. løsning. da jeg havde gravet priser frem på de forskellige komponenter som skulle bruges. så endte det på omkring 150kr. og hvis det ikke lykkedes. så gik det nok.

man kan så ikke se hvilket apperat som bruger meget strøm osv. men hvis man holder lidt øje. og ved hvad der er tændt, så finder man hurtigt ud af det. meningen er så at sætte noget alarm på, som fortæller mig hvis der bliver brugt for meget strøm. så kan jeg slukke for alt strømmen, og tænde et apperat af gangen. for derved at finde frem til hvad der bruger meget strøm.

Forudsætninger/vigtige ting

  1. Din elmåler har en lille lampe der blinker hver gang den har brugt et bestemt antal watt
  2. forbind ikke de to kort inden du flasher
  3. jeg brugte ikke status LED da der er rigeligt med indikatorer på begge kort.
  4. Vær sikker på at LED vender rigtigt
  5. Sørg for at LED har den afrundede spids imod lysdioden på din elmåler.

Bestilling

Jeg fik bestilt komponenterne (glemte dog ledningerne, hvilket vi kommer tilbage til.)

  1. ESP32 udviklings kort, med WIFI osv. LINK 80kr. (Man kan også købe et billigere kort, uden USB tilslutning. men så skal man have et andet kort som tillader kommunikation til USB/computer)
  2. Lysføler med LED (det er MEGET vigtigt at det er med LED ikke LDR) LINK 22kr.
  3. og så skulle jeg have bestilt jumper kabler. da det havde gjort det hele meget lettere LINK 7kr. (Hun til Hun stik/kabler)

som tidligere beskrevet. så fik jeg ikke bestilt kabler. så jeg brugte nogle computer kabler og stik. men de passede ikke så godt.

Github projekt hjemmeside
https://github.com/klaasnicolaas/home-assistant-glow

Samling

Jeg forsøgte også at lodde ledningerne direkte, hvilket havde været fint. men jeg syntes det var svært at få dem loddet korrekt, og i den proces fik jeg smeltet noget af potentiometeret, hvilket gjorde at jeg måtte slibe lidt af toppen for at kunne dreje det.

Jeg fik samlet de to kort med 3 ledninger. hvilket var nemt nok hvis man følger vejledningen på siden. jeg syntes det var svært at læse hvad der stod ud fra hver pin på kortene. så jeg tog et billede og brugte det.

lysfølerESP32
A0bruges ikke
D0D12 (GPIO12)
VCC3V3
GNDGND

Installering/opsætning

jeg installerede ESP32 i home assistant. og fik forbindelse til kortet. jeg forsøgte at flashe. og det virkede ikke. så huskede jeg at man IKKE skulle forbinde de to kort når man skulle flashe. så jeg fjernede ledningerne og efter en del roden rundt med forbindelser og den YAML kode som skal sendes til ESP32 kortet. så virkede det.

det drillede en del. men efter flere forsøg. så kørte det bare.

her er min YAML fil som skal bruges INDE i ESP32 integrationen i home assistant

HUSK at skifte WIFI-SSID, WIFI-KODE gateway og evt. statisk IP

substitutions:
  device_name: glow
  friendly_name: House
  project_version: "3.0.0"
  device_description: "Measure your energy consumption with the pulse LED on your smart meter"
  pulse_pin: GPIO12
  status_led: GPIO5

  # imp/kWh rate ⬇ #
  pulse_rate: '1000'

  # Webserver credentials ⬇ #
  web_username: 'glow'
  web_password: 'esphome'

dashboard_import:
  package_import_url: github://klaasnicolaas/home-assistant-glow/home_assistant_glow.yaml

esphome:
  name: '${device_name}'
  comment: '${device_description}'
  project:
    name: "klaasnicolaas.home-assistant-glow"
    version: "${project_version}"

esp32:
  board: esp32dev
  framework:
    type: arduino

# Enable logging
logger:


wifi:
  ssid: WIFI-SSID
  password: WIFI-KODE
  manual_ip:
    # Set this to the IP of the ESP
    static_ip: 192.168.0.250
    # Set this to the IP address of the router. Often ends with .1
    gateway: 192.168.0.2
    # The subnet of the network. 255.255.255.0 works for most home networks.
    subnet: 255.255.255.0  

  # Enable fallback hotspot (captive portal) in case wifi connection fails
  ap:
    ssid: "Glow Fallback Hotspot"
    password: "w7W3MnSmaCOq"

captive_portal:



# Enable improv over serial
improv_serial:

# Enable Home Assistant API
api:
  services:
    - service: reset_total_energy
      then:
        - button.press:
            id: button_reset_total

ota:
  safe_mode: true
  reboot_timeout: 10min
  num_attempts: 5

web_server:
  port: 80
  auth:
    username: '${web_username}'
    password: '${web_password}'

output:
  # - platform: gpio
  #   pin: GPIO5
  #   id: output_blue
  - platform: gpio
    pin: GPIO2
    id: output_red
  - platform: gpio
    pin: GPIO4
    id: output_green

light:
  - platform: binary
    internal: true
    id: led_red
    name: Red
    output: output_red

# Status LED for connection
status_led:
  pin:
    # Blue LED
    number: ${status_led}

button:
  - platform: restart
    name: "Restart - Glow"
  - platform: template
    name: "Reset - Total Energy"
    id: button_reset_total
    on_press:
      - pulse_meter.set_total_pulses:
          id: sensor_energy_pulse_meter
          value: 0

# Sensors for ESP version and WIFI information
text_sensor:
  # Installed version
  - platform: template
    name: "Glow - Installed version"
    id: glow_version
    icon: "mdi:label-outline"
    entity_category: diagnostic
    lambda: |-
      return {"${project_version}"};
    update_interval: 6h
  - platform: version
    hide_timestamp: true
    name: '${friendly_name} - ESPHome Version'
  - platform: wifi_info
    ip_address:
      name: '${friendly_name} - IP Address'
      icon: mdi:wifi
    ssid:
      name: '${friendly_name} - Connected SSID'
      icon: mdi:wifi-strength-2

sensor:
  # WiFi signal
  - platform: wifi_signal
    name: "${friendly_name} - WiFi Signal"
    update_interval: 120s

  # Pulse meter
  - platform: pulse_meter
    name: '${friendly_name} - Power Consumption'
    id: sensor_energy_pulse_meter
    unit_of_measurement: 'W'
    state_class: measurement
    device_class: power
    icon: mdi:flash-outline
    accuracy_decimals: 0
    pin: ${pulse_pin}
    # internal_filter: 100ms
    on_value:
      then:
        - light.turn_on:
            id: led_red
        - delay: 0.5s
        - light.turn_off:
            id: led_red
    filters:
      # multiply value = (60 / imp value) * 1000
      # - multiply: 60
      - lambda: return x * ((60.0 / ${pulse_rate}) * 1000.0);
    total:
      name: '${friendly_name} - Total Energy'
      id: sensor_total_energy
      unit_of_measurement: 'kWh'
      icon: mdi:circle-slice-3
      state_class: total_increasing
      device_class: energy
      accuracy_decimals: 3
      filters:
        # multiply value = 1 / imp value
        # - multiply: 0.001
        - lambda: return x * (1.0 / ${pulse_rate});
  # Total day useage
  - platform: total_daily_energy
    name: '${friendly_name} - Daily Energy'
    id: sensor_total_daily_energy
    power_id: sensor_energy_pulse_meter
    unit_of_measurement: 'kWh'
    icon: mdi:circle-slice-3
    state_class: total_increasing
    device_class: energy
    accuracy_decimals: 3
    filters:
      # Multiplication factor from W to kW is 0.001
      - multiply: 0.001

# Enable time component to reset energy at midnight
# https://esphome.io/components/time.html#home-assistant-time-source
time:
  - platform: homeassistant
    id: homeassistant_time


Leave a Reply

Your email address will not be published. Required fields are marked *