From 31b626a1b5c7385211d5ff5b21cd7dde9396c1b1 Mon Sep 17 00:00:00 2001 From: pgleeson Date: Wed, 21 Aug 2024 16:16:49 +0100 Subject: [PATCH] Temp partial fix for parametercondition issue --- src/modeci_mdf/execution_engine.py | 17 ++++++++++++++--- src/modeci_mdf/interfaces/graphviz/exporter.py | 14 +++++++++++--- 2 files changed, 25 insertions(+), 6 deletions(-) diff --git a/src/modeci_mdf/execution_engine.py b/src/modeci_mdf/execution_engine.py index 50558b49..e5429757 100644 --- a/src/modeci_mdf/execution_engine.py +++ b/src/modeci_mdf/execution_engine.py @@ -586,15 +586,26 @@ def evaluate( if len(self.parameter.conditions) > 0: for condition in self.parameter.conditions: + + test = ( + condition.test if hasattr(condition, "test") else condition["test"] + ) + value = ( + condition.value + if hasattr(condition, "value") + else condition["value"] + ) + cond_id = condition.id if hasattr(condition, "id") else condition["id"] + cond_mask = evaluate_expr( - condition.test, + test, parameters, verbose=False, array_format=array_format, ) val_if_true = evaluate_expr( - condition.value, + value, parameters, verbose=False, array_format=array_format, @@ -603,7 +614,7 @@ def evaluate( if self.verbose: print( " --- Condition: %s: %s = %s: true? %s" - % (condition.id, condition.test, val_if_true, cond_mask) + % (cond_id, test, val_if_true, cond_mask) ) # e.g. if the parameter value is set only by a set of conditions... diff --git a/src/modeci_mdf/interfaces/graphviz/exporter.py b/src/modeci_mdf/interfaces/graphviz/exporter.py index 770b45d2..b928e0bc 100644 --- a/src/modeci_mdf/interfaces/graphviz/exporter.py +++ b/src/modeci_mdf/interfaces/graphviz/exporter.py @@ -352,12 +352,20 @@ def mdf_to_graphviz( p.time_derivative, node ) for cond in p.conditions: - test = cond.test.replace(">", ">").replace("<", "<") + cond_test = ( + cond.test if hasattr(cond, "test") else cond["test"] + ) + cond_value = ( + cond.value if hasattr(cond, "value") else cond["value"] + ) + cond_id = cond.id if hasattr(cond, "id") else cond["id"] + + test = cond_test.replace(">", ">").replace("<", "<") v += "
{}: IF {} THEN {}={}".format( - cond.id, + cond_id, match_in_expr(test, node), format_param(p.id), - match_in_expr(cond.value, node), + match_in_expr(cond_value, node), ) info += "{}{} = {}".format( format_label(" "),