HOL (kontrolní asistent) - HOL (proof assistant)

HOL
NavrhlMichael J. C. Gordon
LicenceUpravená (3-klauzule) licence BSD
Přípony názvu souboru.ml
webová stránkahol-teorem-prover.org

HOL (Logika vyšších objednávek) označuje rodinu systémy pro ověřování interaktivních vět podobné (vyšší řád) logika a implementační strategie. Systémy v této rodině následují LCF přístup, protože jsou implementovány jako knihovna v některých programovacích jazycích. Tato knihovna implementuje abstraktní datový typ prokázané věty takže nové objekty tohoto typu lze vytvářet pouze pomocí funkcí v knihovně, které odpovídají odvozovací pravidla v logika vyššího řádu. Pokud jsou tyto funkce správně implementovány, musí být platné všechny věty ověřené v systému. Tímto způsobem lze vybudovat velký systém na vrcholu malého důvěryhodného jádra.

Systémy v rodině HOL používají ML programovací jazyk nebo jeho nástupci. ML byl původně vyvinut spolu s LCF, aby sloužil účelu metajazyka pro systémy dokazující věty; ve skutečnosti název znamená „metajazyk“.

Základní logika

Systémy HOL používají varianty klasický logika vyššího řádu, který má jednoduché axiomatické základy s několika axiomy a dobře srozumitelnou sémantikou.[1]

Logika použitá v testech HOL úzce souvisí s Isabelle / HOL,[2] nejpoužívanější logika Isabelle.

Členové rodiny ověřovatelů HOL

Existují čtyři systémy HOL (sdílející v podstatě stejnou logiku), které jsou stále udržovány a vyvíjeny.

  • První, HOL4 vychází ze systému HOL88, který byl vyvrcholením původního implementačního úsilí HOL, vedeného Mike Gordon. HOL88 zahrnoval vlastní implementaci ML, která byla zase implementována nad Společný Lisp. Všechny implementace následující po HOL88 (HOL90, hol98 a HOL4) byly použity Standardní ML jako implementační jazyk. Systém hol98 je vázán na Moskva ML implementace Standardní ML; HOL4 lze postavit s oběma Moskva ML nebo Poly / ML. Z těchto čtyř systémů se udržuje a vyvíjí pouze HOL4. Všechny přicházejí s velkými knihovnami ověřovacího kódu věty. Tyto implementují další automatizaci navíc k velmi jednoduchému základnímu kódu. HOL4 má licenci BSD.[3]
  • Druhou současnou implementací je HOL Light. Začalo to jako experimentální „minimalistická“ verze HOL. Ačkoli se následně rozrostla do další tradiční varianty HOL, její logické základy zůstávají neobvykle jednoduché. HOL Light bývalo implementováno v Velbloudí světlo, ale nyní používá OCaml. HOL Light je k dispozici pod novou licencí BSD.[4]
  • Třetí současná implementace je ProofPower sbírka nástrojů určených k poskytování zvláštní podpory při práci s Z notace pro formální specifikaci. 5 ze 6 nástrojů má licenci GNU GPL v2. Šestý (PPDaz) má proprietární licenci.[5]
  • Čtvrtý je HOL nula, minimalistická implementace zaměřená na důvěryhodnost. HOL Zero má licenci GNU GPL 3+.[6]

Ačkoli HOL je předchůdcem Isabelle, různé deriváty HOL, jako jsou HOL4 a HOL Light, zůstávají aktivní a používají se.

Vybraný vývoj formálních důkazů

CakeML[7] Projekt vyvinul formálně osvědčený překladač pro ML. Dříve byl HOL používán k vývoji formálně ověřeného LISP implementace běžící na ARM, x86 a PowerPC.[8]

HOL byl také použit k vývoji formální sémantiky pro x86 multiprocesory,[9] stejně jako sémantika strojového kódu pro Napájení ISA a PAŽE architektury.[10]

Reference

  1. ^ Andrews, Peter B (2002). Úvod do matematické logiky a teorie typů: k pravdě skrz důkaz. Aplikovaná logická řada. 27 (Druhé vydání.). Dordrecht: Kluwer Academic Publishers. ISBN  978-1-4020-0763-7.
  2. ^ Tobias Nipkow; Markus Wenzel; Lawrence C. Paulson (2002). Isabelle / HOL: Proof Assistant for Higher-Order Logic. Berlin, Heidelberg: Springer-Verlag. ISBN  978-3-540-45949-1.
  3. ^ „HOL Interactive Theorem Prover“.
  4. ^ "HOL Light".
  5. ^ „Získání ProofPower“.
  6. ^ Viz soubor LICENCE v tarball Archivováno 03.03.2012 na Wayback Machine.
  7. ^ „CakeML“.
  8. ^ Magnus O. Myreen; Michael J. C. Gordon. Ověřené implementace LISP na ARM, x86 a PowerPC (PDF). TPHOLs 2009. str. 359–374.
  9. ^ Peter Sewell; Susmit Sarkar; Scott Owens; Francesco Zappa Nardelli; Magnus O. Myreen (2010). „x86-TSO: přísný a použitelný programátorský model pro x86 multiprocesory“ (PDF). Komunikace ACM. 53 (7): 89–97. doi:10.1145/1785414.1785443.
  10. ^ Jade Alglave; Anthony C. J. Fox; Samin Ishtiaq; Magnus O. Myreen; Susmit Sarkar; Peter Sewell; Francesco Zappa Nardelli. Sémantika výkonu a víceprocesorový strojový kód ARM (PDF). VLHKINA 2009. s. 13–24.

Další čtení

externí odkazy