| 2656 |      1 | \documentstyle[a4,12pt]{article}
 | 
|  |      2 | \makeatletter
 | 
|  |      3 | \input{../proof209.sty}
 | 
|  |      4 | \input{../iman.sty}
 | 
|  |      5 | \input{../extra.sty}
 | 
|  |      6 | \makeatother
 | 
|  |      7 | 
 | 
| 105 |      8 | %% $Id$
 | 
|  |      9 | %% run    bibtex intro         to prepare bibliography
 | 
|  |     10 | %% run    ../sedindex intro    to prepare index file
 | 
|  |     11 | %prth *(\(.*\));          \1;      
 | 
|  |     12 | %{\\out \(.*\)}          {\\out val it = "\1" : thm}
 | 
|  |     13 | 
 | 
|  |     14 | \title{Introduction to Isabelle}   
 | 
|  |     15 | \author{{\em Lawrence C. Paulson}\\
 | 
|  |     16 |         Computer Laboratory \\ University of Cambridge \\[2ex]
 | 
|  |     17 |         {\small{\em Electronic mail\/}: {\tt lcp@cl.cam.ac.uk}}
 | 
|  |     18 | }
 | 
|  |     19 | \makeindex
 | 
|  |     20 | 
 | 
|  |     21 | \underscoreoff
 | 
|  |     22 | 
 | 
|  |     23 | \setcounter{secnumdepth}{2} \setcounter{tocdepth}{2}
 | 
|  |     24 | 
 | 
|  |     25 | \sloppy
 | 
|  |     26 | \binperiod     %%%treat . like a binary operator
 | 
|  |     27 | 
 | 
|  |     28 | \newcommand\qeq{\stackrel{?}{\equiv}}  %for disagreement pairs in unification
 | 
|  |     29 | \newcommand{\nand}{\mathbin{\lnot\&}} 
 | 
|  |     30 | \newcommand{\xor}{\mathbin{\#}}
 | 
|  |     31 | 
 | 
|  |     32 | \pagenumbering{roman} 
 | 
|  |     33 | \begin{document}
 | 
|  |     34 | \pagestyle{empty}
 | 
|  |     35 | \begin{titlepage}
 | 
|  |     36 | \maketitle 
 | 
|  |     37 | \thispagestyle{empty}
 | 
|  |     38 | \vfill
 | 
|  |     39 | {\small Copyright \copyright{} \number\year{} by Lawrence C. Paulson}
 | 
|  |     40 | \end{titlepage}
 | 
|  |     41 | 
 | 
|  |     42 | \pagestyle{headings}
 | 
|  |     43 | \part*{Preface}
 | 
| 1878 |     44 | \index{Isabelle!overview} \index{Isabelle!object-logics supported}
 | 
|  |     45 | Isabelle~\cite{paulson-natural,paulson-found,paulson700} is a generic theorem
 | 
|  |     46 | prover.  It has been instantiated to support reasoning in several
 | 
|  |     47 | object-logics:
 | 
| 105 |     48 | \begin{itemize}
 | 
|  |     49 | \item first-order logic, constructive and classical versions
 | 
|  |     50 | \item higher-order logic, similar to that of Gordon's {\sc
 | 
| 348 |     51 | hol}~\cite{mgordon-hol}
 | 
| 105 |     52 | \item Zermelo-Fraenkel set theory~\cite{suppes72}
 | 
|  |     53 | \item an extensional version of Martin-L\"of's Type Theory~\cite{nordstrom90}
 | 
|  |     54 | \item the classical first-order sequent calculus, {\sc lk}
 | 
|  |     55 | \item the modal logics $T$, $S4$, and $S43$
 | 
|  |     56 | \item the Logic for Computable Functions~\cite{paulson87}
 | 
|  |     57 | \end{itemize}
 | 
|  |     58 | A logic's syntax and inference rules are specified declaratively; this
 | 
|  |     59 | allows single-step proof construction.  Isabelle provides control
 | 
|  |     60 | structures for expressing search procedures.  Isabelle also provides
 | 
|  |     61 | several generic tools, such as simplifiers and classical theorem provers,
 | 
|  |     62 | which can be applied to object-logics.
 | 
|  |     63 | 
 | 
|  |     64 | \index{ML}
 | 
|  |     65 | Isabelle is a large system, but beginners can get by with a small
 | 
|  |     66 | repertoire of commands and a basic knowledge of how Isabelle works.  Some
 | 
|  |     67 | knowledge of Standard~\ML{} is essential, because \ML{} is Isabelle's user
 | 
|  |     68 | interface.  Advanced Isabelle theorem proving can involve writing \ML{}
 | 
|  |     69 | code, possibly with Isabelle's sources at hand.  My book
 | 
|  |     70 | on~\ML{}~\cite{paulson91} covers much material connected with Isabelle,
 | 
|  |     71 | including a simple theorem prover.  Users must be familiar with logic as
 | 
|  |     72 | used in computer science; there are many good
 | 
|  |     73 | texts~\cite{galton90,reeves90}.
 | 
|  |     74 | 
 | 
|  |     75 | \index{LCF}
 | 
| 348 |     76 | {\sc lcf}, developed by Robin Milner and colleagues~\cite{mgordon79}, is an
 | 
| 105 |     77 | ancestor of {\sc hol}, Nuprl, and several other systems.  Isabelle borrows
 | 
|  |     78 | ideas from {\sc lcf}: formulae are~\ML{} values; theorems belong to an
 | 
|  |     79 | abstract type; tactics and tacticals support backward proof.  But {\sc lcf}
 | 
|  |     80 | represents object-level rules by functions, while Isabelle represents them
 | 
|  |     81 | by terms.  You may find my other writings~\cite{paulson87,paulson-handbook}
 | 
|  |     82 | helpful in understanding the relationship between {\sc lcf} and Isabelle.
 | 
|  |     83 | 
 | 
|  |     84 | \index{Isabelle!release history} Isabelle was first distributed in 1986.
 | 
|  |     85 | The 1987 version introduced a higher-order meta-logic with an improved
 | 
|  |     86 | treatment of quantifiers.  The 1988 version added limited polymorphism and
 | 
|  |     87 | support for natural deduction.  The 1989 version included a parser and
 | 
|  |     88 | pretty printer generator.  The 1992 version introduced type classes, to
 | 
|  |     89 | support many-sorted and higher-order logics.  The current version provides
 | 
|  |     90 | greater support for theories and is much faster.  Isabelle is still under
 | 
|  |     91 | development and will continue to change.
 | 
|  |     92 | 
 | 
|  |     93 | \subsubsection*{Overview} 
 | 
| 296 |     94 | This manual consists of three parts.  Part~I discusses the Isabelle's
 | 
|  |     95 | foundations.  Part~II, presents simple on-line sessions, starting with
 | 
|  |     96 | forward proof.  It also covers basic tactics and tacticals, and some
 | 
|  |     97 | commands for invoking them.  Part~III contains further examples for users
 | 
|  |     98 | with a bit of experience.  It explains how to derive rules define theories,
 | 
|  |     99 | and concludes with an extended example: a Prolog interpreter.
 | 
| 105 |    100 | 
 | 
|  |    101 | Isabelle's Reference Manual and Object-Logics manual contain more details.
 | 
|  |    102 | They assume familiarity with the concepts presented here.
 | 
|  |    103 | 
 | 
|  |    104 | 
 | 
|  |    105 | \subsubsection*{Acknowledgements} 
 | 
| 311 |    106 | Tobias Nipkow contributed most of the section on defining theories.
 | 
| 1866 |    107 | Stefan Berghofer, Sara Kalvala and Markus Wenzel suggested improvements.
 | 
| 105 |    108 | 
 | 
|  |    109 | Tobias Nipkow has made immense contributions to Isabelle, including the
 | 
| 184 |    110 | parser generator, type classes, and the simplifier.  Carsten Clasohm and
 | 
|  |    111 | Markus Wenzel made major contributions; Sonia Mahjoub and Karin Nimmermann
 | 
|  |    112 | also helped.  Isabelle was developed using Dave Matthews's Standard~{\sc
 | 
|  |    113 |   ml} compiler, Poly/{\sc ml}.  Many people have contributed to Isabelle's
 | 
|  |    114 | standard object-logics, including Martin Coen, Philippe de Groote, Philippe
 | 
|  |    115 | No\"el.  The research has been funded by the SERC (grants GR/G53279,
 | 
|  |    116 | GR/H40570) and by ESPRIT (projects 3245: Logical Frameworks, and 6453:
 | 
|  |    117 | Types).
 | 
| 105 |    118 | 
 | 
|  |    119 | \newpage
 | 
|  |    120 | \pagestyle{plain} \tableofcontents 
 | 
|  |    121 | \newpage
 | 
|  |    122 | 
 | 
|  |    123 | \newfont{\sanssi}{cmssi12}
 | 
|  |    124 | \vspace*{2.5cm}
 | 
|  |    125 | \begin{quote}
 | 
|  |    126 | \raggedleft
 | 
|  |    127 | {\sanssi
 | 
|  |    128 | You can only find truth with logic\\
 | 
|  |    129 | if you have already found truth without it.}\\
 | 
|  |    130 | \bigskip
 | 
|  |    131 | 
 | 
|  |    132 | G.K. Chesterton, {\em The Man who was Orthodox}
 | 
|  |    133 | \end{quote}
 | 
|  |    134 | 
 | 
|  |    135 | \clearfirst  \pagestyle{headings}
 | 
|  |    136 | \include{foundations}
 | 
|  |    137 | \include{getting}
 | 
|  |    138 | \include{advanced}
 | 
|  |    139 | 
 | 
|  |    140 | \bibliographystyle{plain} \small\raggedright\frenchspacing
 | 
| 873 |    141 | \bibliography{string,atp,funprog,general,logicprog,isabelle,theory,crossref}
 | 
| 105 |    142 | 
 | 
|  |    143 | \input{intro.ind}
 | 
|  |    144 | \end{document}
 |