author | blanchet |
Mon, 04 Aug 2014 12:28:42 +0200 | |
changeset 57776 | 1111a9a328fe |
parent 48985 | 5386df44a037 |
child 73723 | 1bbbaae6b5e3 |
permissions | -rw-r--r-- |
7827 | 1 |
\documentclass[12pt,a4paper]{article} |
48941
fbf60999dc31
more standard document preparation within session context;
wenzelm
parents:
42637
diff
changeset
|
2 |
\usepackage{graphicx,iman,extra,ttbox,proof,pdfsetup} |
2656 | 3 |
|
105 | 4 |
%% run bibtex intro to prepare bibliography |
5 |
%% run ../sedindex intro to prepare index file |
|
6 |
%prth *(\(.*\)); \1; |
|
7 |
%{\\out \(.*\)} {\\out val it = "\1" : thm} |
|
8 |
||
30118 | 9 |
\title{\includegraphics[scale=0.5]{isabelle} \\[4ex] Old Introduction to Isabelle} |
105 | 10 |
\author{{\em Lawrence C. Paulson}\\ |
3127 | 11 |
Computer Laboratory \\ University of Cambridge \\ |
12 |
\texttt{lcp@cl.cam.ac.uk}\\[3ex] |
|
13 |
With Contributions by Tobias Nipkow and Markus Wenzel |
|
105 | 14 |
} |
15 |
\makeindex |
|
16 |
||
17 |
\underscoreoff |
|
18 |
||
19 |
\setcounter{secnumdepth}{2} \setcounter{tocdepth}{2} |
|
20 |
||
21 |
\sloppy |
|
22 |
\binperiod %%%treat . like a binary operator |
|
23 |
||
24 |
\newcommand\qeq{\stackrel{?}{\equiv}} %for disagreement pairs in unification |
|
25 |
\newcommand{\nand}{\mathbin{\lnot\&}} |
|
26 |
\newcommand{\xor}{\mathbin{\#}} |
|
27 |
||
28 |
\pagenumbering{roman} |
|
29 |
\begin{document} |
|
30 |
\pagestyle{empty} |
|
31 |
\begin{titlepage} |
|
32 |
\maketitle |
|
14148 | 33 |
\emph{Note}: this document is part of the earlier Isabelle documentation, |
34 |
which is largely superseded by the Isabelle/HOL |
|
35 |
\emph{Tutorial}~\cite{isa-tutorial}. It describes the old-style theory |
|
36 |
syntax and shows how to conduct proofs using the |
|
37 |
ML top level. This style of interaction is largely obsolete: |
|
38 |
most Isabelle proofs are now written using the Isar |
|
39 |
language and the Proof General interface. However, this paper contains valuable |
|
40 |
information that is not available elsewhere. Its examples are based |
|
41 |
on first-order logic rather than higher-order logic. |
|
42 |
||
105 | 43 |
\thispagestyle{empty} |
44 |
\vfill |
|
45 |
{\small Copyright \copyright{} \number\year{} by Lawrence C. Paulson} |
|
46 |
\end{titlepage} |
|
47 |
||
48 |
\pagestyle{headings} |
|
49 |
\part*{Preface} |
|
1878 | 50 |
\index{Isabelle!overview} \index{Isabelle!object-logics supported} |
51 |
Isabelle~\cite{paulson-natural,paulson-found,paulson700} is a generic theorem |
|
52 |
prover. It has been instantiated to support reasoning in several |
|
53 |
object-logics: |
|
105 | 54 |
\begin{itemize} |
55 |
\item first-order logic, constructive and classical versions |
|
56 |
\item higher-order logic, similar to that of Gordon's {\sc |
|
348 | 57 |
hol}~\cite{mgordon-hol} |
105 | 58 |
\item Zermelo-Fraenkel set theory~\cite{suppes72} |
59 |
\item an extensional version of Martin-L\"of's Type Theory~\cite{nordstrom90} |
|
60 |
\item the classical first-order sequent calculus, {\sc lk} |
|
61 |
\item the modal logics $T$, $S4$, and $S43$ |
|
62 |
\item the Logic for Computable Functions~\cite{paulson87} |
|
63 |
\end{itemize} |
|
64 |
A logic's syntax and inference rules are specified declaratively; this |
|
65 |
allows single-step proof construction. Isabelle provides control |
|
66 |
structures for expressing search procedures. Isabelle also provides |
|
67 |
several generic tools, such as simplifiers and classical theorem provers, |
|
68 |
which can be applied to object-logics. |
|
69 |
||
14148 | 70 |
Isabelle is a large system, but beginners can get by with a small |
71 |
repertoire of commands and a basic knowledge of how Isabelle works. |
|
72 |
The Isabelle/HOL \emph{Tutorial}~\cite{isa-tutorial} describes how to get started. Advanced Isabelle users will benefit from some |
|
73 |
knowledge of Standard~\ML{}, because Isabelle is written in \ML{}; |
|
105 | 74 |
\index{ML} |
14148 | 75 |
if you are prepared to writing \ML{} |
76 |
code, you can get Isabelle to do almost anything. My book |
|
6592 | 77 |
on~\ML{}~\cite{paulson-ml2} covers much material connected with Isabelle, |
105 | 78 |
including a simple theorem prover. Users must be familiar with logic as |
79 |
used in computer science; there are many good |
|
80 |
texts~\cite{galton90,reeves90}. |
|
81 |
||
82 |
\index{LCF} |
|
348 | 83 |
{\sc lcf}, developed by Robin Milner and colleagues~\cite{mgordon79}, is an |
105 | 84 |
ancestor of {\sc hol}, Nuprl, and several other systems. Isabelle borrows |
85 |
ideas from {\sc lcf}: formulae are~\ML{} values; theorems belong to an |
|
86 |
abstract type; tactics and tacticals support backward proof. But {\sc lcf} |
|
87 |
represents object-level rules by functions, while Isabelle represents them |
|
88 |
by terms. You may find my other writings~\cite{paulson87,paulson-handbook} |
|
89 |
helpful in understanding the relationship between {\sc lcf} and Isabelle. |
|
90 |
||
91 |
\index{Isabelle!release history} Isabelle was first distributed in 1986. |
|
92 |
The 1987 version introduced a higher-order meta-logic with an improved |
|
93 |
treatment of quantifiers. The 1988 version added limited polymorphism and |
|
94 |
support for natural deduction. The 1989 version included a parser and |
|
95 |
pretty printer generator. The 1992 version introduced type classes, to |
|
14148 | 96 |
support many-sorted and higher-order logics. The 1994 version introduced |
97 |
greater support for theories. The most important recent change is the |
|
98 |
introduction of the Isar proof language, thanks to Markus Wenzel. |
|
99 |
Isabelle is still under |
|
105 | 100 |
development and will continue to change. |
101 |
||
102 |
\subsubsection*{Overview} |
|
296 | 103 |
This manual consists of three parts. Part~I discusses the Isabelle's |
104 |
foundations. Part~II, presents simple on-line sessions, starting with |
|
105 |
forward proof. It also covers basic tactics and tacticals, and some |
|
106 |
commands for invoking them. Part~III contains further examples for users |
|
107 |
with a bit of experience. It explains how to derive rules define theories, |
|
108 |
and concludes with an extended example: a Prolog interpreter. |
|
105 | 109 |
|
110 |
Isabelle's Reference Manual and Object-Logics manual contain more details. |
|
111 |
They assume familiarity with the concepts presented here. |
|
112 |
||
113 |
||
114 |
\subsubsection*{Acknowledgements} |
|
311 | 115 |
Tobias Nipkow contributed most of the section on defining theories. |
14148 | 116 |
Stefan Berghofer, Sara Kalvala and Viktor Kuncak suggested improvements. |
105 | 117 |
|
8979 | 118 |
Tobias Nipkow has made immense contributions to Isabelle, including the parser |
119 |
generator, type classes, and the simplifier. Carsten Clasohm and Markus |
|
120 |
Wenzel made major contributions; Sonia Mahjoub and Karin Nimmermann also |
|
121 |
helped. Isabelle was developed using Dave Matthews's Standard~{\sc ml} |
|
122 |
compiler, Poly/{\sc ml}. Many people have contributed to Isabelle's standard |
|
123 |
object-logics, including Martin Coen, Philippe de Groote, Philippe No\"el. |
|
124 |
The research has been funded by the EPSRC (grants GR/G53279, GR/H40570, |
|
125 |
GR/K57381, GR/K77051, GR/M75440) and by ESPRIT (projects 3245: Logical |
|
126 |
Frameworks, and 6453: Types), and by the DFG Schwerpunktprogramm |
|
127 |
\emph{Deduktion}. |
|
105 | 128 |
|
129 |
\newpage |
|
130 |
\pagestyle{plain} \tableofcontents |
|
131 |
\newpage |
|
132 |
||
133 |
\newfont{\sanssi}{cmssi12} |
|
134 |
\vspace*{2.5cm} |
|
135 |
\begin{quote} |
|
136 |
\raggedleft |
|
137 |
{\sanssi |
|
138 |
You can only find truth with logic\\ |
|
139 |
if you have already found truth without it.}\\ |
|
140 |
\bigskip |
|
141 |
||
142 |
G.K. Chesterton, {\em The Man who was Orthodox} |
|
143 |
\end{quote} |
|
144 |
||
145 |
\clearfirst \pagestyle{headings} |
|
48970
8be091776e93
prefer \input which actually checks file existence;
wenzelm
parents:
48941
diff
changeset
|
146 |
\input{foundations} |
8be091776e93
prefer \input which actually checks file existence;
wenzelm
parents:
48941
diff
changeset
|
147 |
\input{getting} |
8be091776e93
prefer \input which actually checks file existence;
wenzelm
parents:
48941
diff
changeset
|
148 |
\input{advanced} |
105 | 149 |
|
150 |
\bibliographystyle{plain} \small\raggedright\frenchspacing |
|
48941
fbf60999dc31
more standard document preparation within session context;
wenzelm
parents:
42637
diff
changeset
|
151 |
\bibliography{manual} |
105 | 152 |
|
8828 | 153 |
\printindex |
105 | 154 |
\end{document} |