Hostname: page-component-77c78cf97d-5vn5w Total loading time: 0 Render date: 2026-04-26T19:56:35.325Z Has data issue: false hasContentIssue false

Extracting functional programs from Coq, in Coq

Published online by Cambridge University Press:  22 August 2022

DANIL ANNENKOV
Affiliation:
Computer Science, Aarhus University, Aarhus, Denmark (e-mail: danil.v.annenkov@gmail.com)
MIKKEL MILO
Affiliation:
Computer Science, Aarhus University, Aarhus, Denmark (e-mail: mikkelmilo@gmail.com)
JAKOB BOTSCH NIELSEN
Affiliation:
Computer Science, Aarhus University, Aarhus, Denmark (e-mail: jakob.botsch.nielsen@gmail.com)
BAS SPITTERS
Affiliation:
Computer Science, Aarhus University, Aarhus, Denmark (e-mail: bas@cs.au.dk)
Rights & Permissions [Opens in a new window]

Abstract

We implement extraction of Coq programs to functional languages based on MetaCoq’s certified erasure. We extend the MetaCoq erasure output language with typing information and use it as an intermediate representation, which we call ${\lambda^T_\square}$. We complement the extraction functionality with a full pipeline that includes several standard transformations (e.g. eta-expansion and inlining) implemented in a proof-generating manner along with a verified optimisation pass removing unused arguments. We prove the pass correct wrt. a conventional call-by-value operational semantics of functional languages. From the optimised ${\lambda^T_\square}$ representation, we obtain code in two functional smart contract languages, Liquidity and CameLIGO, the functional language Elm, and a subset of the multi-paradigm language for systems programming Rust. Rust is currently gaining popularity as a language for smart contracts, and we demonstrate how our extraction can be used to extract smart contract code for the Concordium network. The development is done in the context of the ConCert framework that enables smart contract verification. We contribute with two verified real-world smart contracts (boardroom voting and escrow), which we use, among other examples, to exemplify the applicability of the pipeline. In addition, we develop a verified web application and extract it to fully functional Elm code. In total, this gives us a way to write dependently typed programs in Coq, verify, and then extract them to several target languages while retaining a small trusted computing base of only MetaCoq and the pretty-printers into these languages.

Information

Type
Research Article
Creative Commons
Creative Common License - CCCreative Common License - BY
This is an Open Access article, distributed under the terms of the Creative Commons Attribution licence (https://creativecommons.org/licenses/by/4.0/), which permits unrestricted re-use, distribution, and reproduction in any medium, provided the original work is properly cited.
Copyright
© The Author(s), 2022. Published by Cambridge University Press
Figure 0

Fig. 1. The pipeline.

Figure 1

Fig. 2. Erasure from CIC types to ${\mathtt{box\_type}}$.

Figure 2

Fig. 3. Erasure for type schemes.

Figure 3

Fig. 4. The counter contract.

Figure 4

Fig. 5. Extracted code.

Figure 5

Fig. 6. Extracted test code in Elm.

Figure 6

Fig. 7. The add function extracted to Rust.

Supplementary material: File

ANNENKOV et al. supplementary material

ANNENKOV et al. supplementary material

Download ANNENKOV et al. supplementary material(File)
File 989.2 KB
Submit a response

Discussions

No Discussions have been published for this article.