doc-src/Intro/intro.toc
author lcp
Wed, 10 Nov 1993 05:06:55 +0100
changeset 105 216d6ed87399
child 359 b5a2e9503a7a
permissions -rw-r--r--
Initial revision
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
105
216d6ed87399 Initial revision
lcp
parents:
diff changeset
     1
\contentsline {part}{\uppercase {i}\phspace {1em}Foundations}{1}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
     2
\contentsline {section}{\numberline {1}Formalizing logical syntax in Isabelle}{1}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
     3
\contentsline {subsection}{\numberline {1.1}Simple types and constants}{1}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
     4
\contentsline {subsection}{\numberline {1.2}Polymorphic types and constants}{3}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
     5
\contentsline {subsection}{\numberline {1.3}Higher types and quantifiers}{4}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
     6
\contentsline {section}{\numberline {2}Formalizing logical rules in Isabelle}{5}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
     7
\contentsline {subsection}{\numberline {2.1}Expressing propositional rules}{6}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
     8
\contentsline {subsection}{\numberline {2.2}Quantifier rules and substitution}{7}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
     9
\contentsline {subsection}{\numberline {2.3}Signatures and theories}{8}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    10
\contentsline {section}{\numberline {3}Proof construction in Isabelle}{9}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    11
\contentsline {subsection}{\numberline {3.1}Higher-order unification}{10}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    12
\contentsline {subsection}{\numberline {3.2}Joining rules by resolution}{11}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    13
\contentsline {subsection}{\numberline {3.3}Lifting a rule into a context}{13}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    14
\contentsline {subsubsection}{Lifting over assumptions}{13}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    15
\contentsline {subsubsection}{Lifting over parameters}{13}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    16
\contentsline {section}{\numberline {4}Backward proof by resolution}{14}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    17
\contentsline {subsection}{\numberline {4.1}Refinement by resolution}{15}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    18
\contentsline {subsection}{\numberline {4.2}Proof by assumption}{15}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    19
\contentsline {subsection}{\numberline {4.3}A propositional proof}{16}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    20
\contentsline {subsection}{\numberline {4.4}A quantifier proof}{17}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    21
\contentsline {subsection}{\numberline {4.5}Tactics and tacticals}{17}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    22
\contentsline {section}{\numberline {5}Variations on resolution}{18}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    23
\contentsline {subsection}{\numberline {5.1}Elim-resolution}{18}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    24
\contentsline {subsection}{\numberline {5.2}Destruction rules}{20}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    25
\contentsline {subsection}{\numberline {5.3}Deriving rules by resolution}{20}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    26
\contentsline {part}{\uppercase {ii}\phspace {1em}Getting started with Isabelle}{22}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    27
\contentsline {section}{\numberline {6}Forward proof}{22}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    28
\contentsline {subsection}{\numberline {6.1}Lexical matters}{22}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    29
\contentsline {subsection}{\numberline {6.2}Syntax of types and terms}{23}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    30
\contentsline {subsection}{\numberline {6.3}Basic operations on theorems}{24}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    31
\contentsline {subsection}{\numberline {6.4}Flex-flex equations}{26}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    32
\contentsline {section}{\numberline {7}Backward proof}{27}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    33
\contentsline {subsection}{\numberline {7.1}The basic tactics}{27}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    34
\contentsline {subsection}{\numberline {7.2}Commands for backward proof}{28}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    35
\contentsline {subsection}{\numberline {7.3}A trivial example in propositional logic}{28}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    36
\contentsline {subsection}{\numberline {7.4}Proving a distributive law}{30}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    37
\contentsline {section}{\numberline {8}Quantifier reasoning}{31}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    38
\contentsline {subsection}{\numberline {8.1}Two quantifier proofs, successful and not}{31}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    39
\contentsline {subsubsection}{The successful proof}{31}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    40
\contentsline {subsubsection}{The unsuccessful proof}{32}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    41
\contentsline {subsection}{\numberline {8.2}Nested quantifiers}{33}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    42
\contentsline {subsubsection}{The wrong approach}{33}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    43
\contentsline {subsubsection}{The right approach}{34}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    44
\contentsline {subsubsection}{A one-step proof using tacticals}{35}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    45
\contentsline {subsection}{\numberline {8.3}A realistic quantifier proof}{35}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    46
\contentsline {subsection}{\numberline {8.4}The classical reasoning package}{36}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    47
\contentsline {part}{\uppercase {iii}\phspace {1em}Advanced methods}{38}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    48
\contentsline {section}{\numberline {9}Deriving rules in Isabelle}{38}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    49
\contentsline {subsection}{\numberline {9.1}Deriving a rule using tactics}{38}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    50
\contentsline {subsection}{\numberline {9.2}Definitions and derived rules}{40}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    51
\contentsline {subsubsection}{Deriving the introduction rule}{41}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    52
\contentsline {subsubsection}{Deriving the elimination rule}{42}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    53
\contentsline {section}{\numberline {10}Defining theories}{44}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    54
\contentsline {subsection}{\numberline {10.1}Declaring constants and rules}{45}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    55
\contentsline {subsection}{\numberline {10.2}Declaring type constructors}{46}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    56
\contentsline {subsection}{\numberline {10.3}Infixes and Mixfixes}{47}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    57
\contentsline {subsection}{\numberline {10.4}Overloading}{48}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    58
\contentsline {subsection}{\numberline {10.5}Extending first-order logic with the natural numbers}{50}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    59
\contentsline {subsection}{\numberline {10.6}Declaring the theory to Isabelle}{51}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    60
\contentsline {section}{\numberline {11}Refinement with explicit instantiation}{52}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    61
\contentsline {subsection}{\numberline {11.1}A simple proof by induction}{52}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    62
\contentsline {subsection}{\numberline {11.2}An example of ambiguity in {\ptt resolve_tac}}{53}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    63
\contentsline {subsection}{\numberline {11.3}Proving that addition is associative}{54}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    64
\contentsline {section}{\numberline {12}A {\psc Prolog} interpreter}{55}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    65
\contentsline {subsection}{\numberline {12.1}Simple executions}{56}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    66
\contentsline {subsection}{\numberline {12.2}Backtracking}{57}
216d6ed87399 Initial revision
lcp
parents:
diff changeset
    67
\contentsline {subsection}{\numberline {12.3}Depth-first search}{58}