Affiliation:
1. MPI-SWS, Germany
2. Universidad Nacional de Córdoba, Argentina / CONICET, Argentina
3. Delft University of Technology, Netherlands
4. IRIF, France / CNRS, France / University of Paris Diderot, France / Inria, France
Abstract
Coq supports a range of built-in tactics, which are engineered primarily to support
backward reasoning
. Starting from a desired goal, the Coq programmer can use these tactics to manipulate the proof state interactively, applying axioms or lemmas to break the goal into subgoals until all subgoals have been solved. Additionally, it provides support for
tactic programming
via OCaml and Ltac, so that users can roll their own custom proof automation routines.
Unfortunately, though, these tactic languages share a significant weakness. They do not offer the tactic programmer any static guarantees about the soundness of their custom tactics, making large tactic developments difficult to maintain. To address this limitation, Ziliani et al. previously proposed
Mtac
, a new typed approach to custom proof automation in Coq which provides the static guarantees that OCaml and Ltac are missing. However, despite its name, Mtac is really more of a metaprogramming language than it is a full-blown tactic language: it misses an essential feature of tactic programming, namely the ability to directly manipulate Coq’s proof state and perform backward reasoning on it.
In this paper, we present
Mtac2
, a next-generation version of Mtac that combines its support for typed metaprogramming with additional support for the programming of backward-reasoning tactics in the style of Ltac. In so doing, Mtac2 introduces a novel feature in tactic programming languages—what we call
typed backward reasoning
. With this feature, Mtac2 is capable of statically ruling out several classes of errors that would otherwise remain undetected at tactic definition time. We demonstrate the utility of Mtac2’s typed tactics by porting several tactics from a large Coq development, the Iris Proof Mode, from Ltac to Mtac2.
Publisher
Association for Computing Machinery (ACM)
Subject
Safety, Risk, Reliability and Quality,Software
Reference32 articles.
1. Raphaël Cauderlier. 2018. Tactics and certificates in Meta Dedukti. In ITP (ITP ‘18). Raphaël Cauderlier. 2018. Tactics and certificates in Meta Dedukti. In ITP (ITP ‘18).
2. Raphaël Cauderlier and François Thiré. {n. d.}. Meta Dedukti. http://deducteam.gforge.inria.fr/metadedukti/ Raphaël Cauderlier and François Thiré. {n. d.}. Meta Dedukti. http://deducteam.gforge.inria.fr/metadedukti/
Cited by
13 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. Modularity, Code Specialization, and Zero-Cost Abstractions for Program Verification;Proceedings of the ACM on Programming Languages;2023-08-30
2. From Intuition to Coq: A Case Study in Verified Response-Time Analysis 1 of FIFO Scheduling;2022 IEEE Real-Time Systems Symposium (RTSS);2022-12
3. Touring the MetaCoq Project (Invited Paper);Electronic Proceedings in Theoretical Computer Science;2021-07-16
4. Verification of dynamic bisimulation theorems in Coq;Journal of Logical and Algebraic Methods in Programming;2021-04
5. Lassie: HOL4 tactics by example;Proceedings of the 10th ACM SIGPLAN International Conference on Certified Programs and Proofs;2021-01-17