Katana VentraIP

Isabelle (proof assistant)

The Isabelle[a] automated theorem prover is a higher-order logic (HOL) theorem prover, written in Standard ML and Scala. As an LCF-style theorem prover, it is based on a small logical core (kernel) to increase the trustworthiness of proofs without requiring — yet supporting — explicit proof objects.

Isabelle is available inside a flexible system framework allowing for logically safe extensions, which comprise both theories as well as implementations for code-generation, documentation, and specific support for a variety of formal methods. It can be seen as an IDE for formal methods. In recent years, a substantial number of theories and system extensions have been collected in the Isabelle Archive of Formal Proofs (Isabelle AFP)[2]


Isabelle was named by Lawrence Paulson after Gérard Huet's daughter.[3]


The Isabelle theorem prover is free software, released under the revised BSD license.

Katana VentraIP

$_$_$DEEZ_NUTS#0__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#0__subtitleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#0__call_to_action.textDEEZ_NUTS$_$_$
Katana VentraIP

$_$_$DEEZ_NUTS#0__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#0__subtitleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#0__call_to_action.textDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#2__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#2__descriptionDEEZ_NUTS$_$_$

Features[edit]

Isabelle is generic: it provides a meta-logic (a weak type theory), which is used to encode object logics like first-order logic (FOL), higher-order logic (HOL) or Zermelo–Fraenkel set theory (ZFC). The most widely used object logic is Isabelle/HOL, although significant set theory developments were completed in Isabelle/ZF. Isabelle's main proof method is a higher-order version of resolution, based on higher-order unification.


Though interactive, Isabelle features efficient automatic reasoning tools, such as a term rewriting engine and a tableaux prover, various decision procedures, and, through the Sledgehammer proof-automation interface, external satisfiability modulo theories (SMT) solvers (including CVC4) and resolution-based automated theorem provers (ATPs), including E, SPASS, and Vampire (the Metis[b] proof method reconstructs resolution proofs generated by these ATPs).[4] It also features two model finders (counterexample generators): Nitpick[5] and Nunchaku.[6]


Isabelle features locales which are modules that structure large proofs. A locale fixes types, constants, and assumptions within a specified scope[5] so that they do not have to be repeated for every lemma.


Isar ("intelligible semi-automated reasoning") is Isabelle's formal proof language. It is inspired by the Mizar system.[5]

$_$_$DEEZ_NUTS#3__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__descriptionDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#2__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#2__descriptionDEEZ_NUTS$_$_$

In 2009, the L4.verified project at produced the first formal proof of functional correctness of a general-purpose operating system kernel:[8] the seL4 (secure embedded L4) microkernel. The proof is constructed and checked in Isabelle/HOL and comprises over 200,000 lines of proof script to verify 7,500 lines of C. The verification covers code, design, and implementation, and the main theorem states that the C code correctly implements the formal specification of the kernel. The proof uncovered 144 bugs in an early version of the C code of the seL4 kernel, and about 150 issues in each of design and specification.

NICTA

Isabelle has been used to aid formal methods for the specification, development and verification of software and hardware systems.


Isabelle has been used to formalize numerous theorems from mathematics and computer science, like Gödel's completeness theorem, Gödel's theorem about the consistency of the axiom of choice, the prime number theorem, correctness of security protocols, and properties of programming language semantics. Many of the formal proofs are, as mentioned, maintained in the Archive of Formal Proofs, which contains (as of 2019) at least 500 articles with over 2 million lines of proof in total.[7]


Larry Paulson keeps a list of research projects that use Isabelle.[10]

written in Haskell

Agda

written in OCaml

Coq

written in C++

Lean

written in Standard ML of New Jersey

LEGO

written in Free Pascal

Mizar system

written in ANSI C

Metamath

written in C, with a GUI written in Python

Prover9

written in Standard ML

Twelf

Several languages and systems provide similar functionality:

Official website

Isabelle on Stack Overflow

The Archive of Formal Proofs

IsarMathLib

$_$_$DEEZ_NUTS#6__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__subtextDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__quote--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__name--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__company_or_position--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__subtextDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__quote--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__name--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__company_or_position--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__subtextDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__quote--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__name--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__company_or_position--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__subtextDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__quote--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__name--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__company_or_position--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__quote--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__name--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__company_or_position--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__quote--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__name--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__company_or_position--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__quote--3DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__name--3DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__company_or_position--3DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__quote--4DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__name--4DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__company_or_position--4DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__quote--5DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__name--5DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__company_or_position--5DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__quote--6DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__name--6DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#3__company_or_position--6DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__subtextDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__quote--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__name--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__company_or_position--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__quote--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__name--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__company_or_position--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__quote--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__name--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#6__company_or_position--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__subtextDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__quote--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__name--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__company_or_position--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__quote--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__name--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__company_or_position--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__quote--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__name--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#4__company_or_position--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__subtextDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__quote--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__name--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__company_or_position--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__quote--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__name--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#5__company_or_position--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__subtextDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--3DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--4DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--5DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--6DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--7DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--8DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--9DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--10DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--11DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--12DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__titleDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__subtextDEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--0DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--1DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--2DEEZ_NUTS$_$_$

$_$_$DEEZ_NUTS#1__answer--3DEEZ_NUTS$_$_$