|
|
@@ -0,0 +1,79 @@
|
|
|
+from state.devstate import DevState
|
|
|
+from bootstrap.scd import bootstrap_scd
|
|
|
+from concrete_syntax.textual_od import parser, renderer
|
|
|
+from concrete_syntax.plantuml.renderer import render_object_diagram, render_class_diagram
|
|
|
+from concrete_syntax.plantuml.make_url import make_url
|
|
|
+from api.od import ODAPI
|
|
|
+
|
|
|
+from transformation.ramify import ramify
|
|
|
+from transformation.topify.topify import Topifier
|
|
|
+from transformation.merger import merge_models
|
|
|
+from transformation.ramify import ramify
|
|
|
+from transformation.rule import RuleMatcherRewriter, ActionGenerator
|
|
|
+
|
|
|
+from util import loader
|
|
|
+
|
|
|
+from examples.semantics.operational.simulator import Simulator, RandomDecisionMaker, InteractiveDecisionMaker
|
|
|
+from examples.semantics.operational.port import models
|
|
|
+from examples.semantics.operational.port.helpers import design_to_state, state_to_design, get_time
|
|
|
+from examples.semantics.operational.port.renderer import render_port_textual, render_port_graphviz
|
|
|
+from examples.petrinet.renderer import render_petri_net
|
|
|
+from examples.semantics.operational import simulator
|
|
|
+
|
|
|
+import os
|
|
|
+import sys
|
|
|
+THIS_DIR = os.path.dirname(__file__)
|
|
|
+
|
|
|
+# get file contents as string
|
|
|
+def read_file(filename):
|
|
|
+ with open(THIS_DIR+'/'+filename) as file:
|
|
|
+ return file.read()
|
|
|
+
|
|
|
+if __name__ == "__main__":
|
|
|
+ if len(sys.argv) != 2:
|
|
|
+ print("Usage:")
|
|
|
+ print(f" python {__file__} model.od")
|
|
|
+ print("where `model.od` is a valid instance of Port+Petri-Net.")
|
|
|
+ sys.exit(1)
|
|
|
+
|
|
|
+ model_to_open = sys.argv[1]
|
|
|
+
|
|
|
+ state = DevState()
|
|
|
+ scd_mmm = bootstrap_scd(state)
|
|
|
+
|
|
|
+ print('loading merged MM...')
|
|
|
+ merged_mm = loader.parse_and_check(state, read_file("merged_mm.od"), scd_mmm, "merged_mm.od",
|
|
|
+ check_conformance=False, # no need to check conformance every time
|
|
|
+ )
|
|
|
+
|
|
|
+ print('ramifying...')
|
|
|
+ ramified_merged_mm = ramify(state, merged_mm)
|
|
|
+
|
|
|
+ print('loading petri net rules...')
|
|
|
+ rules = loader.load_rules(state,
|
|
|
+ lambda rule_name, kind: f"{THIS_DIR}/../../petrinet/operational_semantics/r_{rule_name}_{kind}.od",
|
|
|
+ ramified_merged_mm,
|
|
|
+ ["fire_transition"])
|
|
|
+
|
|
|
+ print('loading model...')
|
|
|
+ filename = f"{THIS_DIR}/{model_to_open}"
|
|
|
+ with open(filename, "r") as file:
|
|
|
+ model = loader.parse_and_check(state, file.read(), merged_mm, "model",
|
|
|
+ check_conformance=False, # no need to check conformance every time
|
|
|
+ )
|
|
|
+ print('loaded', filename)
|
|
|
+
|
|
|
+ print('ready!')
|
|
|
+
|
|
|
+ matcher_rewriter = RuleMatcherRewriter(state, merged_mm, ramified_merged_mm)
|
|
|
+ action_generator = ActionGenerator(matcher_rewriter, rules)
|
|
|
+
|
|
|
+ sim = simulator.Simulator(
|
|
|
+ action_generator=action_generator,
|
|
|
+ decision_maker=simulator.InteractiveDecisionMaker(auto_proceed=False),
|
|
|
+ # decision_maker=simulator.RandomDecisionMaker(seed=0),
|
|
|
+ renderer=lambda od: render_petri_net(od) + renderer.render_od(state, od.m, od.mm),
|
|
|
+ # renderer=lambda od: render_od(state, od.m, od.mm),
|
|
|
+ )
|
|
|
+
|
|
|
+ sim.run(ODAPI(state, model, merged_mm))
|