Proof assistant








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


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.




Contents





  • 1 Comparison of systems


  • 2 User interface


  • 3 See also


  • 4 Notes


  • 5 References


  • 6 External links




Comparison of systems


























































































































































NameLatest versionDeveloper(s)Implementation languageFeatures
Higher-order logicDependent typesSmall kernelProof automationProof by reflection
Code generation
ACL27.1
Matt Kaufmann and J Strother Moore
Common LispNoUntypedNoYesYes[1]Already executable
Agda2.5.1.1
Ulf Norell, Nils Anders Danielsson, and Andreas Abel (Chalmers and Gothenburg)HaskellYesYesYesNoPartialAlready executable
Albatross0.4
Helmut BrandlOCamlYesNoYesYesUnknownNot Yet Implemented
Coq8.8INRIAOCamlYesYesYesYesYesYes
F*repository
Microsoft Research and INRIA
F*YesYesNoYesUnknownYes
HOL LightrepositoryJohn HarrisonOCamlYesNoYesYesNoNo
HOL4Kananaskis-12 (or repo)Michael Norrish, Konrad Slind, and othersStandard MLYesNoYesYesNoYes
Isabelle2018
Larry Paulson (Cambridge), Tobias Nipkow (München) and Makarius Wenzel

Standard ML, Scala
YesNoYesYesYesYes

Lean
repository

Microsoft Research
C++
Yes
Yes
Yes
Yes
Yes
Unknown
LEGO (not affiliated with the LEGO company)1.3.1
Randy Pollack (Edinburgh)
Standard MLYesYesYesNoNoNo
Mizar8.1.05Białystok UniversityFree PascalPartialYesNoNoNoNo
NuPRL5Cornell UniversityCommon LispYesYesYesYesUnknownYes
PVS5.0SRI InternationalCommon LispYesYesNoYesNoUnknown
Twelf1.7.1
Frank Pfenning and Carsten Schürmann
Standard MLYesYesUnknownNoNoUnknown

  • 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 – Which 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.



  • 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.

  • 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.


  • 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.

  • Typelab

  • Yarrow


User interface


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.



See also


  • Automated theorem proving

  • Computer-assisted proof

  • QED manifesto

  • Satisfiability modulo theories


  • Metamath – a language for developing strictly formalized mathematical definitions and proofs accompanied by a proof checker for this language and a growing database of thousands of proved theorems


Notes




  1. ^ Hunt, Warren; Matt Kaufmann; Robert Bellarmine Krug; J Moore; Eric W. Smith (2005). "Meta Reasoning in ACL2" (PDF). Springer Lecture Notes in Computer Science. 3603: 163–178..mw-parser-output cite.citationfont-style:inherit.mw-parser-output .citation qquotes:"""""""'""'".mw-parser-output .citation .cs1-lock-free abackground:url("//upload.wikimedia.org/wikipedia/commons/thumb/6/65/Lock-green.svg/9px-Lock-green.svg.png")no-repeat;background-position:right .1em center.mw-parser-output .citation .cs1-lock-limited a,.mw-parser-output .citation .cs1-lock-registration abackground:url("//upload.wikimedia.org/wikipedia/commons/thumb/d/d6/Lock-gray-alt-2.svg/9px-Lock-gray-alt-2.svg.png")no-repeat;background-position:right .1em center.mw-parser-output .citation .cs1-lock-subscription abackground:url("//upload.wikimedia.org/wikipedia/commons/thumb/a/aa/Lock-red-alt-2.svg/9px-Lock-red-alt-2.svg.png")no-repeat;background-position:right .1em center.mw-parser-output .cs1-subscription,.mw-parser-output .cs1-registrationcolor:#555.mw-parser-output .cs1-subscription span,.mw-parser-output .cs1-registration spanborder-bottom:1px dotted;cursor:help.mw-parser-output .cs1-ws-icon abackground:url("//upload.wikimedia.org/wikipedia/commons/thumb/4/4c/Wikisource-logo.svg/12px-Wikisource-logo.svg.png")no-repeat;background-position:right .1em center.mw-parser-output code.cs1-codecolor:inherit;background:inherit;border:inherit;padding:inherit.mw-parser-output .cs1-hidden-errordisplay:none;font-size:100%.mw-parser-output .cs1-visible-errorfont-size:100%.mw-parser-output .cs1-maintdisplay:none;color:#33aa33;margin-left:0.3em.mw-parser-output .cs1-subscription,.mw-parser-output .cs1-registration,.mw-parser-output .cs1-formatfont-size:95%.mw-parser-output .cs1-kern-left,.mw-parser-output .cs1-kern-wl-leftpadding-left:0.2em.mw-parser-output .cs1-kern-right,.mw-parser-output .cs1-kern-wl-rightpadding-right:0.2em




References



  • Henk Barendregt and Herman Geuvers (2001). "Proof-assistants using Dependent Type Systems". In Handbook of Automated Reasoning.

  • Frank Pfenning (2001). "Logical frameworks". In Handbook of Automated Reasoning.


  • Frank Pfenning (1996). "The Practice of Logical Frameworks".


  • Robert L. Constable (1998). "Types in computer science, philosophy and logic". In Handbook of Proof Theory.

  • H. Geuvers. "Proof assistants: History, ideas and future".

  • Freek Wiedijk. "The Seventeen Provers of the World"


External links



  • "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

Catalogues
  • 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


Popular posts from this blog

Peggy Mitchell

Palaiologos

The Forum (Inglewood, California)