Skip to main content
European Commission logo
español español
CORDIS - Resultados de investigaciones de la UE
CORDIS
CORDIS Web 30th anniversary CORDIS Web 30th anniversary

Verified Extraction from Coq to OCaml with GADTs

Descripción del proyecto

Comprobación de la extracción de código de Coq a lenguajes de propósito general

Coq es un asistente de pruebas formal. Una de sus aplicaciones típicas es la comprobación de la precisión de «software» crítico. Aunque recientemente se ha comprobado un verificador de tipos para Coq a través de una prueba matemática comprobada por máquina, extraer OCaml de Coz sigue siendo parte de su base informática acreditada. Financiado por las Acciones Marie Skłodowska-Curie, el proyecto Coqaml seguirá minimizando la base informática acreditada para programas extraídos proporcionando una prueba de corrección verificada por máquina. Los investigadores pondrán en práctica la extracción de Coq como un complemento MetaCoq verificado mecánicamente, garantizando así que los programas OCaml extraídos se comporten exactamente como indica la función Coq.

Objetivo

The Coq proof assistant is a popular tool to verify the correctness of security-critical software. The CompCert C compiler, some implementations of blockchain languages, and the implementation of the P-256 elliptic curve in Google’s BoringSSL library are all OCaml programs obtained by extraction from Coq functions.

While a type checker for Coq has recently been verified via a machine-checked mathematical proof based on the MetaCoq project for verified meta-programming, the extraction process from Coq to OCaml is still part of the trusted computing base (TCB).

The Coqaml project will minimise the TCB for extracted programs even further by also providing a machine-checked correctness proof for the extraction mechanism to OCaml. Under the supervision of Nicolas Tabareau, head of the Inria Gallinette team in Nantes, the experienced researcher (ER) will implement Coq's extraction as mechanically verified MetaCoq-plugin, obtaining the guarantee that extracted OCaml programs behave exactly like the Coq function specified.

In order to be usable in industrial applications, Coqaml will include a novel extraction targeting generalized algebraic datatypes (GADTs) in OCaml. The project includes a secondment of the ER to Nomadic Labs in Paris, who require GADTs as target for Coq's extraction. The intermediate semantic correctness proof for type and proof erasure, allowing axioms like functional extensionality or proof irrelevance in verified programs, can also be exploited in other extraction projects like the CertiCoq compiler from Coq to C code.

The Coqaml project is interdisciplanary by design, spanning logic, type theory, programming languages, and compilers. The density of some of the world’s leading experts on Coq and type theory in the Gallinette team and the expertise at Nomadic Labs will ensure that the environment is ideal for the success of the Coqaml project and the most beneficial development of the ER, greatly enhancing his future career prospects.

Coordinador

INSTITUT NATIONAL DE RECHERCHE EN INFORMATIQUE ET AUTOMATIQUE
Aportación neta de la UEn
€ 184 707,84
Dirección
DOMAINE DE VOLUCEAU ROCQUENCOURT
78153 Le Chesnay Cedex
Francia

Ver en el mapa

Región
Ile-de-France Ile-de-France Yvelines
Tipo de actividad
Research Organisations
Enlaces
Coste total
€ 184 707,84