You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
lumapu 200ce0c0cc * Merge branch 'development03' into asyncWeb03 2 years ago
..
html * Merge branch 'development03' into asyncWeb03 2 years ago
include ESP32 support added 2 years ago
scripts added esp32 to release work flow 2 years ago
.gitignore - Improve config system allowing a user customizable config_override.h file to ensure git pulls don't require merges 2 years ago
CHANGES.md documentation and service release 2 years ago
CircularBuffer.h ESP32 support added 2 years ago
README.md * Merge branch 'development03' into asyncWeb03 2 years ago
User_Manual.md Merge branch 'main' into development03 2 years ago
ahoywifi.cpp ESP32 support added 2 years ago
ahoywifi.h /setup geht noch nicht 2 years ago
app.cpp * Merge branch 'development03' into asyncWeb03 2 years ago
app.h * Merge branch 'development03' into asyncWeb03 2 years ago
config.h Set default NTP Port to 123 2 years ago
config_override_example.h - Improve config system allowing a user customizable config_override.h file to ensure git pulls don't require merges 2 years ago
crc.cpp first changes to prepare code for esp32 2 years ago
crc.h first changes to prepare code for esp32 2 years ago
defines.h * Merge branch 'development03' into asyncWeb03 2 years ago
eep.h ESP32 support added 2 years ago
hmDefines.h fix in parser for 1CH inverters 2 years ago
hmInverter.h speed up set power limit 2 years ago
hmRadio.h Merge branch 'development02' into config_override 2 years ago
hmSystem.h added command queue 2 years ago
main.cpp * first refactored version which is accessible through web interface 2 years ago
mqtt.h MQTT reconnect delay, fixed ESP32 build 2 years ago
platformio.ini Merge branch 'development02' into asyncWeb02 2 years ago
tmplProc.h /setup geht noch nicht 2 years ago
web.cpp * Merge branch 'development03' into asyncWeb03 2 years ago
web.h * start creation of visualisation api contents 2 years ago
webApi.cpp * Merge branch 'development03' into asyncWeb03 2 years ago
webApi.h * start creation of visualisation api contents 2 years ago

README.md

Table of Contents


Overview

This page describes how the module of a Wemos D1 mini and ESP8266 is wired to the radio module and is flashed with the latest Firmware.
Further information will help you to communicate to the compatible inverters.

Compatiblity

For now the following Inverters should work out of the box:

Hoymiles Inverters

  • HM300
  • HM350
  • HM400
  • HM600
  • HM700
  • HM800
  • HM1000?
  • HM1200
  • HM1500

TSun Inverters:

  • TSOL-350
  • TSOL-400
  • othery may work as well (need to be veryfied).

Things needed

In order to build your own Ahoy DTU, you will need some things.
This list is not closing as the Maker Community offers more Boards than we could cover in this Readme.

We suggest to use a WEMOS D1 mini Board as well as a NRF24L01+ Breakout Board.
Make sure it has the "+" in its name as we depend on some features provided with the plus-variant.
Any other ESP8266 Board with at least 4MBytes of ROM could work as well, depending on your skills.

There are fake NRF24L01+ Modules out there

Whatch out, there are some fake NRF24L01+ Modules out there that seem to use rebranded NRF24L01 Chips (without the +).
An example can be found in Issue #230.
You are welcome to add more examples of faked chips. We will that information here.

Wiring things up

The NRF24L01+ radio module is connected to the standard SPI pins:

  • SCLK (Signal Clock),
  • MISO (Master In Slave Out) and
  • MOSI (Master Out Slave In)

These pins need to be configured in the config.h.

Additional, there are 3 pins, which can be set individual:

  • CS (Chip Select),
  • CE (Chip Enable) and
  • IRQ (Interrupt)

These pins can be changed from the /setup URL.

ESP8266 wiring example

This is an example wiring using a Wemos D1 mini.

Flash the Firmware on your Ahoy DTU Hardware

Once your Hardware is ready to run, you need to flash the Ahoy DTU Firmware to your Board. You can either build your own using your own configuration or use one or our pre-compiled generic builds.

Compiling your own Version

This information suits you if you want to configure and build your own firmware.

This code comes to you as a PlatformIO project and can be compiled using the PlatformIO Addon.
Visual Studio Code, AtomIDE and other IDE's support the PlatformIO Addon.
If you do not want to compile your own build, you can use one of our ready-to-flash binaries.

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.

Using a ready-to-flash binary using nodemcu-pyflasher

This information suits you if you just want to use an easy way.

  1. download the flash-tool nodemcu-pyflasher
  2. download latest release bin-file from ahoy_
  3. open flash-tool and connect the target device to your computer.
  4. Set the correct serial port and select the correct *.bin file
  5. click on "Flash NodeMCU"
  6. flash the ESP with the compiled firmware using the UART pins or
  7. repower the ESP
  8. the ESP will start as access point (AP) if there is no network config stored in its eeprom
  9. connect to the AP, you will be forwarded to the setup page
  10. configure your WiFi settings, save, repower
  11. check your router or serial console for the IP address of the module. You can try ping the configured device name as well.

Once your Ahoy DTU is running, you can use the Over The Air (OTA) capabilities to update your firmware.

! ATTENTION: If you update from a very low version to the newest, please make sure to wipe all flash data!

Connect to your Ahoy DTU

When everything is wired up and the firmware is flashed, it is time to connect to your Ahoy DTU.

Your Ahoy DTU is very verbose using the Serial Console

When connected to your computer, you can open a Serial Console to obtain additional information.
This might be useful in case of any troubles that might occur as well as to simply
obtain information about the converted values which were read out of the inverter(s).

Connect to the Ahoy DTU Webinterface using your Browser

After you have sucessfully flashed and powered your Ahoy DTU, you can access it via your Browser.
If your Ahoy DTU was able to log into the configured WiFi Network, it will try to obtain an IP-Address
from your local DHCP Server (in most cases thats your Router).

In case it could not connect to your configured Network, it will provide its own WiFi Network that you can
connect to for furter configuration.
The WiFi SSID (the WiFi Name) and Passwort is configured in the config.h and defaults to the SSID "AHOY-DTU" with the Passwort "esp_8266".
The Ahoy DTU will keep that Network open for a certain amount of time (also configurable in the config.h and defaults to 60secs).
If nothing connects to it and that time runs up, it will retry to connect to the configured network an so on.

If connected to your local Network, you just have to find out the used IP Address. In most cases your Router will give you a hint.
If you connect to the WiFi the Ahoy DTU opens in case it could not connect to any other Network, the IP-Address of your Ahoy DTU is 192.168.1.1.
Just open the IP-Address in your browser.

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)
HTTP based Pages

To take control of your Ahoy DTU, you can directly call one of the following sub-pages (e.g. http://192.168.1.1/setup ).

page use output
/uptime displays the uptime uf your Ahoy DTU 0 Days, 01:37:34; now: 2022-08-21 11:13:53
/reboot reboots the Ahoy DTU
/erase erases the EEPROM
/factory resets to the factory defaults configured in config.h
/setup opens the setup page
/save
/cmdstat show stat from the home page
/visualization displays the information from your converter
/livedata displays the live data
/json gets live-data in JSON format json output from the livedata
/api

MQTT command to set the DTU without webinterface

Read here

Used Libraries

Name version License
ESP8266WiFi 1.0 LGPL-2.1
DNSServer 1.1.1 LGPL-2.1
SPI 1.0 LGPL-2.1
Hash 1.0 LGPL-2.1
EEPROM 1.0 LGPL-2.1
ESP Async WebServer 1.2.3 LGPL-3.0
ESPAsyncTCP 1.2.2 LGPL-3.0
Time 1.6.1 LGPL-2.1
RF24 1.4.5 GPL-2.0
PubSubClient 2.8 MIT
ArduinoJson 6.19.4 MIT

Contact

We run a Discord Server that can be used to get in touch with the Developers and Users.

https://discord.gg/WzhxEY62mB

ToDo

See this post