Proof assistant

Interactive theorem prover software From Wikipedia, the free encyclopedia

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.

An interactive proof session in RocqIDE, showing the proof script on the left and the proof state on the right

A recent effort within this field is making these tools use artificial intelligence to automate the formalization of ordinary mathematics.[1]

Automated proof checking

Automated proof checking is the process of using software for checking proofs for correctness. It is one of the most developed fields in automated reasoning. Automated proof checking differs from automated theorem proving in that automated proof checking simply mechanically checks the formal workings of an existing proof, instead of trying to develop new proofs or theorems itself. Because of this, the task of automated proof verification is much simpler than that of automated theorem proving, allowing automated proof checking software to be much simpler than automated theorem proving software.

Because of this small size, some automated proof checking systems can have less than a thousand lines of core code, and are thus themselves amenable to both hand-checking and automated software verification. The Mizar system, HOL Light, and Metamath are examples of automated proof checking systems. Automated proof checking can be done either as a batch operation, or interactively, as part of an interactive theorem proving system.

History

Automath, which was developed by Nicolaas Govert de Bruijn starting in 1967, is often considered the first proof checker and the first system to utilize the Curry–Howard correspondence between programs and proofs.[2] Automath was used by L.S. van Benthem Jutting in 1977 to formalize Landau's Foundations of Analysis, which was the first formalization of the real numbers.[3]

In 1973, Robert Boyer and J Moore published Proving Theorems about LISP Functions which aimed to verify programs, not mathematics.[4] Their theorem prover is now known as ACL2.

In the 1970s, Edinburgh LCF introduced the idea of using a functional programming language as the metalanguage for a theorem prover, and led to the HOL family of proof assistants.[3]

The 1990s saw the rise of Rocq, (then known as Coq), which has been used for many large-scale formalization projects. Since the late 2010s, Lean, a proof assistant strongly influence by Rocq, has become another popular choice, especially for formalizing mathematics.

System comparison

More information Name, Latest version ...
NameLatest versionDeveloper(s)Implementation languageFeatures
Higher-order logicDependent typesSmall
kernel
Proof automationProof by
reflection
Code generation
ACL28.3Matt Kaufmann, J Strother MooreCommon LispNoUntypedNoYesYes[5]Already executable
Agda2.8.0[6]Ulf Norell, Nils Anders Danielsson, and Andreas Abel (Chalmers and Gothenburg)[6]Haskell[6]Yes
[citation needed]
Yes
[7]
Yes
[citation needed]
No
[citation needed]
Partial
[citation needed]
Already executable
[citation needed]
Albatross0.4Helmut BrandlOCamlYesNoYesYesUnknownNot yet implemented
F*repositoryMicrosoft Research and INRIAF*YesYesNoYesYes[8]Yes
HOL LightrepositoryJohn HarrisonOCamlYesNoYesYesNoNo
HOL4Kananaskis-13 (or repo)Michael Norrish, Konrad Slind, and othersStandard MLYesNoYesYesNoYes
Idris2 0.6.0Edwin BradyIdrisYesYesYesUnknownPartialYes
IsabelleIsabelle2025 (March 2025)Larry Paulson (Cambridge), Tobias Nipkow (München) and Makarius WenzelStandard ML, ScalaYesNoYesYesYesYes
Lean v4.28.0-rc1[9] Leonardo de Moura (AWS) C++, Lean Yes Yes Yes Yes Yes Yes
LEGO1.3.1Randy Pollack (Edinburgh)Standard MLYesYesYesNoNoNo
Metamathv0.198[10]Norman MegillANSI C
Mizar8.1.11Białystok UniversityFree PascalPartialYesNoNoNoNo
Nqthm
NuPRL5Cornell UniversityCommon LispYesYesYesYesUnknownYes
PVS6.0SRI InternationalCommon LispYesYesNoYesNoUnknown
Rocq9.0INRIAOCamlYesYesYesYesYesYes
Twelf1.7.1Frank Pfenning, Carsten SchürmannStandard MLYesYesUnknownNoNoUnknown
Close
  • ACL2 – a programming language, a first-order logical theory, and a theorem prover (with both interactive and automatic modes) in the Boyer–Moore tradition.
  • 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:
  • IMPS, An Interactive Mathematical Proof System.[11]
  • Isabelle is an interactive theorem prover where other systems can be encoded. Isabelle/HOL is its most popular instance, whose foundation is close to that of the HOL prover. Other instances include Isabelle/ZF and Isabelle/FOL[12]. The main code-base is BSD-licensed, but the Isabelle distribution bundles many add-on tools with different licenses.
  • Jape – Java based.
  • Lean is both an interactive theorem prover and a functional, dependently-typed programming language. It is based on the calculus of inductive constructions with non-cumulative universes. Since version 4 (released in 2023), it is self-hosting. It can be used to formalise mathematics (and has a large, coherent library for formal mathematics), but also for software and hardware verification.
  • LEGO
  • 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.
  • Rocq (formerly named Coq) – A popular interactive theorem prover based on the calculus of inductive constructions.
  • Theorem Proving System (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.

User interfaces

A commonly used front-end for proof assistants was the Emacs-based Proof General, developed at the University of Edinburgh. Nowadays, many provers include their own editor. Rocq includes RocqIDE, 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, Visual Studio Code extensions have been developed for Rocq,[13] Isabelle by Makarius Wenzel,[14] and for Lean 4 by the leanprover developers.[15]

Formalization extent

Freek Wiedijk has been keeping a ranking of proof assistants by the amount of formalized theorems out of a list of 100 well-known theorems. As of September 2025, only six systems have formalized proofs of more than 70% of the theorems, namely Isabelle, HOL Light, Lean, Rocq, Metamath and Mizar.[16][17]

Notable formalized proofs

The following is a list of notable proofs that have been formalized within proof assistants.

More information Polynomial Freiman-Ruzsa conjecture over ...
Theorem Proof assistant Year
Four color theorem[18]Rocq2005
Feit–Thompson theorem[19]Rocq2012
Fundamental group of the circle[20]Rocq2013
Erdős–Graham problem[21][22] Lean 2022
Polynomial Freiman-Ruzsa conjecture over [23]Lean2023
BB(5) = 47,176,870[24] Rocq 2024
Close

See also

References

References

Related Articles

Wikiwand AI