sources - CAVE-PNP/cave-pnp GitHub Wiki
Sources and Literature
- P vs NP
- Isabelle/HOL
- Coq
- Other Proof Assistants
- General Quotes
- Additional reading
- Missing/Hard-to-Find Resources
P vs NP
pvsnp.pdf
: Stephen Cook: The P versus NP Problem. 2006.
Related Topics
relative.pdf
: Lance Fortnow: The Role of Relativization in Complexity Theory. 1994.
Isabelle/HOL
Formalizations
This section lists results and resources relevant to or close to the topic of this project.
- AFP backlog
- relevant topics include: Algorithms, Data Structures, Security, Computability, Probability, Graph theory
- [TODO] look into
- Andreas Lochbihler: CryptHOL
- Andreas Lochbihler and S. Reza Sefidgar: Constructive Cryptography in HOL
tm.pdf
: Jian Xu and Xingyuan Zhang and Christian Urban: Mechanising Turing Machines and Computability Theory in Isabelle/HOL. Springer 2013. (in AFP)- Turing machine alphabet is ${Bk,Oc}$ (for Blank and Occupied, resp., amounts to unary encoding)
- follows the structure of Boolos et al.: Computability and Logic. Cambridge University Press 2007.
- use abacus machines (counter-machines, a kind of register machine) to make more complicated TM programs feasible and prove that abacus machines can be simulated on TMs
- use recursive functions to make complicated abacus programs feasible and prove that recursive functions can be computed by abacus machines
- GitHub repo: The Archive of Graph Formalizations (collection of graph-related works)
- Lars Noschinski: Graph Theory
This development provides a formalization of directed graphs, supporting (labelled) multi-edges and infinite graphs.
- Lars Noschinski: Graph Theory
- Robin Eßmann and Tobias Nipkow and Simon Robillard: Verified Approximation Algorithms (in AFP)
- Using Hoare logic (implemented in HOL)
- Jeremy Avigad and Kevin Donnelly: Formalizing $O$ notation in Isabelle/HOL (distributed as part of
HOL-Library
) - Bohua Zhan et al.: Verifying Asymptotic Time Complexity of Imperative Programs in Isabelle
- see also GitHub repo
- Tobias Nipkow: Amortized Complexity Verified (in AFP)
- focus on data structures
- uses an invariant approach with an additional property for amortized potential
- Frank J. Balbach: Some classical results in inductive inference of recursive functions (in AFP)
- contains formalization of Gödel numbers
- specific to inductive inference, thus probably not useful for paper #116
- contains formalization of Gödel numbers
Quick Reference
- isabelle.systems - Isabelle Quick Access Links
- Isabelle Search
- filter by type
- allows following uses and used by relations of definitions
- search includes Isabelle sources and AFP
- The cookbook
useful tips/tricks/hints for Isabelle users contributed by the community
- the section on Proof Methods and the examples on Chained facts are recommended reading
- not to be confused with The Isabelle Cookbook on Isabelle/ML (see above)
how_to_prove_it.pdf
: Tobias Nipkow: How to Prove it in Isabelle/HOL.- solutions for common issues over
nat
,list
, and for arithmetic statements
- solutions for common issues over
- Isabelle/Isar (syntax) quick reference (Appendix A of
isar-ref.pdf
) - Isabelle Cheat Sheet on the community wiki
- Isabelle / Proof General Cheat Sheet
- somewhat outdated
Tutorials
Note: Markus Wenzel seems to be using the name Makarius Wenzel since ~2007 as can be seen in the list of his publications on his page on the website of the Technische Universität München.
Many of the sources provided here are taken from the Documentation page on the Isabelle homepage, and the homepage as well as the page Course Material of the community wiki.
- Getting Started with Isabelle/jEdit in 2018
- very short introduction of how to set up and work with Isabelle/jEdit
- Thomas Genet: A Short Isabelle/HOL Tutorial for the Functional Programmer
- very short "depth-first" look into Isabelle
- many concepts are explained on-the-fly
- requires an understanding of functional programming
concrete_semantics.pdf
: Tobias Nipkow and Gerwin Klein: Concrete Semantics- full book as PDF available on the homepage
prog-prove.pdf
is Part I of this book- Tobias Nipkow: Programming and Proving in Isabelle/HOL.
- this is the top entry in the list of documentation items on the Isabelle homepage
- is updated (along with other official documentation) with every release
- gives a solid introduction to the basics of using Isabelle/Isar
tutorial.pdf
: Tobias Nipkow and Lawrence C. Paulson and Markus Wenzel: Isabelle/Hol: A Proof Assistant for Higher-Order Logic. Springer 2020.- this is an updated version of the book of the same name (published by Springer, 2002) that is available in the AAU library (see here)
- there was a lecture based on this book with materials available here
jedit.pdf
: Makarius Wenzel: Isabelle/jEdit. 2020.- more in-depth overview of the features of Isabelle/jEdit
- Christian Urban et al.: The Isabelle Cookbook
- Tutorial about programming on the ML level of Isabelle for users who are already familiar with Isabelle
- Course: Thomas Genet: ACF: Software Formal Analysis and Design,
6 lectures and 10 lab sessions, WS20
- full course materials are publicly available (including lectures in french)
-
Disclaimer: this is a course on formal software design and not on proof design. Students are given a limited set of proof tactics that is enough to prove properties defined during the lab sessions. However, resulting proofs can be long and cumbersome. As a result, it is accepted that properties are not proven but only checked using Isabelle/HOL powerful counter-example finders.
- Course: Clemens Ballarin and Gerwin Klein:
Introduction to the Isabelle Proof Assistant
- one-day introduction to Isabelle
- materials (slides, exercises) available
- starts by formally introducing syntax, explaining inner workings -> not recommended for starters
- Course: Holger Gast: Interactive Software Verification
- materials (slides, exercises & solutions) available online
- introduction and working with Isabelle
- focus on software verification (small C-like language)
Resources
- isabelle.systems - Isabelle Quick Access Links
- The Archive of Formal Proofs (AFP)
- a collection of proof libraries, examples, and larger scientific developments
- official proof repository of Isabelle
- Homepage of Isabelle
- Documentation
- Tutorials (excerpts included in the section above)
- Reference Manuals
system.pdf
extensive manual for theisabelle
CLI (backend)implementation.pdf
- some interesting resources are hard to find or are not linked to
- specific versions of the homepage (e.g. Isabelle2019) can be accessed
by inserting
website-Isabelle20xx/
between host and path (see also version history) for example, viewing an old version of the documentation overview: - all files of a distribution can be accessed through the
dist/
path
- specific versions of the homepage (e.g. Isabelle2019) can be accessed
by inserting
- Documentation
- Isabelle community Wiki
- seems to consist of 33 pages in total with most not being very long (2021-02-06)
- custom
isa-*:
links are broken (2021-08-02)- fix by inserting the URL of the Isabelle homepage. example:
- Sketis - Homepage of Makarius Wenzel,
also hosts most Isabelle development-related resources, services and tools
- Overview: Isabelle Development
- Blog: Isabelle NEWS
- Blog: Isabelle Release
- Overview: Isabelle Development
- Mailing Lists
- for users: The Cl-isabelle-users Archives
- for devs: The isabelle-dev Archives
- Talks from Makarius Wenzel (hosted on YouTube)
talk:isa-news
Makarius Wenzel: Isabelle NEWS and trends in 2020 (Isabelle 2020)- new features in Isabelle2020
- development trends (where will time be invested)
talk:isa-vscode
Makarius über Isabelle/VSCode (in German)- the inner workings of Isabelle/VSCode
- benefits and drawbacks when compared to Isabelle/jEdit (the main platform)
talk:isa_intro
Makarius Wenzel: Einführung in Isabelle- inner workings and structure of Isabelle/HOL
- Pure (just natural deduction)
- HOL (definition of
theorem
,rule
,datatype
) - Isar (
fix
,assume
,from
,with
,have
,show
)
- examples
- the concept that proof "by auto" is less valuable/informative
than one where the intermediate steps are enumerated
- i.e. only using the
..
("default") and.
("immediate") tactics - these tactics and the concept are not mentioned in
prog-prove.pdf
- i.e. only using the
- the concept that proof "by auto" is less valuable/informative
than one where the intermediate steps are enumerated
- inner workings and structure of Isabelle/HOL
- Isabelle Community Conventions
- Conventions for various aspects of the Isabelle ecosystem
- Gerwin Klein's Style Guide for Isabelle/HOL
(Part 1: Good Proofs,
Part 2: Good Style)
- Tips/~Conventions for Isabelle/HOL
- Style Guide for Contributors to IsarMathLib
- proposes some interesting rules for additional readability in Isar proofs
Coq
Formalizations
- The Coq Package Index
- proof repository of Coq
- part of the OCaml Package Manager (OPAM)
- counterpart of the Isabelle AFP
- see also the Package Ecosystem section here
- EasyCrypt (GitHub repo)
EasyCrypt is a toolset for reasoning about relational properties of probabilistic computations with adversarial code. Its main application is the construction and verification of game-based cryptographic proofs.
- CertiCrypt (GitHub repo)
CertiCrypt is a toolset that assists the construction and verification of cryptographic proofs; it supports common patterns of reasoning in cryptography, and has been used successfully to prove the security of many constructions [...]
- CertiCrypt (GitHub repo)
- Forster et al.: A Coq Library of Undecidable Problems
- collection of results from computability and complexity theory
- sources available as
github:uds-psl/coq-library-undecidability
- maintained by the University of Saarland
- related: The Coq Library of Complexity Theory (GitHub repository)
- builds upon the Coq Library of Undecidable Problems to extend further into complexity theory
- includes a proof for the Time Hierarchy Theorem
exists (P : term * nat -> Prop), ~P ∈Timeo f /\ P ∈TimeO (fun n => n * f n * f n).
- the target model of computability seems to be the weak call-by-value λ-calculus (
L
)- complexity is "formulated for the call-by-value lambda calculus
L
"- introduced by Forster et al.: Weak Call-by-Value Lambda Calculus as a Model of Computation in Coq. Springer 2018.
- there is ongoing work toward replacing TMs with
L
as the main model of computation in complexity theory- Forster et al.: A Mechanised Proof of the Time Invariance Thesis for the Weak Call-by-value λ-Calculus.
Draft, to be presented at ITP 2021.
- L and TMs can simulate each other with poly-time overhead
- the number of β-reductions is used as time-measure for
L
- the number of β-reductions is used as time-measure for
- sources:
github:uds-psl/time-invariance-thesis-for-L
, to be included in the Coq Library of Undecidable Problems
- L and TMs can simulate each other with poly-time overhead
- Forster et al.: The Weak Call-By-Value λ-Calculus is Reasonable for Both Time and Space.
ACM 2019.
- L and TMs can simulate each other with polynomial time-overhead and a linear overhead in space
- the size of the largest term in the computation is used as space measure for `L``
- terms in L may exhibit size explosion, but this can always be avoided
- not to be mechanized until problems with space measure are resolved
- see the explanations given in the presentation at the POPL 2020 conference
- hosted as supplemental material on the ACM entry of the paper
- L and TMs can simulate each other with polynomial time-overhead and a linear overhead in space
- Forster et al.: A Mechanised Proof of the Time Invariance Thesis for the Weak Call-by-value λ-Calculus.
Draft, to be presented at ITP 2021.
- complexity is "formulated for the call-by-value lambda calculus
- Yannick Forster, Fabian Kunze, and Maximilian Wuttke:
Verified Programming of Turing Machines in Coq. ACM 2020.
- TMs with space and time complexity, including the universal TM
- maintained as part of the Coq Library of Undecidable Problems (see above)
- static standalone (paper) version available as
github:uds-psl/tm-verification-framework
- static standalone (paper) version available as
- extends Wuttke's Bachelor's thesis of the same name
- this is not confirmed, but definitions and content match
- the universal TM and space complexity are not parts of the Bachelor's thesis
- states the heavy use of dependent types, making this particular formalization of TMs rather unpleasant for proof assistants that do not support them (like Isabelle/HOL)
- it may be possible to work around this using the pattern suggested by Tobias Nipkow (unconstrained type + predicate)
- based on the Matita implementation by Asperti and Ricciotti (see below)
- see the external Appendix for definitions that are left out in the paper
- see also the Bachelor's thesis
- multi-tape TMs
- universal TM simulates single tape TM
- compiler from multi-tape to single-tape
- three abstraction layers from standard TM to ~register machine/pseudo code
- custom tactics for reasoning about TMs
- the authors state (about a certain kind of statement) that "using them by hand is almost impossible"
- the tactic (
TMSimp
) simplifies goals by "destruction of complex assumptions" (i.e. conjunctions, existentials) and "exhaustively rewriting with all available equations between tapes"
- Lennard Gäher and Fabian Kunze: Mechanising Complexity Theory: The Cook-Levin Theorem in Coq
- unpublished (2021-04-30), set to be presented at the ITP 2021 conference
- based on Lennard Gäher: Towards a Formal Proof of the Cook-Levin Theorem. Bachelor's thesis, 2020.
- sources available on GitHub as github:uds-psl/cook-levin
- to be included in the Coq Library of Complexity Theory (see above)
- see also the compiled documentation
Tutorials
The documentation section on the Coq homepage gives an overview of resources.
sf1
: Benjamin C. Pierce et al.: Software Foundations, Volume 1: Logical Foundations. Online book. I consider this to be the best Coq introduction.MPCTT
: Gert Smolka: Modeling and Proving in Computational Type Theory Using the Coq Proof Assistant. "Textbook, under construction", 2021.- accompanying git repository github:uds-psl/MPCTT
Resources
- Coq Documentation
- recommended reading: Built-in decision procedures and programmable tactics
- Tricks in Coq
- (outdated) Overview of the Coq Ecosystem
Other Proof Assistants
General
-
Michael Kohlhase and Florian Rabe: Experiences from Exporting Major Proof Assistant Libraries
- comments on the interoperability of proof assistants
-
Blanchette et al: Hammering towards QED
- History and techniques of "hammers", strong automated tools that allow users of ITPs to make use of ATPs
-
Its four authors can be considered the main hammer people (Sledgehammer, MizAR, HOLyHammer, CoqHammer).
Matita
- Homepage: http://matita.cs.unibo.it
- Developed at: Computer Science Department of the University of Bologna
- Latest release (as of 2021-04): 0.99.3 (2016-05-18)
- sources: self-hosted git (active 2021-03)
Based on the Calculus of (Co)Inductive Constructions, like Coq.
Publications
- Asperti et al.: Crafting a Proof Assistant. Springer 2007.
- includes comparison to Coq
- Asperti et al.: The Matita Interactive Theorem Prover. Springer 2011.
Formalizations
- Andrea Asperti, and Wilmer Ricciotti: Formalizing Turing Machines. Springer 2012.
- Follow-up: A Formalization of Multi-tape Turing Machines. Springer 2015.
- comparison to
tm.pdf
- Asperti and Ricciotti cite the complexity of the machines in
tm.pdf
, in contrast to the composition of very small machines - "In particular, the fact that the universal machine operates with a different alphabet with respect to the machines it simulates is annoying."
- Asperti and Ricciotti cite the complexity of the machines in
General Quotes
-
Manuel Herold, realizing that the solution is trivial, mere seconds after asking whether $P$ is $NP$:
$P = NP$ genau dann, wenn $P = 0$ oder $N = 1$.
-- Manuel Herold, Personal communications (Max), 2021-01-08.
-
The quote in the section on Relativization (Basic Idea)
-
From the preface of Concrete Semantics (cited above), on theorem proving assistants:
-
The beauty is that this includes checking the logical correctness of all proof text. No more 'proofs' that look more like LSD trips than coherent chains of logical arguments.
-
But only recently have proof assistants become mature enough for inflicting them on students without causing the students too much pain.
-
-
A "snarky remark" on possible reasons for why there is no sledgehammer for Coq (from Lawrence Paulson: Sledgehammer: some history, some tips)
-
One of the reasons I prefer higher-order logic to dependent type theories — apart from simple semantics, equality that works and no need to put everything in the kernel — is that dependent types seem to make automation much more difficult. Groups with access to institutional support and steady, ample resources still don’t seem to have duplicated what had been built at Cambridge on a single £250K grant. And please don’t say “dependent type checking makes other automation unnecessary”. Yes, I keep hearing this.
-
-
From Scott Aaronson: Death of proof greatly exaggerated (answer to John Horgan: The Death of Proof)
-
In many areas of math (including my own, theoretical computer science), proofs have continued to get longer and harder for any one person to absorb. This has led some to advocate a split approach, wherein human mathematicians would talk to each other only about the handwavy intuitions and high-level concepts, while the tedious verification of details would be left to computers. So far, though, the huge investment of time needed to write proofs in machine-checkable format — for almost no return in new insight — has prevented this approach’s wide adoption.
- see also the wider discussion on whether automated proof assistants are the end of formal mathematics, for instance Okay, Maybe Proofs Aren't Dying After All by John Horgan
-
Additional reading
Comparison of proof assistants
Inspecting solver steps
- Stackoverflow: How to see step-by-step reasoning of Isabelle 'proofs'
- has a somewhat unsatisfying answer of why we can "trust" Isabelle and that the actual list of steps (pure natural deduction) would be too long to comprehend
- Stackoverflow: Can resolution proofs be traced in Isabelle?
Unsorted Resources
These are everything from blog posts to StackExchange questions that may be of use at some point.
- https://cs.stackexchange.com/questions/41501/relativization-results-in-class-separation
- https://mathoverflow.net/questions/75890/definition-of-relativization-of-complexity-class
- https://cstheory.stackexchange.com/questions/1388/proofs-barriers-and-p-vs-np
- https://www.cs.toronto.edu/~toni/Courses/PvsNP/Lectures/lecture11.pdf
- https://cstheory.stackexchange.com/questions/48164/formalization-of-simulation-for-turing-machines
Missing/Hard-to-Find Resources
- Hartmanis1985. J Hartmanis: Solvable problems with conflicting relativizations
- paper is frequently quoted in works on relativization but nowhere to be found
- given an oracle $A$ such that $P^A = NP^A$, one could construct an oracle $B$ such that $P^{A,B} ≠ NP^{A,B}$, which would mean that $P^A = NP^A$ does not relativize. (see [Hartmanis1985] as cited in Allender1990)
- some believe that "[statements that do not relativize] may fall outside the axioms of set theory"
(see [Hartmanis1985] as quoted in
relative.pdf
)