| author | wenzelm | 
| Wed, 11 Oct 2023 11:37:18 +0200 | |
| changeset 78758 | 05da36bc806f | 
| parent 77141 | 1310df9229bd | 
| child 79766 | feec445a82c3 | 
| permissions | -rw-r--r-- | 
| 47269 | 1 | Isabelle is a generic system for | 
| 58502 | 2 | implementing logical formalisms, and Isabelle/HOL is the specialization | 
| 47269 | 3 | of Isabelle for HOL, which abbreviates Higher-Order Logic. We introduce | 
| 4 | HOL step by step following the equation | |
| 5 | \[ \mbox{HOL} = \mbox{Functional Programming} + \mbox{Logic}. \]
 | |
| 56989 | 6 | We assume that the reader is used to logical and set-theoretic notation | 
| 52782 | 7 | and is familiar with the basic concepts of functional programming. | 
| 8 | \ifsem | |
| 9 | Open-minded readers have been known to pick up functional | |
| 10 | programming through the wealth of examples in \autoref{sec:FP}
 | |
| 11 | and \autoref{sec:CaseStudyExp}.
 | |
| 12 | \fi | |
| 47269 | 13 | |
| 14 | \autoref{sec:FP} introduces HOL as a functional programming language and
 | |
| 15 | explains how to write simple inductive proofs of mostly equational properties | |
| 16 | of recursive functions. | |
| 52782 | 17 | \ifsem | 
| 47269 | 18 | \autoref{sec:CaseStudyExp} contains a
 | 
| 54508 | 19 | small case study: arithmetic and boolean expressions, their evaluation, | 
| 47269 | 20 | optimization and compilation. | 
| 52782 | 21 | \fi | 
| 47269 | 22 | \autoref{ch:Logic} introduces the rest of HOL: the
 | 
| 56989 | 23 | language of formulas beyond equality, automatic proof tools, single-step | 
| 24 | proofs, and inductive definitions, an essential specification construct. | |
| 47269 | 25 | \autoref{ch:Isar} introduces Isar, Isabelle's language for writing structured
 | 
| 26 | proofs. | |
| 27 | ||
| 28 | %Further material (slides, demos etc) can be found online at | |
| 29 | %\url{http://www.in.tum.de/~nipkow}.
 | |
| 30 | ||
| 31 | % Relics: | |
| 32 | % We aim to minimise the amount of background knowledge of logic we expect | |
| 33 | % from the reader | |
| 34 | % We have focussed on the core material | |
| 35 | % in the intersection of computation and logic. | |
| 36 | ||
| 37 | This introduction to the core of Isabelle is intentionally concrete and | |
| 54508 | 38 | example-based: we concentrate on examples that illustrate the typical cases | 
| 39 | without explaining the general case if it can be inferred from the examples. | |
| 52782 | 40 | We cover the essentials (from a functional programming point of view) as | 
| 41 | quickly and compactly as possible. | |
| 42 | \ifsem | |
| 43 | After all, this book is primarily about semantics. | |
| 44 | \fi | |
| 45 | ||
| 47269 | 46 | For a comprehensive treatment of all things Isabelle we recommend the | 
| 47 | \emph{Isabelle/Isar Reference Manual}~\cite{IsarRef}, which comes with the
 | |
| 48 | Isabelle distribution. | |
| 54508 | 49 | The tutorial by Nipkow, Paulson and Wenzel~\cite{LNCS2283} (in its updated version that comes with the Isabelle distribution) is still recommended for the wealth of examples and material, but its proof style is outdated. In particular it does not cover the structured proof language Isar.
 | 
| 47546 | 50 | |
| 52782 | 51 | %This introduction to Isabelle has grown out of many years of teaching | 
| 52 | %Isabelle courses. | |
| 53 | ||
| 52814 | 54 | \ifsem | 
| 55 | \subsection*{Getting Started with Isabelle}
 | |
| 56 | ||
| 57 | If you have not done so already, download and install Isabelle | |
| 68649 | 58 | from \url{https://isabelle.in.tum.de}. You can start it by clicking
 | 
| 52814 | 59 | on the application icon. This will launch Isabelle's | 
| 62221 | 60 | user interface based on the text editor \concept{jEdit}. Below you see
 | 
| 62222 | 61 | a typical example snapshot of a session. At this point we merely explain | 
| 52814 | 62 | the layout of the window, not its contents. | 
| 63 | ||
| 64 | \begin{center}
 | |
| 65 | \includegraphics[width=\textwidth]{jedit.png}
 | |
| 66 | \end{center}
 | |
| 58504 | 67 | The upper part of the window shows the input typed by the user, i.e., the | 
| 52814 | 68 | gradually growing Isabelle text of definitions, theorems, proofs, etc. The | 
| 69 | interface processes the user input automatically while it is typed, just like | |
| 70 | modern Java IDEs. Isabelle's response to the user input is shown in the | |
| 71 | lower part of the window. You can examine the response to any input phrase | |
| 72 | by clicking on that phrase or by hovering over underlined text. | |
| 73 | ||
| 62223 | 74 | \begin{warn}\label{proof-state}
 | 
| 62224 | 75 | Part I frequently refers to the proof state. | 
| 64852 
f3504bc69ea3
fix problems because of "surj" input abbreviation; tuned
 nipkow parents: 
62224diff
changeset | 76 | You can see the proof state if you press the ``State'' button. | 
| 
f3504bc69ea3
fix problems because of "surj" input abbreviation; tuned
 nipkow parents: 
62224diff
changeset | 77 | If you want to see the proof state combined with other system output, press ``Output'' and tick the ``Proof state'' box. | 
| 62222 | 78 | \end{warn}
 | 
| 79 | ||
| 80 | This should suffice to get started with the jEdit interface. | |
| 52814 | 81 | Now you need to learn what to type into it. | 
| 82 | \else | |
| 52782 | 83 | If you want to apply what you have learned about Isabelle we recommend you | 
| 59187 | 84 | download and read the book | 
| 57847 | 85 | \href{http://www.concrete-semantics.org}{Concrete
 | 
| 52782 | 86 | Semantics}~\cite{ConcreteSemantics}, a guided tour of the wonderful world of
 | 
| 87 | programming langage semantics formalised in Isabelle. In fact, | |
| 88 | \emph{Programming and Proving in Isabelle/HOL} constitutes part~I of
 | |
| 57847 | 89 | \href{http://www.concrete-semantics.org}{Concrete Semantics}.  The web
 | 
| 90 | pages for \href{http://www.concrete-semantics.org}{Concrete Semantics}
 | |
| 57819 | 91 | also provide a set of \LaTeX-based slides and Isabelle demo files | 
| 92 | for teaching \emph{Programming and Proving in Isabelle/HOL}.
 | |
| 52782 | 93 | \fi | 
| 47546 | 94 | |
| 52814 | 95 | \ifsem\else | 
| 47546 | 96 | \paragraph{Acknowledgements}
 | 
| 54467 | 97 | I wish to thank the following people for their comments on this document: | 
| 57819 | 98 | Florian Haftmann, Peter Johnson, Ren\'{e} Thiemann, Sean Seefried,
 | 
| 99 | Christian Sternagel and Carl Witty. | |
| 52814 | 100 | \fi |