package catala
Install
Dune Dependency
Authors
Maintainers
Sources
md5=4a2c5495f30d8fc2e3bf977df6e602f9
sha512=8dcc404b6068b9dbd76982ade60d8fba1950fdd0a8a626db17429120483367dce1f51997e96d7b8ee5308f305c3bcbb897ef85336f25e9ef3681f4cb9237f56a
doc/desugared.html
Desugared representation
This representation is the second in the compilation chain (see Architecture). Its main difference with the surface representation is that the legislative text has been discarded and all the definitions of each variables have been collected in the same place rather than being scattered across the code base.
The module describing the abstract syntax tree is:
Desugared.Ast
Abstract syntax tree of the desugared representation
Translation to the scope language
Related modules:
Desugared.Dependency
Scope dependencies computations using OCamlgraphDesugared.Desugared_to_scope
Translation fromDesugared.Ast
toScopelang.Ast
Before the translation to the scope language, Desugared.Dependency
checks that within a scope, there is no computational circular dependency between the variables of the scope. When the dependency graph is a DAG, Desugared.Desugared_to_scope
performs a topological ordering to produce an ordered list of the scope definitions compatible with the computation order. All the graph computations are done using the Ocamlgraph library.
The other important piece of work performed by Desugared.Desugared_to_scope
is the construction of the default trees (see Dcalc.Ast.EDefault
) from the list of prioritized rules.