Artículo
A comprehensible guide to a new unifier for CIC including universe polymorphism and overloading
Fecha de publicación:
02/2017
Editorial:
Cambridge University Press
Revista:
Journal Of Functional Programming
ISSN:
0956-7968
Idioma:
Inglés
Tipo de recurso:
Artículo publicado
Clasificación temática:
Resumen
Unification is a core component of every proof assistant or programming language featuring dependent types. In many cases, it must deal with higher order problems up to conversion. Since unification in such conditions is undecidable, unification algorithms may include several heuristics to solve common problems. However, when the stack of heuristics grows large, the result and complexity of the algorithm can become unpredictable. Our contributions are twofold: (1) We present a full description of a new unification algorithm for the Calculus of Inductive Constructions (the base logic of COQ), building it up from a basic calculus to the full Calculus of Inductive Constructions as it is implemented in COQ, including universe polymorphism, canonical structures (the overloading mechanism baked into COQ's unification), and a small set of useful heuristics. (2) We implemented our algorithm, and tested it on several libraries, providing evidence that the selected set of heuristics suffices for large developments.
Palabras clave:
Unification
,
Calculus of Inductive Constructions
,
Coq
Archivos asociados
Licencia
Identificadores
Colecciones
Articulos(CCT - CORDOBA)
Articulos de CTRO.CIENTIFICO TECNOL.CONICET - CORDOBA
Articulos de CTRO.CIENTIFICO TECNOL.CONICET - CORDOBA
Citación
Ziliani, Luis Francisco; Sozeau, Matthieu; A comprehensible guide to a new unifier for CIC including universe polymorphism and overloading; Cambridge University Press; Journal Of Functional Programming; 27; 2-2017; 1-58
Compartir
Altmétricas