live_modelling_CBD.py 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. import sys
  2. sys.path.append("wrappers")
  3. from modelverse import *
  4. init()
  5. login("admin", "admin")
  6. model_add("formalisms/CBD/Design_MM", "formalisms/SimpleClassDiagrams", open("models/CBD/metamodels/CBD_MM.mvc", 'r').read())
  7. model_add("formalisms/CBD/PartialRuntime_MM", "formalisms/SimpleClassDiagrams", open("models/CBD/metamodels/CBD_MM_partial_runtime.mvc", 'r').read())
  8. model_add("formalisms/CBD/FullRuntime_MM", "formalisms/SimpleClassDiagrams", open("models/CBD/metamodels/CBD_MM_runtime.mvc", 'r').read())
  9. model_add("models/CBD_spring", "formalisms/CBD/Design_MM", open("models/CBD/models/cbd_spring.mvc", 'r').read())
  10. transformation_add_MANUAL({"Design": "formalisms/CBD/Design_MM"}, {"Design": "formalisms/CBD/Design_MM"}, "models/CBD/edit")
  11. def trace_D2P(model):
  12. instantiate(model, "Association", ("Design/Block", "PartialRuntime/Block"), ID="D2P_block")
  13. transformation_add_AL({"Design": "formalisms/CBD/Design_MM", "PartialRuntime": "formalisms/CBD/PartialRuntime_MM"}, {"PartialRuntime": "formalisms/CBD/PartialRuntime_MM"}, "models/CBD/toRuntime", open("models/CBD/transformations/to_runtime.alc", 'r').read(), trace_D2P)
  14. def trace_P2F(model):
  15. instantiate(model, "Association", ("PartialRuntime/Block", "FullRuntime/Block"), ID="P2F_block")
  16. transformation_add_AL({"PartialRuntime": "formalisms/CBD/PartialRuntime_MM", "FullRuntime": "formalisms/CBD/FullRuntime_MM"}, {"NewFullRuntime": "formalisms/CBD/FullRuntime_MM"}, "models/CBD/merge", open("models/CBD/transformations/merge.alc", 'r').read(), trace_P2F)
  17. transformation_add_AL({"FullRuntime": "formalisms/CBD/FullRuntime_MM"}, {"FullRuntime": "formalisms/CBD/FullRuntime_MM"}, "models/CBD/simulate", open("models/CBD/transformations/simulate.alc", 'r').read())
  18. transformation_add_AL({}, {}, "models/CBD/restartSim", open("models/generic/restart_simulation.alc", 'r').read())
  19. model_add("models/live_modelling_CBD", "formalisms/ProcessModel", open("models/CBD/PM_live_modelling.mvc", 'r').read())
  20. def modify_model(model):
  21. print("Modifying model in edit operation")
  22. if len(all_instances(model, "Design/ProbeBlock")) > 2:
  23. import time
  24. print("Sufficient Probeblocks detected, so pausing with edits")
  25. while 1:
  26. time.sleep(1)
  27. print("Will modify!")
  28. new_block = instantiate(model, "Design/ProbeBlock")
  29. attr_assign(model, new_block, "name", "MyProbeBlock")
  30. print("Added new probeblock: " + new_block)
  31. process_execute("models/live_modelling_CBD", {"design_model": "models/CBD_spring"}, {"models/CBD/edit": modify_model})