123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425 |
- include "primitives.alh"
- include "object_operations.alh"
- include "library.alh"
- include "conformance_scd.alh"
- include "modelling.alh"
- Element function constraint_natural(model : Element, name : String):
- if (is_physical_int(model["model"][name])):
- if (integer_gte(model["model"][name], 0)):
- return "OK"!
- else:
- return "Natural number not larger than or equal to zero"!
- else:
- return "Natural has non-integer instance"!
- Element function constraint_string(model : Element, name : String):
- if (is_physical_string(model["model"][name])):
- return "OK"!
- else:
- return "String has non-string instance"!
- Element function constraint_if(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "if"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_while(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "while"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_break(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "break"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_continue(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "continue"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_assign(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "assign"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_return(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "return"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_output(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "output"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_input(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "input"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_declare(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "declare"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_global(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "global"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_access(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "access"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_constant(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "constant"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_resolve(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "resolve"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function constraint_call(model : Element, name : String):
- if (is_physical_action(model["model"][name])):
- if (cast_a2s(model["model"][name]) == "call"):
- return "OK"!
- else:
- return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
- else:
- return "Expected physical action value"!
- Element function initialize_SCD(location : String):
- Element scd
- scd = instantiate_bottom()
- // Initial model, typed using LTM_bottom
- model_add_node(scd, "Class")
- model_add_node(scd, "Any")
- model_add_node(scd, "String")
- model_add_value(scd, "name", "name")
- model_add_edge(scd, "Association", "Class", "Any")
- model_add_edge(scd, "Inheritance", "Class", "Class")
- model_add_edge(scd, "Association_attribute", "Association", "String")
- model_add_edge(scd, "Association_name", "Association_attribute", "name")
- model_add_edge(scd, "assoc_inh_class", "Association", "Class")
- model_add_edge(scd, "class_inh_any", "Class", "Any")
- model_add_edge(scd, "string_inh_any", "String", "Any")
- // Retype to a "real" LTM, which happens to be itself
- retype_model(scd, scd)
- define_inheritance(scd, "Inheritance")
- retype(scd, "Class", "Class")
- retype(scd, "Any", "Class")
- retype(scd, "String", "Class")
- retype(scd, "name", "String")
- retype(scd, "Association", "Association")
- retype(scd, "Inheritance", "Association")
- retype(scd, "Association_attribute", "Association")
- retype(scd, "Association_name", "Association_attribute")
- retype(scd, "assoc_inh_class", "Inheritance")
- retype(scd, "class_inh_any", "Inheritance")
- retype(scd, "string_inh_any", "Inheritance")
- // Add some attributes, now that it is an ordinary model
- instantiate_node(scd, "Class", "Natural")
- instantiate_link(scd, "Association", "lc", "Class", "Natural")
- instantiate_attribute(scd, "lc", "name", "lower_cardinality")
- instantiate_link(scd, "Association", "uc", "Class", "Natural")
- instantiate_attribute(scd, "uc", "name", "upper_cardinality")
- instantiate_link(scd, "Association", "slc", "Association", "Natural")
- instantiate_attribute(scd, "slc", "name", "source_lower_cardinality")
- instantiate_link(scd, "Association", "suc", "Association", "Natural")
- instantiate_attribute(scd, "suc", "name", "source_upper_cardinality")
- instantiate_link(scd, "Association", "tlc", "Association", "Natural")
- instantiate_attribute(scd, "tlc", "name", "target_lower_cardinality")
- instantiate_link(scd, "Association", "tuc", "Association", "Natural")
- instantiate_attribute(scd, "tuc", "name", "target_upper_cardinality")
- // Add in the Action Language metamodel
- instantiate_node(scd, "Class", "Action")
- instantiate_node(scd, "Class", "Statement")
- instantiate_node(scd, "Class", "Expression")
- instantiate_node(scd, "Class", "funcdef")
- instantiate_node(scd, "Class", "param")
- instantiate_node(scd, "Class", "if")
- instantiate_node(scd, "Class", "break")
- instantiate_node(scd, "Class", "while")
- instantiate_node(scd, "Class", "continue")
- instantiate_node(scd, "Class", "assign")
- instantiate_node(scd, "Class", "return")
- instantiate_node(scd, "Class", "output")
- instantiate_node(scd, "Class", "declare")
- instantiate_node(scd, "Class", "global")
- instantiate_node(scd, "Class", "access")
- instantiate_node(scd, "Class", "constant")
- instantiate_node(scd, "Class", "input")
- instantiate_node(scd, "Class", "resolve")
- instantiate_node(scd, "Class", "call")
- instantiate_link(scd, "Association", "dict_link", "Action", "Any")
- instantiate_link(scd, "Association", "to_str", "dict_link", "String")
- instantiate_attribute(scd, "to_str", "name", "name")
- instantiate_link(scd, "Inheritance", "", "Action", "Any")
- instantiate_link(scd, "Inheritance", "", "funcdef", "Action")
- instantiate_link(scd, "Inheritance", "", "param", "Action")
- instantiate_link(scd, "Inheritance", "", "Statement", "Action")
- instantiate_link(scd, "Inheritance", "", "Expression", "Action")
- instantiate_link(scd, "Inheritance", "", "resolve", "Statement")
- instantiate_link(scd, "Inheritance", "", "if", "Statement")
- instantiate_link(scd, "Inheritance", "", "break", "Statement")
- instantiate_link(scd, "Inheritance", "", "continue", "Statement")
- instantiate_link(scd, "Inheritance", "", "global", "Statement")
- instantiate_link(scd, "Inheritance", "", "while", "Statement")
- instantiate_link(scd, "Inheritance", "", "assign", "Statement")
- instantiate_link(scd, "Inheritance", "", "return", "Statement")
- instantiate_link(scd, "Inheritance", "", "call", "Statement")
- instantiate_link(scd, "Inheritance", "", "declare", "Statement")
- instantiate_link(scd, "Inheritance", "", "call", "Expression")
- instantiate_link(scd, "Inheritance", "", "access", "Expression")
- instantiate_link(scd, "Inheritance", "", "constant", "Expression")
- instantiate_link(scd, "Inheritance", "", "input", "Expression")
- instantiate_link(scd, "Association", "statement_next", "Statement", "Statement")
- instantiate_link(scd, "Association", "if_cond", "if", "Expression")
- instantiate_link(scd, "Association", "if_then", "if", "Statement")
- instantiate_link(scd, "Association", "if_else", "if", "Statement")
- instantiate_link(scd, "Association", "while_cond", "while", "Expression")
- instantiate_link(scd, "Association", "while_body", "while", "Statement")
- instantiate_link(scd, "Association", "assign_var", "assign", "Any")
- instantiate_link(scd, "Association", "assign_value", "assign", "Expression")
- instantiate_link(scd, "Association", "break_while", "break", "while")
- instantiate_link(scd, "Association", "continue_while", "continue", "while")
- instantiate_link(scd, "Association", "return_value", "return", "Expression")
- instantiate_link(scd, "Association", "resolve_var", "resolve", "Any")
- instantiate_link(scd, "Association", "access_var", "access", "Any")
- instantiate_link(scd, "Association", "constant_node", "constant", "Any")
- instantiate_link(scd, "Association", "output_node", "output", "Expression")
- instantiate_link(scd, "Association", "global_var", "global", "String")
- instantiate_link(scd, "Association", "param_name", "param", "String")
- instantiate_link(scd, "Association", "param_value", "param", "Expression")
- instantiate_link(scd, "Association", "param_next_param", "param", "param")
- instantiate_link(scd, "Association", "funcdef_body", "funcdef", "Statement")
- instantiate_link(scd, "Association", "call_func", "call", "Expression")
- instantiate_link(scd, "Association", "call_params", "call", "param")
- instantiate_link(scd, "Association", "call_last_param", "call", "param")
- instantiate_link(scd, "Inheritance", "", "statement_next", "dict_link")
- instantiate_link(scd, "Inheritance", "", "if_cond", "dict_link")
- instantiate_link(scd, "Inheritance", "", "if_then", "dict_link")
- instantiate_link(scd, "Inheritance", "", "if_else", "dict_link")
- instantiate_link(scd, "Inheritance", "", "while_cond", "dict_link")
- instantiate_link(scd, "Inheritance", "", "while_body", "dict_link")
- instantiate_link(scd, "Inheritance", "", "assign_var", "dict_link")
- instantiate_link(scd, "Inheritance", "", "assign_value", "dict_link")
- instantiate_link(scd, "Inheritance", "", "break_while", "dict_link")
- instantiate_link(scd, "Inheritance", "", "continue_while", "dict_link")
- instantiate_link(scd, "Inheritance", "", "return_value", "dict_link")
- instantiate_link(scd, "Inheritance", "", "resolve_var", "dict_link")
- instantiate_link(scd, "Inheritance", "", "access_var", "dict_link")
- instantiate_link(scd, "Inheritance", "", "constant_node", "dict_link")
- instantiate_link(scd, "Inheritance", "", "output_node", "dict_link")
- instantiate_link(scd, "Inheritance", "", "global_var", "dict_link")
- instantiate_link(scd, "Inheritance", "", "param_name", "dict_link")
- instantiate_link(scd, "Inheritance", "", "param_value", "dict_link")
- instantiate_link(scd, "Inheritance", "", "param_next_param", "dict_link")
- instantiate_link(scd, "Inheritance", "", "funcdef_body", "dict_link")
- instantiate_link(scd, "Inheritance", "", "call_func", "dict_link")
- instantiate_link(scd, "Inheritance", "", "call_params", "dict_link")
- instantiate_link(scd, "Inheritance", "", "call_last_param", "dict_link")
- // Add cardinalities on how many connections are allowed: one of each
- instantiate_attribute(scd, "statement_next", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "if_cond", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "if_cond", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "if_then", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "if_then", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "if_else", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "while_cond", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "while_cond", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "while_body", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "while_body", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "assign_var", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "assign_var", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "assign_value", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "assign_value", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "break_while", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "break_while", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "continue_while", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "continue_while", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "return_value", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "resolve_var", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "resolve_var", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "access_var", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "access_var", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "constant_node", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "constant_node", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "output_node", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "output_node", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "global_var", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "global_var", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "param_name", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "param_name", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "param_value", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "param_value", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "param_next_param", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "funcdef_body", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "funcdef_body", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "call_func", "target_lower_cardinality", 1)
- instantiate_attribute(scd, "call_func", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "call_params", "target_upper_cardinality", 1)
- instantiate_attribute(scd, "call_last_param", "target_upper_cardinality", 1)
- // Now still allow for constraints on classes
- instantiate_link(scd, "Association", "constraint", "Class", "funcdef")
- instantiate_attribute(scd, "constraint", "name", "constraint")
- // Add constraints to all primitive classes
- //add_constraint(scd, "if", constraint_if)
- //add_constraint(scd, "while", constraint_while)
- //add_constraint(scd, "break", constraint_break)
- //add_constraint(scd, "continue", constraint_continue)
- //add_constraint(scd, "assign", constraint_assign)
- //add_constraint(scd, "return", constraint_return)
- //add_constraint(scd, "output", constraint_output)
- //add_constraint(scd, "input", constraint_input)
- //add_constraint(scd, "declare", constraint_declare)
- //add_constraint(scd, "global", constraint_global)
- //add_constraint(scd, "access", constraint_access)
- //add_constraint(scd, "constant", constraint_constant)
- //add_constraint(scd, "resolve", constraint_resolve)
- //add_constraint(scd, "call", constraint_call)
- // And add some, to enforce correct physical types
- add_constraint(scd, "Natural", constraint_natural)
- add_constraint(scd, "String", constraint_string)
- // Finally done, so export!
- export_node(location, scd)
- return scd!
- Element function initialize_PN(location_SCD : String, location_PN : String):
- Element pn
- Element scd
- scd = import_node(location_SCD)
- pn = instantiate_model(scd)
- define_inheritance(pn, "Inheritance")
- instantiate_node(pn, "Class", "Place")
- instantiate_node(pn, "Class", "Transition")
- instantiate_node(pn, "Class", "Natural")
- instantiate_link(pn, "Association", "P2T", "Place", "Transition")
- instantiate_link(pn, "Association", "T2P", "Transition", "Place")
- instantiate_link(pn, "Association", "Place_tokens", "Place", "Natural")
- instantiate_attribute(pn, "Place_tokens", "name", "tokens")
- instantiate_attribute(pn, "Place_tokens", "target_lower_cardinality", 1)
- instantiate_attribute(pn, "Place_tokens", "target_upper_cardinality", 1)
- instantiate_link(pn, "Association", "P2T_weight", "P2T", "Natural")
- instantiate_attribute(pn, "P2T_weight", "name", "weight")
- instantiate_attribute(pn, "P2T_weight", "target_lower_cardinality", 1)
- instantiate_attribute(pn, "P2T_weight", "target_upper_cardinality", 1)
- instantiate_link(pn, "Association", "T2P_weight", "T2P", "Natural")
- instantiate_attribute(pn, "T2P_weight", "name", "weight")
- instantiate_attribute(pn, "T2P_weight", "target_lower_cardinality", 1)
- instantiate_attribute(pn, "T2P_weight", "target_upper_cardinality", 1)
- // Add constraint on the Natural
- add_constraint(pn, "Natural", constraint_natural)
- // Add global constraints
- //set_model_constraints(pn, petrinet_constraints)
- export_node(location_PN, pn)
- return pn!
- Element function initialize_bottom(location_bottom : String):
- Element ltm_bottom
- ltm_bottom = instantiate_bottom()
- model_add_node(ltm_bottom, "Node")
- model_add_edge(ltm_bottom, "Edge", "Node", "Node")
- model_add_edge(ltm_bottom, "inheritance", "Node", "Node")
- model_add_edge(ltm_bottom, "__inh", "Edge", "Node")
- retype_model(ltm_bottom, ltm_bottom)
- define_inheritance(ltm_bottom, "inheritance")
- retype(ltm_bottom, "Node", "Node")
- retype(ltm_bottom, "Edge", "Edge")
- retype(ltm_bottom, "inheritance", "Edge")
- retype(ltm_bottom, "__inh", "inheritance")
- export_node(location_bottom, ltm_bottom)
- return ltm_bottom!
- Element function create_metamodels():
- String location_SCD
- String location_PN
- String location_bottom
- location_SCD = "models/SimpleClassDiagrams"
- location_PN = "models/PetriNets"
- location_bottom = "models/LTM_bottom"
- if (bool_not(dict_in(dict_read(dict_read(read_root(), "__hierarchy"), "models"), "SimpleClassDiagrams"))):
- initialize_SCD(location_SCD)
- if (bool_not(dict_in(dict_read(dict_read(read_root(), "__hierarchy"), "models"), "PetriNets"))):
- initialize_PN(location_SCD, location_PN)
- if (bool_not(dict_in(dict_read(dict_read(read_root(), "__hierarchy"), "models"), "LTM_bottom"))):
- initialize_bottom(location_bottom)
- return dict_read(dict_read(read_root(), "__hierarchy"), "models")!
|