metamodels.alc 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. include "primitives.alh"
  2. include "object_operations.alh"
  3. include "library.alh"
  4. include "conformance_scd.alh"
  5. include "modelling.alh"
  6. Element function constraint_integer(model : Element, name : String):
  7. if (is_physical_int(model["model"][name])):
  8. return "OK"
  9. else:
  10. return "Integer has non-integer instance"
  11. Element function create_metamodels():
  12. if (bool_not(dict_in(dict_read(read_root(), "__hierarchy"), "models"))):
  13. Element scd
  14. scd = instantiate_bottom()
  15. // Initial model, typed using LTM_bottom
  16. model_add_node(scd, "Class")
  17. model_add_node(scd, "Any")
  18. model_add_node(scd, "String")
  19. model_add_value(scd, "name", "name")
  20. model_add_edge(scd, "Association", "Class", "Any")
  21. model_add_edge(scd, "Inheritance", "Class", "Class")
  22. model_add_edge(scd, "Association_attribute", "Association", "String")
  23. model_add_edge(scd, "Association_name", "Association_attribute", "name")
  24. model_add_edge(scd, "assoc_inh_class", "Association", "Class")
  25. model_add_edge(scd, "class_inh_any", "Class", "Any")
  26. model_add_edge(scd, "string_inh_any", "String", "Any")
  27. // Retype to a "real" LTM, which happens to be itself
  28. retype_model(scd, scd)
  29. define_inheritance(scd, "Inheritance")
  30. retype(scd, "Class", "Class")
  31. retype(scd, "Any", "Class")
  32. retype(scd, "String", "Class")
  33. retype(scd, "name", "String")
  34. retype(scd, "Association", "Association")
  35. retype(scd, "Inheritance", "Association")
  36. retype(scd, "Association_attribute", "Association")
  37. retype(scd, "Association_name", "Association_attribute")
  38. retype(scd, "assoc_inh_class", "Inheritance")
  39. retype(scd, "class_inh_any", "Inheritance")
  40. retype(scd, "string_inh_any", "Inheritance")
  41. // Add some attributes, now that it is an ordinary model
  42. instantiate_node(scd, "Class", "Integer")
  43. instantiate_link(scd, "Association", "lc", "Class", "Integer")
  44. instantiate_attribute(scd, "lc", "name", "lower_cardinality")
  45. instantiate_link(scd, "Association", "uc", "Class", "Integer")
  46. instantiate_attribute(scd, "uc", "name", "upper_cardinality")
  47. instantiate_link(scd, "Association", "slc", "Association", "Integer")
  48. instantiate_attribute(scd, "slc", "name", "source_lower_cardinality")
  49. instantiate_link(scd, "Association", "suc", "Association", "Integer")
  50. instantiate_attribute(scd, "suc", "name", "source_upper_cardinality")
  51. instantiate_link(scd, "Association", "tlc", "Association", "Integer")
  52. instantiate_attribute(scd, "tlc", "name", "target_lower_cardinality")
  53. instantiate_link(scd, "Association", "tuc", "Association", "Integer")
  54. instantiate_attribute(scd, "tuc", "name", "target_upper_cardinality")
  55. // Add in the Action Language metamodel
  56. instantiate_node(scd, "Class", "Action")
  57. instantiate_node(scd, "Class", "Statement")
  58. instantiate_node(scd, "Class", "Expression")
  59. instantiate_node(scd, "Class", "funcdef")
  60. instantiate_node(scd, "Class", "param")
  61. instantiate_node(scd, "Class", "if")
  62. instantiate_node(scd, "Class", "break")
  63. instantiate_node(scd, "Class", "while")
  64. instantiate_node(scd, "Class", "continue")
  65. instantiate_node(scd, "Class", "assign")
  66. instantiate_node(scd, "Class", "return")
  67. instantiate_node(scd, "Class", "output")
  68. instantiate_node(scd, "Class", "declare")
  69. instantiate_node(scd, "Class", "global")
  70. instantiate_node(scd, "Class", "access")
  71. instantiate_node(scd, "Class", "constant")
  72. instantiate_node(scd, "Class", "input")
  73. instantiate_node(scd, "Class", "resolve")
  74. instantiate_node(scd, "Class", "call")
  75. instantiate_link(scd, "Association", "dict_link", "Action", "Any")
  76. instantiate_link(scd, "Association", "to_str", "dict_link", "String")
  77. instantiate_attribute(scd, "to_str", "name", "name")
  78. instantiate_link(scd, "Inheritance", "", "Action", "Any")
  79. instantiate_link(scd, "Inheritance", "", "funcdef", "Action")
  80. instantiate_link(scd, "Inheritance", "", "param", "Action")
  81. instantiate_link(scd, "Inheritance", "", "Statement", "Action")
  82. instantiate_link(scd, "Inheritance", "", "Expression", "Action")
  83. instantiate_link(scd, "Inheritance", "", "resolve", "Statement")
  84. instantiate_link(scd, "Inheritance", "", "if", "Statement")
  85. instantiate_link(scd, "Inheritance", "", "break", "Statement")
  86. instantiate_link(scd, "Inheritance", "", "continue", "Statement")
  87. instantiate_link(scd, "Inheritance", "", "global", "Statement")
  88. instantiate_link(scd, "Inheritance", "", "while", "Statement")
  89. instantiate_link(scd, "Inheritance", "", "assign", "Statement")
  90. instantiate_link(scd, "Inheritance", "", "return", "Statement")
  91. instantiate_link(scd, "Inheritance", "", "call", "Statement")
  92. instantiate_link(scd, "Inheritance", "", "declare", "Statement")
  93. instantiate_link(scd, "Inheritance", "", "call", "Expression")
  94. instantiate_link(scd, "Inheritance", "", "access", "Expression")
  95. instantiate_link(scd, "Inheritance", "", "constant", "Expression")
  96. instantiate_link(scd, "Inheritance", "", "input", "Expression")
  97. instantiate_link(scd, "Association", "statement_next", "Statement", "Statement")
  98. instantiate_link(scd, "Association", "if_cond", "if", "Expression")
  99. instantiate_link(scd, "Association", "if_true", "if", "Statement")
  100. instantiate_link(scd, "Association", "if_false", "if", "Statement")
  101. instantiate_link(scd, "Association", "while_cond", "while", "Expression")
  102. instantiate_link(scd, "Association", "while_body", "while", "Statement")
  103. instantiate_link(scd, "Association", "assign_var", "assign", "Any")
  104. instantiate_link(scd, "Association", "assign_value", "assign", "Expression")
  105. instantiate_link(scd, "Association", "break_while", "break", "while")
  106. instantiate_link(scd, "Association", "continue_while", "continue", "while")
  107. instantiate_link(scd, "Association", "return_value", "return", "Expression")
  108. instantiate_link(scd, "Association", "resolve_var", "resolve", "Any")
  109. instantiate_link(scd, "Association", "access_var", "access", "Any")
  110. instantiate_link(scd, "Association", "constant_node", "constant", "Any")
  111. instantiate_link(scd, "Association", "output_node", "output", "Expression")
  112. instantiate_link(scd, "Association", "global_var", "global", "String")
  113. instantiate_link(scd, "Association", "param_name", "param", "String")
  114. instantiate_link(scd, "Association", "param_value", "param", "Expression")
  115. instantiate_link(scd, "Association", "param_next_param", "param", "param")
  116. instantiate_link(scd, "Association", "funcdef_body", "funcdef", "Statement")
  117. instantiate_link(scd, "Association", "call_func", "call", "Expression")
  118. instantiate_link(scd, "Association", "call_params", "call", "param")
  119. instantiate_link(scd, "Association", "call_last_param", "call", "param")
  120. // Now still allow for constraints on classes
  121. instantiate_link(scd, "Association", "constraint", "Class", "funcdef")
  122. instantiate_attribute(scd, "constraint", "name", "constraint")
  123. // Finally done, so export!
  124. export_node("models/SimpleClassDiagrams", scd)
  125. // Now for some examples: a PetriNet
  126. Element pn
  127. pn = instantiate_model(scd)
  128. define_inheritance(pn, "Inheritance")
  129. instantiate_node(pn, "Class", "Place")
  130. instantiate_node(pn, "Class", "Transition")
  131. instantiate_node(pn, "Class", "Integer")
  132. instantiate_link(pn, "Association", "P2T", "Place", "Transition")
  133. instantiate_link(pn, "Association", "T2P", "Transition", "Place")
  134. instantiate_link(pn, "Association", "Place_tokens", "Place", "Integer")
  135. instantiate_attribute(pn, "Place_tokens", "name", "tokens")
  136. instantiate_attribute(pn, "Place_tokens", "target_lower_cardinality", 1)
  137. instantiate_attribute(pn, "Place_tokens", "target_upper_cardinality", 1)
  138. instantiate_link(pn, "Association", "P2T_weight", "P2T", "Integer")
  139. instantiate_attribute(pn, "P2T_weight", "name", "weight")
  140. instantiate_attribute(pn, "P2T_weight", "target_lower_cardinality", 1)
  141. instantiate_attribute(pn, "P2T_weight", "target_upper_cardinality", 1)
  142. instantiate_link(pn, "Association", "T2P_weight", "T2P", "Integer")
  143. instantiate_attribute(pn, "T2P_weight", "name", "weight")
  144. instantiate_attribute(pn, "T2P_weight", "target_lower_cardinality", 1)
  145. instantiate_attribute(pn, "T2P_weight", "target_upper_cardinality", 1)
  146. // Add constraint on the Integer
  147. add_constraint(pn, "Integer", constraint_integer)
  148. // Add global constraints
  149. set_model_constraints(pn, petrinet_constraints)
  150. export_node("models/PetriNets", pn)
  151. Element ltm_bottom
  152. ltm_bottom = instantiate_bottom()
  153. model_add_node(ltm_bottom, "Node")
  154. model_add_edge(ltm_bottom, "Edge", "Node", "Node")
  155. model_add_edge(ltm_bottom, "inheritance", "Node", "Node")
  156. model_add_edge(ltm_bottom, "__inh", "Edge", "Node")
  157. retype_model(ltm_bottom, ltm_bottom)
  158. define_inheritance(ltm_bottom, "inheritance")
  159. retype(ltm_bottom, "Node", "Node")
  160. retype(ltm_bottom, "Edge", "Edge")
  161. retype(ltm_bottom, "inheritance", "Edge")
  162. retype(ltm_bottom, "__inh", "inheritance")
  163. export_node("models/LTM_bottom", ltm_bottom)
  164. return dict_read(dict_read(read_root(), "__hierarchy"), "models")
  165. String function petrinet_constraints(model : Element):
  166. // Check places to have positive number of tokens
  167. Element all_elems
  168. String elem_constraint
  169. log("Check constraints")
  170. all_elems = allInstances(model, "Place")
  171. log("Got all instances")
  172. log("Length " + cast_i2s(list_len(all_elems)))
  173. log("First element: " + cast_e2s(all_elems[0]))
  174. while (0 < list_len(all_elems)):
  175. elem_constraint = set_pop(all_elems)
  176. log("Check Place " + elem_constraint)
  177. if (integer_lt(read_attribute(model, elem_constraint, "tokens"), 0)):
  178. return "Negative number of tokens in Place " + elem_constraint
  179. // Check P2T transitions to have positive weight
  180. log("Check constraints 2")
  181. all_elems = allInstances(model, "P2T")
  182. log("Got all instances")
  183. while (0 < read_nr_out(all_elems)):
  184. elem_constraint = set_pop(all_elems)
  185. log("Check P2T " + elem_constraint)
  186. if (integer_lt(read_attribute(model, elem_constraint, "weight"), 0)):
  187. return "Negative weight in arc " + elem_constraint
  188. // Check T2P transitions to have positive weight
  189. log("Check constraints 3")
  190. all_elems = allInstances(model, "T2P")
  191. log("Got all instances")
  192. while (0 < read_nr_out(all_elems)):
  193. elem_constraint = set_pop(all_elems)
  194. log("Check T2P " + elem_constraint)
  195. if (integer_lt(read_attribute(model, elem_constraint, "weight"), 0)):
  196. return "Negative weight in arc " + elem_constraint
  197. return "OK"