lumapu
4796555fac
|
2 years ago | |
---|---|---|
.. | ||
WemosD1_NRF24_Case | 3 years ago | |
html | 2 years ago | |
include | 2 years ago | |
scripts | 2 years ago | |
.gitignore | 2 years ago | |
CHANGES.md | 2 years ago | |
CircularBuffer.h | 2 years ago | |
README.md | 2 years ago | |
User_Manual.md | 2 years ago | |
ahoywifi.cpp | 2 years ago | |
ahoywifi.h | 2 years ago | |
app.cpp | 2 years ago | |
app.h | 2 years ago | |
config.h | 2 years ago | |
config_override_example.h | 2 years ago | |
crc.cpp | 2 years ago | |
crc.h | 2 years ago | |
defines.h | 2 years ago | |
eep.h | 2 years ago | |
favicon.h | 3 years ago | |
hmDefines.h | 2 years ago | |
hmInverter.h | 2 years ago | |
hmRadio.h | 2 years ago | |
hmSystem.h | 2 years ago | |
main.cpp | 2 years ago | |
mqtt.h | 2 years ago | |
platformio.ini | 2 years ago | |
web.cpp | 2 years ago | |
web.h | 2 years ago |
README.md
OVERVIEW
This page describes how the module of a Wemos D1 mini and ESP8266 is wired to the radio module, flashed and how the further steps are to communicate with the WR HM series.
Compatiblity
For now the following inverters should work out of the box:
- HM350
- HM400
- HM600
- HM700
- HM800
- HM1200
- HM1500
The NRF24L01+ radio module is connected to the standard SPI pins. Additional there are 3 pins, which can be set individual: CS, CE and IRQ These pins can be changed in the http:///setup URL or with a click on the Setup link.
ESP8266 electr. associate
Compile
This code can be compiled using Visual Studio Code and PlatformIO Addon. The settings were:
- Board: Generic ESP8266 Module
- Flash-Size: 1MB (FS: none, OTA: 502kB)
- Install libraries (not included in the Arduino IDE 1.8.19):
Time
1.6.1RF24
1.4.5PubSubClient
2.8ArduinoJson
6.19.4
Optional Configuration before compilation
- number of supported inverters (set to 3 by default)
config.h
- DTU radio id
config.h
(default = 1234567801) - unformated list in webbrowser
/livedata
config.h
,LIVEDATA_VISUALIZED
Alternativly, instead of modifying config.h
, config_override_example.h
can be copied to config_override.h
and customized.
config_override.h is excluded from version control and stays local.
Flash ESP with firmware
nodemcu-pyflasher (easy way)
-
download the flash-tool nodemcu-pyflasher
-
download latest release bin-file from ahoy_
-
connect the target device with your pc.
-
Set the correct serial port and select the correct *.bin file
-
click now on "Flash NodeMCU"
-
flash the ESP with the compiled firmware using the UART pins or any preinstalled firmware with OTA capabilities
-
repower the ESP
-
the ESP will start as access point (AP) if there is no network config stored in its eeprom
-
connect to the AP, you will be forwarded to the setup page
X. configure your WiFi settings, save, repower Y. check your router or serial console for the IP address of the module. You can try ping the configured device name as well.
! ATTENTION: If you update from a very low version to the newest, please make sure to wipe all flash data!
pages
page | output |
---|---|
/uptime | 0 Days, 01:37:34; now: 2022-08-21 11:13:53 |
/reboot | reboot dtu device |
/erase | |
/factory | |
/setup | |
/save | open the setup site |
/cmdstat | show stat from the home site |
/visualization | |
/livedata | |
/json | json output from the livedata |
/api |
Usage
The webinterface has the following abilities:
- OTA Update (over the air update)
- Configuration (Wifi, inverter(s), NTP Server, Pinout, MQTT, Amplifier Power Level, Debug)
- visual display of the connected inverters / modules
- some statistics about communication (debug)
The serial console will print the converted values which were read out of the inverter(s)
MQTT command to set the DTU without webinterface
Todo's See this post
- Wechsel zu AsyncWebServer und ElegantOTA für Stabilität
- klarer Scheduler / Task manager, der ggf. den Receive Task priorisieren kann
- Device Info Kommandos (Firmware Version, etc.) über das Dashboard anzeigen Device Information (
0x15
REQ_ARW_DAT_ALL
) SubCmd Kommandos #145 - AlarmData & AlarmUpdate Parsen und auf eigener Seite darstellen
------------------ SWIM LANE ---------------------------
- HM300
- Device Control Kommandos aus dem Setup ermöglichen (TurnOn, TurnOff, Restart, ActivePower Limit, ReactivePower Limit, SetPowerFactor, etc.)
- Settings exportieren / importieren (API/UI)
- Settings in settings.ini speichern (LittleFS statt EEPROM) Settings in settings.ini speichern (LittleFS statt EEPROM) #164
- Homepage aufräumen nur ein Status (aktuell drei AJAX Calls /uptime, /time, /cmdstat)
- app.cpp aufräumen und in hmRadio / hmProtokollGen3 auslagern
- MI Wechselrichter unterstützen (miSystem, miInverter, miDefines, miProtokollGen2 etc.)
- nRF24 Interrupt Handling sinnvoll oder warum macht die nRF24 Bibliothek ständig
0x07
Statusabfragen NRF24 polling trotz aktiviertem IRQ #83 - Debug Level im Setup änderbar -auch Livedata Visualisierung abschalten ?
- MQTT Discovery (HomeAssistant) im Setup optional machen
- MQTT Subscribe nur beim Reconnect Das subscribe in der Reconnect Procedure sollte doch nur nach einem conect ausgeführt werden und nicht bei jedem Duchlauf #139