Skip to content

massimotisi/CoqTL

 
 

Repository files navigation

CoqTL: an Internal DSL for Model Transformation in Coq

In model-driven engineering, model transformation (MT) verification is essential for reliably producing software artifacts. While recent advancements have enabled automatic Hoare-style verification for non-trivial MTs, there are certain verification tasks (e.g. induction) that are intrinsically difficult to automate. Existing tools that aim at simplifying the interactive verification of MTs typically translate the MT specification (e.g. in ATL) and properties to prove (e.g. in OCL) into an interactive theorem prover. However, since the MT specification and proof phases happen in separate languages, the proof developer needs a deep knowledge of the translation logic. Naturally any error in the MT translation could cause unsound verification, i.e. the MT executed in the original environment may have different semantics from the verified MT.

We propose an alternative solution by designing and implementing an internal domain specific language, namely CoqTL, for the specification of declarative MTs directly in the Coq interactive theorem prover. Expressions in CoqTL are written in Gallina (the specification language of Coq), increasing the possibilities of reuse of native Coq libraries in the transformation definition and proof. In this repository, it contains the example and proofs of CoqTL.

Repository structure

  • The main example and proofs of CoqTL is contained by fr.inria.atlanmod.coqtl.coq.
  • The code generator from EMF metamodel/model to CoqTL is contained by fr.inria.atlanmod.coqtl.generators.

Requirements

  • CoqTL is developed under Coq v.8.6.
  • The code generator from EMF metamodel/model to CoqTL is developed on top of Eclipse Modelling Project (Neon), and mainly requires EMF v.2.12 and XTEND v.2.10 to build, please refer its manefest.MF for detail.

Contacts

Massimo Tisi: [email protected]

Zheng Cheng: [email protected]

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Coq 77.8%
  • Makefile 11.3%
  • Xtend 8.9%
  • Verilog 1.7%
  • Java 0.3%