This repo contains some experimental software written in (micro)python, creating a battery powered display for an OpenEnergyMonitor dashboard. It displays my home's solar installation.
M5Stack is a small battery powered display with as core an ESP32. See https://m5stack.com/. I used the M5Stack Grey kit.
OpenEnergyMonitor is an open-source energy monitoring platform. It comes in some different variants, but I used the emonPi. See https://openenergymonitor.org/.
For this project, it's madatory to have two feeds measuring the feed from the solar panels, and the feed from/to the grid. These need to be available on the emonPi's MQTT broker.
I flashed the Loboris MicroPython port for ESP32. Using the guide on https://github.com/loboris/MicroPython_ESP32_psRAM_LoBo it's fairly straightforward to create a build for the M5Stack.
Add a config.json
JSON file in the project's root with following content:
solar_topic
: The MQTT topic holding the realtime data for the solar feed;grid_topic
: The MQTT topic holding the realtime data for the grid feed;mqtt_broker
: The MQTT broker endpoint (ip address from the emonPi);wifi_credentials
: A list holding the SSID as first element, and the password as second.
Optionally, following parameters can also be specified:
update_interval_ms
: How frequent (in ms) the display must be updated;graph_interval_s
: How frequent (in s) the graph needs to be updated.
Tip: A graph interval of 270
seconds is just enough for exactly 24h of data.
- Copy the files over to the M5Stack and reset/reboot the device:
rshell --port /dev/ttyUSB0 rsync --mirror . /flash
. - Soft restart the M5Stack: Open the REPL with
screen /dev/ttyUSB0 115200
and soft restart withCTRL+D
.
Tip: You can exit the screen by pressing CTRL+A
, then k
and then y
.
The system supports update via SD card. Format an micro SD card with FAT32 and put the contents
of this repo in an update
folder on the SD card's root. Put the SD card in the M5Stack and use
the A
and C
buttons to nativate to the reboot & update
menu item. Press the B
button to
activate. The system will take a backup of the graph, reset the M5Stack, update the code from the
SD card and load the graph again.
When the REPL is open, do a soft restart and watch the debug output. It might give a clue about what's going on.
All code is licensed under AGPL 3.0 except for files stating differently.
This project uses and/or relies on following software:
- Loboris ESP32 MicroPython fork;
- Mika Tuupola's IP5306 I2C driver & button wrapper
Let me know if I miss anything.