15 if (data.size() < MODBUS_REGISTER_COUNT * 2) {
16 ESP_LOGW(TAG,
"Invalid size for HavellsSolar!");
24 auto havells_solar_get_2_registers = [&](
size_t i,
float unit) ->
float {
25 uint32_t temp =
encode_uint32(data[i], data[i + 1], data[i + 2], data[i + 3]);
33 auto havells_solar_get_1_register = [&](
size_t i,
float unit) ->
float {
38 for (uint8_t i = 0; i < 3; i++) {
43 float voltage = havells_solar_get_1_register(HAVELLS_PHASE_1_VOLTAGE * 2 + (i * 4), ONE_DEC_UNIT);
44 float current = havells_solar_get_1_register(HAVELLS_PHASE_1_CURRENT * 2 + (i * 4), TWO_DEC_UNIT);
46 if (phase.voltage_sensor_ !=
nullptr)
47 phase.voltage_sensor_->publish_state(voltage);
48 if (phase.current_sensor_ !=
nullptr)
49 phase.current_sensor_->publish_state(current);
52 for (uint8_t i = 0; i < 2; i++) {
53 auto pv = this->
pvs_[i];
57 float voltage = havells_solar_get_1_register(HAVELLS_PV_1_VOLTAGE * 2 + (i * 4), ONE_DEC_UNIT);
58 float current = havells_solar_get_1_register(HAVELLS_PV_1_CURRENT * 2 + (i * 4), TWO_DEC_UNIT);
59 float active_power = havells_solar_get_1_register(HAVELLS_PV_1_POWER * 2 + (i * 2), MULTIPLY_TEN_UNIT);
60 float voltage_sampled_by_secondary_cpu =
61 havells_solar_get_1_register(HAVELLS_PV1_VOLTAGE_SAMPLED_BY_SECONDARY_CPU * 2 + (i * 2), ONE_DEC_UNIT);
62 float insulation_of_p_to_ground =
63 havells_solar_get_1_register(HAVELLS_PV1_INSULATION_OF_P_TO_GROUND * 2 + (i * 2), NO_DEC_UNIT);
65 if (pv.voltage_sensor_ !=
nullptr)
66 pv.voltage_sensor_->publish_state(voltage);
67 if (pv.current_sensor_ !=
nullptr)
68 pv.current_sensor_->publish_state(current);
69 if (pv.active_power_sensor_ !=
nullptr)
70 pv.active_power_sensor_->publish_state(active_power);
71 if (pv.voltage_sampled_by_secondary_cpu_sensor_ !=
nullptr)
72 pv.voltage_sampled_by_secondary_cpu_sensor_->publish_state(voltage_sampled_by_secondary_cpu);
73 if (pv.insulation_of_p_to_ground_sensor_ !=
nullptr)
74 pv.insulation_of_p_to_ground_sensor_->publish_state(insulation_of_p_to_ground);
77 float frequency = havells_solar_get_1_register(HAVELLS_GRID_FREQUENCY * 2, TWO_DEC_UNIT);
78 float active_power = havells_solar_get_1_register(HAVELLS_SYSTEM_ACTIVE_POWER * 2, MULTIPLY_TEN_UNIT);
79 float reactive_power = havells_solar_get_1_register(HAVELLS_SYSTEM_REACTIVE_POWER * 2, TWO_DEC_UNIT);
80 float today_production = havells_solar_get_1_register(HAVELLS_TODAY_PRODUCTION * 2, TWO_DEC_UNIT);
81 float total_energy_production = havells_solar_get_2_registers(HAVELLS_TOTAL_ENERGY_PRODUCTION * 2, NO_DEC_UNIT);
82 float total_generation_time = havells_solar_get_2_registers(HAVELLS_TOTAL_GENERATION_TIME * 2, NO_DEC_UNIT);
83 float today_generation_time = havells_solar_get_1_register(HAVELLS_TODAY_GENERATION_TIME * 2, NO_DEC_UNIT);
84 float inverter_module_temp = havells_solar_get_1_register(HAVELLS_INVERTER_MODULE_TEMP * 2, NO_DEC_UNIT);
85 float inverter_inner_temp = havells_solar_get_1_register(HAVELLS_INVERTER_INNER_TEMP * 2, NO_DEC_UNIT);
86 float inverter_bus_voltage = havells_solar_get_1_register(HAVELLS_INVERTER_BUS_VOLTAGE * 2, NO_DEC_UNIT);
87 float insulation_pv_n_to_ground = havells_solar_get_1_register(HAVELLS_INSULATION_OF_PV_N_TO_GROUND * 2, NO_DEC_UNIT);
88 float gfci_value = havells_solar_get_1_register(HAVELLS_GFCI_VALUE * 2, NO_DEC_UNIT);
89 float dci_of_r = havells_solar_get_1_register(HAVELLS_DCI_OF_R * 2, NO_DEC_UNIT);
90 float dci_of_s = havells_solar_get_1_register(HAVELLS_DCI_OF_S * 2, NO_DEC_UNIT);
91 float dci_of_t = havells_solar_get_1_register(HAVELLS_DCI_OF_T * 2, NO_DEC_UNIT);