210 likes | 295 Views
Instant Bidirectional QVT Transformation for Runtime Models. Runtime models. Models that represent the structure, configuration , etc., of an executing system Monitoring the system by reading the model Reconfiguring the system by writing the model
E N D
Runtime models • Models that represent the structure, configuration, etc., of an executing system • Monitoring the system by reading the model • Reconfiguring the system by writing the model • With full semantics basis and supporting tools • A hot topic in the models community • “A new trend” by Robert France’s survey on MDE • A in last MoDELS, a topic in this one
Supporting runtime models Goods, storage… System meta-model Runtime application model conforms to Different views according to different application concerns system Runtime application model Runtime system model RFID readers, tags, sensors… Persons, things, rooms…
Supporting runtime models Applicationmeta-model System meta-model relation conforms to conforms to Guided by system Runtime application model Runtime system model Causal connection
Approach overview Applicationmeta-model in MOF System meta-model in MOF Relation in QVT-R conforms to conforms to Guided by system Runtime application model Runtime system model Instant QVT transformation engine
Challenge • Instant: • Traditional transformation is from model to model • Inefficient when the models are big • System changes are small but frequent • Require a new execution from change to change • With live models maintained as a reference • Bidirectional: • Not bijective, one change may corresponds to many • Need a proper and determined semantics
Batching transformation th : Thing ps : Person rm : Room rd : Reader sn : Sensor sr : SysRoot ar : AppRoot tg1 : Tag tg2 : Tag name=phone id = 104 id = 1621 temp=16.0 Bright=620.0 number = 1621 temp = 16.0 name : pkusi id = 1621 name = Hui id = 102 id = 104 id = 102 name = pkusi root root room person thing sensor reader reader owner person own locate tag Why in-efficient: the impact of the change is not the whole model, but since the change is not considered, the impact scope is not utilized add:[rd, reader, tg2]
Instant transformation th : Thing ps : Person rm : Room rd : Reader sn : Sensor sr : SysRoot ar : AppRoot tg1 : Tag tg2 : Tag name=phone id = 104 id = 1621 temp=16.0 Bright=620.0 number = 1621 temp = 16.0 name : pkusi id = 1621 name = Hui id = 102 id = 104 id = 102 name = pkusi root root room person thing sensor reader reader owner person own locate tag set:[th, locate, rm] add:[rd, reader, tg2]
About bidirectional th : Thing ps : Person rm : Room rd : Reader sn : Sensor sr : SysRoot ar : AppRoot tg2 : Tag tg1 : Tag name=phone id = 104 id = 1621 temp=16.0 Bright=620.0 id = 1621 name : pkusi number = 1621 temp = 16.0 id = 104 id = 102 name = Hui id = 102 name = pkusi root root room person thing sensor reader reader owner person own locate tag set:[th, locate, null] remove:[rd, reader, tg2] destroy:[th]
Contributions of this paper • Formal semantics of instant QVT transformation for runtime models • Algorithms to implement instant QVT transformation • An instant transformation engine based on mediniQVT
Formal semantics • Abstraction: • Properties • Consistency: • Stability: • Restorability:
The algorithm • Basic idea • Record the mapped model elements(traces) • Analyze the impact of the change • Influence no relations: stop • Influence a relation: • Found the relevant traces, re-evaluate • Cause new groups of elements to be mapped • Create new traces, record changes • Cause an existing trace to fail • Delete the trace, roll-back the recorded changes
Evaluation • Feasibility and effectiveness • Performance • Limitation
feasibility and effectiveness • Main case study: Our SmartLab IOT system • System meta-model: rfid readers, tags, sensors, switches, locks • Application meta-model: rooms, persons, things • Scenarios: • Missing personal effects • Leaving the air-conditioner on • … • Conforms to the expectations of scenario developers • Other case studies: JOnAS-C2, JOnAS-Client/Server
performance • Made-up models conforming to IOT case • Control the scale • Eliminate other factors such as device invocations
Limitation • For modeling • Every model element must has a key attribute • Only support unordered multiple properties • For QVT • No “where” clause (but can use when)
Related work • Runtime models • Usually based on code wrapping • One on TGG, but no discussion about runtime-model specific semantics • Model transformation with semantics • On batching transformations • Incremental transformation (supported by QVT) • Still model to model, not change to change • Instant transformation • No transformation language, or TGG
Conclusion • Runtime models and causal connections • A transformation-based approach to support causal connections • Instant, bidirectional • Semantics • Algorithms • Implementation and evaluation