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.
Ámbito científico
Palabras clave
Programa(s)
Régimen de financiación
MSCA-IF - Marie Skłodowska-Curie Individual Fellowships (IF)Coordinador
78153 Le Chesnay Cedex
Francia