Py-T-Core is a Python implementation of T-Core. T-Core is a framework to building your own domain-specific, custom-built model transformation engines. It offers primitive transformation constructs that can be combined to define and encapsulate reusable model transformation idioms. The user can use existing transformation building blocks from an extensible library or define his own transformation units.
- Precondition and postcondition patterns to declaratively specify (graph transformation) rules.
- Matching precondition patterns of a rule on an input model.
- Rewriting the model to satisfy the postcondition of a rule.
- Validation of consistent rule applications to detect conflicts and resolve them.
- Manipulation of matches to iterate through them and rollback to previous match states.
- Control of flow of rule applications with choices and concurrency
- Composition mechanisms for structure, reuse & encapsulation
For more information, read this article.
E. Syriani, H. Vangheluwe, and B. LaShomb. T-Core: A Framework for Custom-built Transformation Languages. Software & Systems Modeling: 14(3), pp. 1215-1243 (2015).
This distribution contains the following files and folders:
tc_python
: implementation of most common transformation units (e.g., ARule, FRule, etc.) and other more advanced units (e.g., XRule) in Pythont_core
: all primitive transformation operatorscore
: matching algorithm and Himesis data structure (abstraction over igraph)util
: utility module for common operationsexamples
: contains a simple transformation example (simply run main.py) and a fully running example of modeling a mutual exclusion problem with four transformations (InitModel, ALAP, LTS,STS)
The source code is licensed under a GNU LESSER GENERAL PUBLIC LICENSE 3
T-Core is intended to be used as a Python library. To use T-Core, you need to install:
- Latest version of Python 2.X (see https://www.python.org/downloads/)
- igraph (see http://igraph.org/python/)
Most users will use Py-T-Core (the tc_python
module).
To implement a Py-T-Core transformation, you need the following modules: core
, util
, t_core
, tc_python
.
T-Core takes as input a input graph to transform, a set of graph transformation rules (pre/postcondition patterns, a.k.a. Left-hand side and Right-hand side).
T-Core operates on a custom data structure called Himesis (see the article for more information). You can programatically construct a Himesis graph through its API and then call the compile()
method to serialize it in a Python class that you can later import. However, it is best to generate the graph from our other tool AToMPM to make sure all the node attributes are well-formed. For example, a Himesis graph must have an attribute HConstansts.META_MODEL
and HConstansts.GUID
. Furthermore, the pre- and postcondition graphs must have attributes names prefixed correctly.
- Custom data-structure (Himesis) over igraph
- Very efficient graph matching algorithm
- Pre-defined transformation units for Python (ARule, FRule, etc.)
- Two fully running examples