Affiliation:
1. KU Leuven, Leuven, Belgium
Abstract
Dependent pattern matching is an intuitive way to write programs and proofs in dependently typed languages. It is reminiscent of both pattern matching in functional languages and case analysis in on-paper mathematics. However, in general it is incompatible with new type theories such as homotopy type theory (HoTT). As a consequence, proofs in such theories are typically harder to write and to understand. The source of this incompatibility is the reliance of dependent pattern matching on the so-called K axiom - also known as the uniqueness of identity proofs - which is inadmissible in HoTT. The Agda language supports an experimental criterion to detect definitions by pattern matching that make use of the K axiom, but so far it lacked a formal correctness proof.
In this paper, we propose a new criterion for dependent pattern matching without K, and prove it correct by a translation to eliminators in the style of Goguen et al. (2006). Our criterion both allows more good definitions than existing proposals, and solves a previously undetected problem in the criterion offered by Agda. It has been implemented in Agda and is the first to be supported by a formal proof. Thus it brings the benefits of dependent pattern matching to contexts where we cannot assume K, such as HoTT. It also points the way to new forms of dependent pattern matching, for example on higher inductive types.
Funder
Fonds Wetenschappelijk Onderzoek
Publisher
Association for Computing Machinery (ACM)
Subject
Computer Graphics and Computer-Aided Design,Software
Cited by
8 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. A simpler encoding of indexed types;Proceedings of the 6th ACM SIGPLAN International Workshop on Type-Driven Development;2021-08-18
2. Formalizing category theory in Agda;Proceedings of the 10th ACM SIGPLAN International Conference on Certified Programs and Proofs;2021-01-17
3. Definitional proof-irrelevance without K;Proceedings of the ACM on Programming Languages;2019-01-02
4. Code Generation for Higher Inductive Types;Functional and Constraint Logic Programming;2019
5. Finite sets in homotopy type theory;Proceedings of the 7th ACM SIGPLAN International Conference on Certified Programs and Proofs;2018-01-08