From 91ca06b772dae15c04b6a2e944bff3b4ae78ef5c Mon Sep 17 00:00:00 2001 From: Paul Frank Date: Thu, 30 May 2024 13:51:38 +0000 Subject: [PATCH] revert assignment only if it increases --- .../stiebel_eltron_isg/wpm_coordinator.py | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/custom_components/stiebel_eltron_isg/wpm_coordinator.py b/custom_components/stiebel_eltron_isg/wpm_coordinator.py index b5ff79c..3610dc2 100644 --- a/custom_components/stiebel_eltron_isg/wpm_coordinator.py +++ b/custom_components/stiebel_eltron_isg/wpm_coordinator.py @@ -690,18 +690,18 @@ def read_modbus_energy(self) -> dict: decoder = BinaryPayloadDecoder.fromRegisters( inverter_data.registers, byteorder=Endian.BIG ) - produced_heating_today = self.assign_if_increased(decoder.decode_16bit_uint(), PRODUCED_HEATING_TODAY) + produced_heating_today = decoder.decode_16bit_uint() produced_heating_total_low = decoder.decode_16bit_uint() produced_heating_total_high = decoder.decode_16bit_uint() - produced_water_today = self.assign_if_increased(decoder.decode_16bit_uint(), PRODUCED_WATER_HEATING_TODAY) + produced_water_today = decoder.decode_16bit_uint() produced_water_total_low = decoder.decode_16bit_uint() produced_water_total_high = decoder.decode_16bit_uint() decoder.skip_bytes(8) # Skip NHZ - consumed_heating_today = self.assign_if_increased(decoder.decode_16bit_uint(), CONSUMED_HEATING_TODAY) + consumed_heating_today = decoder.decode_16bit_uint() consumed_heating_total_low = decoder.decode_16bit_uint() consumed_heating_total_high = decoder.decode_16bit_uint() - consumed_water_today = self.assign_if_increased(decoder.decode_16bit_uint(), CONSUMED_WATER_HEATING_TODAY) + consumed_water_today = decoder.decode_16bit_uint() consumed_water_total_low = decoder.decode_16bit_uint() consumed_water_total_high = decoder.decode_16bit_uint() @@ -731,9 +731,8 @@ def read_modbus_energy(self) -> dict: ) result[CONSUMED_WATER_HEATING_TODAY] = consumed_water_today - result[CONSUMED_WATER_HEATING_TOTAL] = self.assign_if_increased( - consumed_water_total_high * 1000 + consumed_water_total_low, CONSUMED_WATER_HEATING_TOTAL - ) + result[CONSUMED_WATER_HEATING_TOTAL] = consumed_water_total_high * 1000 + consumed_water_total_low, CONSUMED_WATER_HEATING_TOTAL + result[CONSUMED_WATER_HEATING] = self.assign_if_increased( result[CONSUMED_WATER_HEATING_TOTAL] + result[CONSUMED_WATER_HEATING_TODAY], CONSUMED_WATER_HEATING