runner.py 3.1 KB

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