From 7aea97a4fca0e7b9057e2418ad2ec00fe45f00ad Mon Sep 17 00:00:00 2001 From: Michael Joyce Date: Tue, 9 Mar 2021 15:08:23 -0800 Subject: [PATCH] Issue #198 - Address stagnant DN to EU value issue Update the packet diffing code so a fields raw / DNtoEU value is always included in the diff if a DNtoEU is defined for that field. This ensures that fields with "complex" DNtoEU functions which take multiple input values or rely on other means to determine a value will always be updated. This does mean that we're performing some "unnecessary" DNtoEU conversions but in practice I expect this to have no noticeable impact on performance. Resolve #198 --- ait/gui/__init__.py | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/ait/gui/__init__.py b/ait/gui/__init__.py index 280d094..8693c71 100644 --- a/ait/gui/__init__.py +++ b/ait/gui/__init__.py @@ -776,12 +776,17 @@ def get_packet_delta(pkt_defn, packet): delta, dntoeus = {}, {} for field in pkt_defn.fields: - new_value = getattr(ait_pkt.raw, field.name) - last_value = packet_states[pkt_defn.name]['raw'][field.name] - - if new_value != last_value: - delta[field.name] = new_value - packet_states[pkt_defn.name]['raw'][field.name] = new_value + new_raw = getattr(ait_pkt.raw, field.name) + last_raw = packet_states[pkt_defn.name]['raw'][field.name] + + # A field update needs sent when the raw value has changed or if a + # DN to EU is defined on the field. DN to EUs can take multiple + # telemetry points as input or may rely on other means to determine + # a value. We can't be sure that they won't change so we should + # always calculate them. + if new_raw != last_raw or field.dntoeu is not None: + delta[field.name] = new_raw + packet_states[pkt_defn.name]['raw'][field.name] = new_raw if field.dntoeu is not None or field.enum is not None or field.type.name in dtype.ComplexTypeMap.keys(): try: