ConCert: A Smart Contract Certification Framework in Coq

Danil Annenkov,Jakob Botsch Nielsen,Bas Spitters
DOI: https://doi.org/10.1145/3372885.3373829
2019-12-21
Abstract:We present a new way of embedding functional languages into the Coq proof assistant by using meta-programming. This allows us to develop the meta-theory of the language using the deep embedding and provides a convenient way for reasoning about concrete programs using the shallow embedding. We connect the deep and the shallow embeddings by a soundness theorem. As an instance of our approach, we develop an embedding of a core smart contract language into Coq and verify several important properties of a crowdfunding contract based on a previous formalisation of smart contract execution in blockchains.
Programming Languages,Logic in Computer Science
What problem does this paper attempt to address?