Skip to content

Latest commit

 

History

History
62 lines (40 loc) · 3.3 KB

README.md

File metadata and controls

62 lines (40 loc) · 3.3 KB

Dvořák

DDI to VTL exploratory work.

This allows VTL rules to be generated to check data conformity with its documentation expressed in DDI.

The generation process takes as input a DDI PhysicalInstance expressed in 3.3 DDI XML file using DDI Fragment Instance and generates a text file containing VTL rules. The process is split into two steps:

  1. dereference building an XML file containing a dereferenced Physical Instance
  2. ddi2vtl generating text file containing VTL rules

The generation process can be represented as follow:

For more details on transformation, see the specification.

Install

  • clone the repository
  • create a /lib folder and a /target folder, where / is the Git repository root
  • download Saxon HE 11.4 from GitHub and extract all files in /lib

Usage

Get started

From the command line (or by double-clicking on the script)

cd src/main/scripts
"./dereference.bat"

The result will be in /target/dereferenced.xml.

Similarly, the ddi2vtl can be executed after dereference and will produce /target/vtl.txt.

See all available command line options in the Saxon documentation.

Customized usage

DDI input is a 3.3 DDI XML file. A DDI PhysicalInstance must be the top-level reference of a Fragment Instance serialized atomically. Two different models are supported:

  1. one containing InstanceVariable referencing RepresentedVariable with the DDI representation.
  2. one containing InstanceVariable serializing DDI representation inline

To test your own DDI file, perform the following steps:

  1. Add your DDI file in src/test/ddi (e.g. my-ddi-file.xml)
  2. Change the name of the source DDI file in the script dereference (e.g. change physicalInstance-test.xml to my-ddi-file.xml). If desired, you also can change the name of the generated file in the script ddi2vtl
  3. Run both scripts dereference then ddi2vtl as mentionned in section "Get started"

Execution of generated VTL rules

The execution of generated VTL rules is out of the scope of this repository. As an example of a VTL engine, see the Trevas Java engine available in Open Source.

References

This work has been the subject of two presentations at international conferences: