ConCert: A Smart Contract Certification Framework in Coq

24 Jul 2019  ·  Danil Annenkov, Jakob Botsch Nielsen, Bas Spitters ·

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.

PDF Abstract

Categories


Programming Languages Logic in Computer Science

Datasets


  Add Datasets introduced or used in this paper