summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorDaniel Friesel <derf@finalrewind.org>2019-03-01 14:51:35 +0100
committerDaniel Friesel <derf@finalrewind.org>2019-03-01 14:51:35 +0100
commit8e07e6b127c6481eedd208e7901440be9b2e60fb (patch)
tree8ea6e69b8ad4f587d5f8abd591144429dc95672f /lib
parent5aa3a8d691c7a0a4b7eda3546b61281bb8638932 (diff)
PTA.from_json: Only generate AnalyticFunction if it is set
Diffstat (limited to 'lib')
-rwxr-xr-xlib/automata.py5
1 files changed, 3 insertions, 2 deletions
diff --git a/lib/automata.py b/lib/automata.py
index 7db1ebf..922cdaf 100755
--- a/lib/automata.py
+++ b/lib/automata.py
@@ -386,7 +386,7 @@ class PTA:
See the State() documentation for acceptable arguments.
"""
- if 'power_function' in kwargs and type(kwargs['power_function']) != AnalyticFunction:
+ if 'power_function' in kwargs and type(kwargs['power_function']) != AnalyticFunction and kwargs['power_function'] != None:
kwargs['power_function'] = AnalyticFunction(kwargs['power_function'],
self.parameters, 0)
self.state[state_name] = State(state_name, **kwargs)
@@ -404,7 +404,7 @@ class PTA:
orig_state = self.state[orig_state]
dest_state = self.state[dest_state]
for key in ('duration_function', 'energy_function', 'timeout_function'):
- if key in kwargs and type(kwargs[key]) != AnalyticFunction:
+ if key in kwargs and kwargs[key] != None and type(kwargs[key]) != AnalyticFunction:
kwargs[key] = AnalyticFunction(kwargs[key], self.parameters, 0)
new_transition = Transition(orig_state, dest_state, function_name, **kwargs)
@@ -412,6 +412,7 @@ class PTA:
orig_state.add_outgoing_transition(new_transition)
def get_transition_id(self, transition: Transition) -> int:
+ """Return PTA-specific ID of transition."""
return self.transitions.index(transition)
def dfs(self, depth: int = 10, orig_state: str = 'UNINITIALIZED', **kwargs):