ConCert: A Smart Contract Certification Framework in Coq

07/24/2019
by   Danil Annenkov, et al.
0

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 formalization of smart contract execution in blockchains.

READ FULL TEXT

Please sign up or login with your details

Forgot password? Click here to reset