5 namespace growatt_solar {
7 static const char *
const TAG =
"growatt_solar";
9 static const uint8_t MODBUS_CMD_READ_IN_REGISTERS = 0x04;
10 static const uint8_t MODBUS_REGISTER_COUNT[] = {33, 95};
17 auto publish_1_reg_sensor_state = [&](
sensor::Sensor *sensor,
size_t i,
float unit) ->
void {
18 if (sensor ==
nullptr)
20 float value =
encode_uint16(data[i * 2], data[i * 2 + 1]) * unit;
24 auto publish_2_reg_sensor_state = [&](
sensor::Sensor *sensor,
size_t reg1,
size_t reg2,
float unit) ->
void {
25 float value = ((
encode_uint16(data[reg1 * 2], data[reg1 * 2 + 1]) << 16) +
28 if (sensor !=
nullptr)
38 publish_1_reg_sensor_state(this->
pvs_[0].voltage_sensor_, 3, ONE_DEC_UNIT);
39 publish_1_reg_sensor_state(this->
pvs_[0].current_sensor_, 4, ONE_DEC_UNIT);
40 publish_2_reg_sensor_state(this->
pvs_[0].active_power_sensor_, 5, 6, ONE_DEC_UNIT);
42 publish_1_reg_sensor_state(this->
pvs_[1].voltage_sensor_, 7, ONE_DEC_UNIT);
43 publish_1_reg_sensor_state(this->
pvs_[1].current_sensor_, 8, ONE_DEC_UNIT);
44 publish_2_reg_sensor_state(this->
pvs_[1].active_power_sensor_, 9, 10, ONE_DEC_UNIT);
49 publish_1_reg_sensor_state(this->
phases_[0].voltage_sensor_, 14, ONE_DEC_UNIT);
50 publish_1_reg_sensor_state(this->
phases_[0].current_sensor_, 15, ONE_DEC_UNIT);
51 publish_2_reg_sensor_state(this->
phases_[0].active_power_sensor_, 16, 17, ONE_DEC_UNIT);
53 publish_1_reg_sensor_state(this->
phases_[1].voltage_sensor_, 18, ONE_DEC_UNIT);
54 publish_1_reg_sensor_state(this->
phases_[1].current_sensor_, 19, ONE_DEC_UNIT);
55 publish_2_reg_sensor_state(this->
phases_[1].active_power_sensor_, 20, 21, ONE_DEC_UNIT);
57 publish_1_reg_sensor_state(this->
phases_[2].voltage_sensor_, 22, ONE_DEC_UNIT);
58 publish_1_reg_sensor_state(this->
phases_[2].current_sensor_, 23, ONE_DEC_UNIT);
59 publish_2_reg_sensor_state(this->
phases_[2].active_power_sensor_, 24, 25, ONE_DEC_UNIT);
72 publish_1_reg_sensor_state(this->
pvs_[0].voltage_sensor_, 3, ONE_DEC_UNIT);
73 publish_1_reg_sensor_state(this->
pvs_[0].current_sensor_, 4, ONE_DEC_UNIT);
74 publish_2_reg_sensor_state(this->
pvs_[0].active_power_sensor_, 5, 6, ONE_DEC_UNIT);
76 publish_1_reg_sensor_state(this->
pvs_[1].voltage_sensor_, 7, ONE_DEC_UNIT);
77 publish_1_reg_sensor_state(this->
pvs_[1].current_sensor_, 8, ONE_DEC_UNIT);
78 publish_2_reg_sensor_state(this->
pvs_[1].active_power_sensor_, 9, 10, ONE_DEC_UNIT);
83 publish_1_reg_sensor_state(this->
phases_[0].voltage_sensor_, 38, ONE_DEC_UNIT);
84 publish_1_reg_sensor_state(this->
phases_[0].current_sensor_, 39, ONE_DEC_UNIT);
85 publish_2_reg_sensor_state(this->
phases_[0].active_power_sensor_, 40, 41, ONE_DEC_UNIT);
87 publish_1_reg_sensor_state(this->
phases_[1].voltage_sensor_, 42, ONE_DEC_UNIT);
88 publish_1_reg_sensor_state(this->
phases_[1].current_sensor_, 43, ONE_DEC_UNIT);
89 publish_2_reg_sensor_state(this->
phases_[1].active_power_sensor_, 44, 45, ONE_DEC_UNIT);
91 publish_1_reg_sensor_state(this->
phases_[2].voltage_sensor_, 46, ONE_DEC_UNIT);
92 publish_1_reg_sensor_state(this->
phases_[2].current_sensor_, 47, ONE_DEC_UNIT);
93 publish_2_reg_sensor_state(this->
phases_[2].active_power_sensor_, 48, 49, ONE_DEC_UNIT);
105 ESP_LOGCONFIG(TAG,
"GROWATT Solar:");
106 ESP_LOGCONFIG(TAG,
" Address: 0x%02X", this->
address_);
struct esphome::growatt_solar::GrowattSolar::GrowattPhase phases_[3]
struct esphome::growatt_solar::GrowattSolar::GrowattPV pvs_[2]
sensor::Sensor * today_production_
sensor::Sensor * inverter_status_
void dump_config() override
sensor::Sensor * pv_active_power_sensor_
sensor::Sensor * grid_active_power_sensor_
void publish_state(float state)
Publish a new state to the front-end.
sensor::Sensor * grid_frequency_sensor_
constexpr uint16_t encode_uint16(uint8_t msb, uint8_t lsb)
Encode a 16-bit value given the most and least significant byte.
GrowattProtocolVersion protocol_version_
void on_modbus_data(const std::vector< uint8_t > &data) override
sensor::Sensor * total_energy_production_
void send(uint8_t function, uint16_t start_address, uint16_t number_of_entities, uint8_t payload_len=0, const uint8_t *payload=nullptr)
Base-class for all sensors.
sensor::Sensor * inverter_module_temp_