This article includes a list of general references, but it lacks sufficient corresponding inline citations. (November 2018)
In computer science and mathematical logic, a proof assistant or interactive theorem prover is a software tool to assist with the development of formal proofs by human-machine collaboration. This involves some sort of interactive proof editor, or other interface, with which a human can guide the search for proofs, the details of which are stored in, and some steps provided by, a computer.
|Name||Latest version||Developer(s)||Implementation language||Features|
|Higher-order logic||Dependent types||Small kernel||Proof automation||Proof by reflection||Code generation|
|ACL2||8.3||Matt Kaufmann and J Strother Moore||Common Lisp||No||Untyped||No||Yes||Yes||Already executable|
|Agda||2.6.3||Ulf Norell, Nils Anders Danielsson, and Andreas Abel (Chalmers and Gothenburg)||Haskell||Yes||Yes||Yes||No||Partial||Already executable|
|Albatross||0.4||Helmut Brandl||OCaml||Yes||No||Yes||Yes||Unknown||Not yet Implemented|
|F*||repository||Microsoft Research and INRIA||F*||Yes||Yes||No||Yes||Yes||Yes|
|HOL Light||repository||John Harrison||OCaml||Yes||No||Yes||Yes||No||No|
|HOL4||Kananaskis-13 (or repo)||Michael Norrish, Konrad Slind, and others||Standard ML||Yes||No||Yes||Yes||No||Yes|
|Idris||2 0.6.0.||Edwin Brady||Idris||Yes||Yes||Yes||Unknown||Partial||Yes|
|Isabelle||Isabelle2021 (February 2021)||Larry Paulson (Cambridge), Tobias Nipkow (München) and Makarius Wenzel||Standard ML, Scala||Yes||No||Yes||Yes||Yes||Yes|
|Lean||v3.4.2 (official release) v3.39.1 (community release) v4.0.0-m3 (pre-release)||Leonardo de Moura (Microsoft Research)||C++||Yes||Yes||Yes||Yes||Yes||Yes|
|LEGO (not affiliated with Lego)||1.3.1||Randy Pollack (Edinburgh)||Standard ML||Yes||Yes||Yes||No||No||No|
|Mizar||8.1.05||Białystok University||Free Pascal||Partial||Yes||No||No||No||No|
|NuPRL||5||Cornell University||Common Lisp||Yes||Yes||Yes||Yes||Unknown||Yes|
|PVS||6.0||SRI International||Common Lisp||Yes||Yes||No||Yes||No||Unknown|
|Twelf||1.7.1||Frank Pfenning and Carsten Schürmann||Standard ML||Yes||Yes||Unknown||No||No||Unknown|
- ACL2 – a programming language, a first-order logical theory, and a theorem prover (with both interactive and automatic modes) in the Boyer–Moore tradition.
- Coq – Allows the expression of mathematical assertions, mechanically checks proofs of these assertions, helps to find formal proofs, and extracts a certified program from the constructive proof of its formal specification.
- HOL theorem provers – A family of tools ultimately derived from the LCF theorem prover. In these systems the logical core is a library of their programming language. Theorems represent new elements of the language and can only be introduced via "strategies" which guarantee logical correctness. Strategy composition gives users the ability to produce significant proofs with relatively few interactions with the system. Members of the family include:
- HOL4 – The "primary descendant", still under active development. Support for both Moscow ML and Poly/ML. Has a BSD-style license.
- HOL Light – A thriving "minimalist fork". OCaml based.
- ProofPower – Went proprietary, then returned to open source. Based on Standard ML.
- IMPS, An Interactive Mathematical Proof System
- Isabelle is an interactive theorem prover, successor of HOL. The main code-base is BSD-licensed, but the Isabelle distribution bundles many add-on tools with different licenses.
- Jape – Java based.
- Matita – A light system based on the Calculus of Inductive Constructions.
- MINLOG – A proof assistant based on first-order minimal logic.
- Mizar – A proof assistant based on first-order logic, in a natural deduction style, and Tarski–Grothendieck set theory.
- PhoX – A proof assistant based on higher-order logic which is eXtensible.
- Prototype Verification System (PVS) – a proof language and system based on higher-order logic.
- TPS and ETPS – Interactive theorem provers also based on simply-typed lambda calculus, but based on an independent formulation of the logical theory and independent implementation.
A popular front-end for proof assistants is the Emacs-based Proof General, developed at the University of Edinburgh.
Coq includes CoqIDE, which is based on OCaml/Gtk. Isabelle includes Isabelle/jEdit, which is based on jEdit and the Isabelle/Scala infrastructure for document-oriented proof processing. More recently, a Visual Studio Code extension for Isabelle has also been developed by Makarius Wenzel.
- Automated theorem proving – Subfield of automated reasoning and mathematical logic
- Computer-assisted proof – Mathematical proof at least partially generated by computer
- Formal verification – Proving or disproving the correctness of certain intended algorithms
- Metamath – Formal language and associated computer program
- QED manifesto – Proposal for a computer-based database of all mathematical knowledge
- Satisfiability modulo theories – Logical problem studied in computer science
- ^ Hunt, Warren; Matt Kaufmann; Robert Bellarmine Krug; J Moore; Eric W. Smith (2005). "Meta Reasoning in ACL2" (PDF). Theorem Proving in Higher Order Logics. Lecture Notes in Computer Science. Vol. 3603. pp. 163–178. doi:10.1007/11541868_11. ISBN 978-3-540-28372-0.
- ^ Search for "proofs by reflection": arXiv:1803.06547
- ^ "Lean Theorem Prover Releases page". GitHub.
- ^ "Lean Community Releases Page". GitHub.
- ^ "Lean 4 Releases Page". GitHub.
- ^ Farmer, William M.; Guttman, Joshua D.; Thayer, F. Javier (1993). "IMPS: An interactive mathematical proof system". Journal of Automated Reasoning. 11 (2): 213–248. doi:10.1007/BF00881906. S2CID 3084322. Retrieved 22 January 2020.
- ^ Wenzel, Makarius. "Isabelle". Retrieved 2 November 2019.
- Barendregt, Henk; Geuvers, Herman (2001). "18. Proof-assistants using Dependent Type Systems" (PDF). In Robinson, Alan J.A.; Voronkov, Andrei (eds.). Handbook of Automated Reasoning. Vol. 2. Elsevier. pp. 1149–. ISBN 978-0-444-50812-6. Archived from the original (PDF) on 2007-07-27.
- Pfenning, Frank. "17. Logical frameworks" (PDF). Handbook vol 2 2001. pp. 1065–1148.
- Pfenning, Frank (1996). "The practice of logical frameworks". In Kirchner, H. (ed.). Trees in Algebra and Programming — CAAP '96. Lecture Notes in Computer Science. Vol. 1059. Springer. pp. 119–134. doi:10.1007/3-540-61064-2_33. ISBN 3-540-61064-2.
- Constable, Robert L. (1998). "X. Types in computer science, philosophy and logic". In Buss, S.R. (ed.). Handbook of Proof Theory. Studies in Logic. Vol. 137. Elsevier. pp. 683–786. ISBN 978-0-08-053318-6.
- Geuvers, H. (February 2009). "Proof assistants: History, ideas and future". Sādhanā. 34 (1): 3–25. doi:10.1007/s12046-009-0001-5. S2CID 14827467.
- Wiedijk, Freek (2005). "The Seventeen Provers of the World" (PDF). Radboud University Nijmegen.
This article's use of external links may not follow Wikipedia's policies or guidelines. (December 2022)
- Theorem Prover Museum
- "Introduction" in Certified Programming with Dependent Types.
- Introduction to the Coq Proof Assistant (with a general introduction to interactive theorem proving)
- Interactive Theorem Proving for Agda Users
- A list of theorem proving tools
- Digital Math by Category: Tactic Provers
- Automated Deduction Systems and Groups
- Theorem Proving and Automated Reasoning Systems
- Database of Existing Mechanized Reasoning Systems
- NuPRL: Other Systems
- Specific Logical Frameworks and Implementations
- DMOZ: Science: Math: Logic and Foundations: Computational Logic: Logical Frameworks