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 (eta-expansion, inlining, etc) 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.


翻译:我们根据MetaCoq的认证消化功能语言实施 Coq 程序。 我们根据MetaCoq的认证消化功能语言。 我们将MetaCoq通过打字信息来消化输出语言, 并将其作为中间代表形式使用, 我们称之为$@lambda ⁇ T ⁇ Z ⁇ Z ⁇ sqqqquare$。 我们用一个完整的管道来补充提取功能功能功能功能, 包括一些标准转换( 扩展、 内衬等), 以及一个经过验证的优化取消未使用的参数。 我们证明, 我们的抽取方法是正确的, 一个常规的逐值操作语言。 从最优化的 $lambda ⁇ T ⁇ qqqqqqqq 平方言中, 我们得到了两种功能智能智能合同语言的代码, Elm, 我们用这些功能语言来全面校验。

0
下载
关闭预览

相关内容

【CVPR 2021】变换器跟踪TransT: Transformer Tracking
专知会员服务
21+阅读 · 2021年4月20日
专知会员服务
75+阅读 · 2021年3月16日
百页Python编程指南
专知会员服务
67+阅读 · 2021年2月16日
专知会员服务
17+阅读 · 2020年9月6日
还在修改博士论文?这份《博士论文写作技巧》为你指南
强化学习最新教程,17页pdf
专知会员服务
168+阅读 · 2019年10月11日
【新书】Python编程基础,669页pdf
专知会员服务
186+阅读 · 2019年10月10日
已删除
将门创投
4+阅读 · 2018年6月26日
gan生成图像at 1024² 的 代码 论文
CreateAMind
4+阅读 · 2017年10月31日
Arxiv
0+阅读 · 2021年10月5日
Arxiv
0+阅读 · 2021年10月4日
Arxiv
0+阅读 · 2021年10月1日
Arxiv
6+阅读 · 2019年3月19日
Rapid Customization for Event Extraction
Arxiv
7+阅读 · 2018年9月20日
VIP会员
相关VIP内容
【CVPR 2021】变换器跟踪TransT: Transformer Tracking
专知会员服务
21+阅读 · 2021年4月20日
专知会员服务
75+阅读 · 2021年3月16日
百页Python编程指南
专知会员服务
67+阅读 · 2021年2月16日
专知会员服务
17+阅读 · 2020年9月6日
还在修改博士论文?这份《博士论文写作技巧》为你指南
强化学习最新教程,17页pdf
专知会员服务
168+阅读 · 2019年10月11日
【新书】Python编程基础,669页pdf
专知会员服务
186+阅读 · 2019年10月10日
相关资讯
已删除
将门创投
4+阅读 · 2018年6月26日
gan生成图像at 1024² 的 代码 论文
CreateAMind
4+阅读 · 2017年10月31日
Top
微信扫码咨询专知VIP会员