runner.py 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. from state.devstate import DevState
  2. from api.od import ODAPI
  3. from concrete_syntax.textual_od.renderer import render_od
  4. from bootstrap.scd import bootstrap_scd
  5. from util import loader
  6. from transformation.rule import RuleMatcherRewriter, ActionGenerator
  7. from transformation.ramify import ramify
  8. from examples.semantics.operational import simulator
  9. from examples.petrinet.renderer import render_petri_net
  10. if __name__ == "__main__":
  11. import os
  12. THIS_DIR = os.path.dirname(__file__)
  13. # get file contents as string
  14. def read_file(filename):
  15. with open(THIS_DIR+'/'+filename) as file:
  16. return file.read()
  17. state = DevState()
  18. scd_mmm = bootstrap_scd(state)
  19. # Read models from their files
  20. mm_cs = read_file('metamodels/mm_design.od')
  21. mm_rt_cs = mm_cs + read_file('metamodels/mm_runtime.od')
  22. m_cs = read_file('models/m_example_simple.od')
  23. m_rt_initial_cs = m_cs + read_file('models/m_example_simple_rt_initial.od')
  24. # m_cs = read_file('models/m_example_mutex.od')
  25. # m_rt_initial_cs = m_cs + read_file('models/m_example_mutex_rt_initial.od')
  26. # Parse them
  27. mm = loader.parse_and_check(state, mm_cs, scd_mmm, "Petri-Net Design meta-model")
  28. mm_rt = loader.parse_and_check(state, mm_rt_cs, scd_mmm, "Petri-Net Runtime meta-model")
  29. m = loader.parse_and_check(state, m_cs, mm, "Example model")
  30. m_rt_initial = loader.parse_and_check(state, m_rt_initial_cs, mm_rt, "Example model initial state")
  31. mm_rt_ramified = ramify(state, mm_rt)
  32. rules = loader.load_rules(state,
  33. lambda rule_name, kind: f"{THIS_DIR}/operational_semantics/r_{rule_name}_{kind}.od",
  34. mm_rt_ramified,
  35. ["fire_transition"]) # only 1 rule :(
  36. matcher_rewriter = RuleMatcherRewriter(state, mm_rt, mm_rt_ramified)
  37. action_generator = ActionGenerator(matcher_rewriter, rules)
  38. sim = simulator.Simulator(
  39. action_generator=action_generator,
  40. decision_maker=simulator.InteractiveDecisionMaker(auto_proceed=False),
  41. # decision_maker=simulator.RandomDecisionMaker(seed=0),
  42. renderer=lambda od: render_petri_net(od) + render_od(state, od.m, od.mm),
  43. )
  44. sim.run(ODAPI(state, m_rt_initial, mm_rt))