Epever ESPHome
Hardware
The current (v1.7) version of the board works natively with ESPHome but if you have an older version of the board then a hardware modification will be required. This is bridging D1 and D2, this needs to be done as DE and RE were originally configured to be used independly but ESPHome can only have one configured flow control pin.
Software
An example yaml configuration file is available at Link
The following is breakdown of the sections of the example configuration files to allow you to create the setup that you require.
Configuration file
modbus:
flow_control_pin: D1
id: modbus1
send_wait_time: 200ms
uart:
id: mod_bus
tx_pin: TX
rx_pin: RX
baud_rate: 9600
stop_bits: 1
These two sections tell ESPHOME that we are going to be using modbus for communicating with the Inverter and the pins we shall be using for sending / receiving and also the flow control pin which controls when the device will be sending or receiving data.
modbus_controller:
- id: solis
## the Modbus device addr
address: 0xA
modbus_id: modbus1
setup_priority: -10
command_throttle: 300ms
update_interval: 30s
the next important configuration is to define a modbus controller which uses the id which created earlier. One important setting here is the
address: 0x1
this tells esphome what id the inverter is configured for, by default most epever charge controllers use an ID of 1. Please note that the value is in hex so for example the value for 10 would be 0xA. If you have modified your inverter to use something different then you shall need to update the value accordingly.
For reading information you must configure every value you which to read/write. Here we refer to the modbus controller which we have setup in the modbus_controller_id.
sensor:
- platform: modbus_controller
modbus_controller_id: solis
id: inverter_tempterature
name: "Inverter Temperature"
address: 33093
unit_of_measurement: "°C"
register_type: read
value_type: U_WORD
accuracy_decimals: 1
filters:
- multiply: 0.1
To breakdown each item
id: inverter_tempterature
This is an ID which you assign to the device which will be used within Home Assistant.
name: "Inverter Temperature"
This is a friendly name which we shall be assigned and used within Home Assistant.
address: 33093
This part is very important as it is the address which ESPHOME will use for reading. This is unique for every item you wish to read and you should be able to find a list of what registers are available for your inverter from Solis.
unit_of_measurement: "°C"
As per the name this defines the unit of measurement be it degree in this example of V for voltage.
register_type: read
This defines if the registers is a read or write type. Typically most registers are read only.
value_type: U_WORD
This defines the length of the data being read, typically this is a UWORD for a single item.
accuracy_decimals: 1
This tells ESPHOME how you wish to present the data, you can have 1 decimal place as in this example or 2 or even 0 for no decimal places and just whole numbers.
filters:
- multiply: 0.1
Lastly this defines the multiplying factor. Registers show a larger number than is shown so a multiplying factor must be set so that it returns a valid figure.