Coq a la Carte: A practical approach to modular syntax with binders

5Citations
Citations of this article
8Readers
Mendeley users who have this article in their library.
Get full text

Abstract

The mechanisation of the meta-theory of programming languages is still considered hard and requires considerable effort. When formalising properties of the extension of a language, one hence wants to reuse definitions and proofs. But type-theoretic proof assistants use inductive types and predicates to formalise syntax and type systems, and these definitions are closed to extensions. Available approaches for modular syntax are either inapplicable to type theory or add a layer of indirectness by requiring complicated encodings of types. We present a concise, transparent, and accessible approach to modular syntax with binders by adapting Swierstra's Data Types a la Carte approach to the Coq proof assistant. Our approach relies on two phases of code generation:We extend the Autosubst 2 tool and allow users to specify modular syntax with binders in a HOAS-like input language. To state and automatically compose modular functions and lemmas, we implement commands based on MetaCoq. We support modular syntax, functions, predicates, and theorems. We demonstrate the practicality of our approach by modular proofs of preservation, weak head normalisation, and strong normalisation for several variants of mini-ML.

Author supplied keywords

Cite

CITATION STYLE

APA

Forster, Y., & Stark, K. (2020). Coq a la Carte: A practical approach to modular syntax with binders. In CPP 2020 - Proceedings of the 9th ACM SIGPLAN International Conference on Certified Programs and Proofs, co-located with POPL 2020 (pp. 186–200). Association for Computing Machinery, Inc. https://doi.org/10.1145/3372885.3373817

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free