doc-src/Ref/simplifier.tex
author wenzelm
Sun, 30 Jul 2000 12:50:33 +0200
changeset 9462 3ac87f80186d
parent 9445 6c93b1eb11f8
child 9695 ec7d7f877712
permissions -rw-r--r--
ThmDeps.enable;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
     1
%% $Id$
3950
e9d5bcae8351 \label{simp-chap} -> chap:simplification
nipkow
parents: 3485
diff changeset
     2
\chapter{Simplification}
e9d5bcae8351 \label{simp-chap} -> chap:simplification
nipkow
parents: 3485
diff changeset
     3
\label{chap:simplification}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
     4
\index{simplification|(}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
     5
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
     6
This chapter describes Isabelle's generic simplification package.  It
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
     7
performs conditional and unconditional rewriting and uses contextual
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
     8
information (`local assumptions').  It provides several general hooks,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
     9
which can provide automatic case splits during rewriting, for example.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    10
The simplifier is already set up for many of Isabelle's logics: \FOL,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    11
\ZF, \HOL, \HOLCF.
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    12
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    13
The first section is a quick introduction to the simplifier that
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    14
should be sufficient to get started.  The later sections explain more
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    15
advanced features.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    16
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    17
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    18
\section{Simplification for dummies}
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    19
\label{sec:simp-for-dummies}
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    20
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    21
Basic use of the simplifier is particularly easy because each theory
4557
wenzelm
parents: 4395
diff changeset
    22
is equipped with sensible default information controlling the rewrite
wenzelm
parents: 4395
diff changeset
    23
process --- namely the implicit {\em current
wenzelm
parents: 4395
diff changeset
    24
  simpset}\index{simpset!current}.  A suite of simple commands is
wenzelm
parents: 4395
diff changeset
    25
provided that refer to the implicit simpset of the current theory
wenzelm
parents: 4395
diff changeset
    26
context.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    27
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    28
\begin{warn}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    29
  Make sure that you are working within the correct theory context.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    30
  Executing proofs interactively, or loading them from ML files
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    31
  without associated theories may require setting the current theory
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    32
  manually via the \ttindex{context} command.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    33
\end{warn}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    34
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    35
\subsection{Simplification tactics} \label{sec:simp-for-dummies-tacs}
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    36
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    37
Simp_tac          : int -> tactic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    38
Asm_simp_tac      : int -> tactic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    39
Full_simp_tac     : int -> tactic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    40
Asm_full_simp_tac : int -> tactic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    41
trace_simp        : bool ref \hfill{\bf initially false}
7920
1ee85d4205b2 new flag debug_simp
wenzelm
parents: 7620
diff changeset
    42
debug_simp        : bool ref \hfill{\bf initially false}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    43
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    44
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    45
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    46
\item[\ttindexbold{Simp_tac} $i$] simplifies subgoal~$i$ using the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    47
  current simpset.  It may solve the subgoal completely if it has
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    48
  become trivial, using the simpset's solver tactic.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    49
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    50
\item[\ttindexbold{Asm_simp_tac}]\index{assumptions!in simplification}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    51
  is like \verb$Simp_tac$, but extracts additional rewrite rules from
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    52
  the local assumptions.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    53
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    54
\item[\ttindexbold{Full_simp_tac}] is like \verb$Simp_tac$, but also
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    55
  simplifies the assumptions (without using the assumptions to
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    56
  simplify each other or the actual goal).
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    57
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    58
\item[\ttindexbold{Asm_full_simp_tac}] is like \verb$Asm_simp_tac$,
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
    59
  but also simplifies the assumptions. In particular, assumptions can
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
    60
  simplify each other.
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
    61
\footnote{\texttt{Asm_full_simp_tac} used to process the assumptions from
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
    62
  left to right. For backwards compatibilty reasons only there is now
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
    63
  \texttt{Asm_lr_simp_tac} that behaves like the old \texttt{Asm_full_simp_tac}.}
7920
1ee85d4205b2 new flag debug_simp
wenzelm
parents: 7620
diff changeset
    64
\item[set \ttindexbold{trace_simp};] makes the simplifier output internal
1ee85d4205b2 new flag debug_simp
wenzelm
parents: 7620
diff changeset
    65
  operations.  This includes rewrite steps, but also bookkeeping like
1ee85d4205b2 new flag debug_simp
wenzelm
parents: 7620
diff changeset
    66
  modifications of the simpset.
1ee85d4205b2 new flag debug_simp
wenzelm
parents: 7620
diff changeset
    67
\item[set \ttindexbold{debug_simp};] makes the simplifier output some extra
1ee85d4205b2 new flag debug_simp
wenzelm
parents: 7620
diff changeset
    68
  information about internal operations.  This includes any attempted
1ee85d4205b2 new flag debug_simp
wenzelm
parents: 7620
diff changeset
    69
  invocation of simplification procedures.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    70
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    71
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    72
\medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    73
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    74
As an example, consider the theory of arithmetic in \HOL.  The (rather
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    75
trivial) goal $0 + (x + 0) = x + 0 + 0$ can be solved by a single call
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    76
of \texttt{Simp_tac} as follows:
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    77
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    78
context Arith.thy;
5205
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
    79
Goal "0 + (x + 0) = x + 0 + 0";
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    80
{\out  1. 0 + (x + 0) = x + 0 + 0}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    81
by (Simp_tac 1);
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    82
{\out Level 1}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    83
{\out 0 + (x + 0) = x + 0 + 0}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    84
{\out No subgoals!}
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    85
\end{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    86
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    87
The simplifier uses the current simpset of \texttt{Arith.thy}, which
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    88
contains suitable theorems like $\Var{n}+0 = \Var{n}$ and $0+\Var{n} =
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    89
\Var{n}$.
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    90
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    91
\medskip In many cases, assumptions of a subgoal are also needed in
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    92
the simplification process.  For example, \texttt{x = 0 ==> x + x = 0}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
    93
is solved by \texttt{Asm_simp_tac} as follows:
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    94
\begin{ttbox}
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    95
{\out  1. x = 0 ==> x + x = 0}
2479
57109c1a653d Updated account of implicit simpsets and clasets
paulson
parents: 2020
diff changeset
    96
by (Asm_simp_tac 1);
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    97
\end{ttbox}
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
    98
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
    99
\medskip \texttt{Asm_full_simp_tac} is the most powerful of this quartet
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   100
of tactics but may also loop where some of the others terminate.  For
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   101
example,
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   102
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   103
{\out  1. ALL x. f x = g (f (g x)) ==> f 0 = f 0 + 0}
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   104
\end{ttbox}
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
   105
is solved by \texttt{Simp_tac}, but \texttt{Asm_simp_tac} and {\tt
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   106
  Asm_simp_tac} loop because the rewrite rule $f\,\Var{x} =
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   107
g\,(f\,(g\,\Var{x}))$ extracted from the assumption does not
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   108
terminate.  Isabelle notices certain simple forms of nontermination,
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   109
but not this one. Because assumptions may simplify each other, there can be
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   110
very subtle cases of nontermination.
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   111
 
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   112
\begin{warn}
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   113
  \verb$Asm_full_simp_tac$ may miss opportunities to simplify an assumption
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   114
  $A@i$ using an assumption $A@j$ in case $A@j$ is to the right of $A@i$.
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   115
  For example, given the subgoal
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   116
\begin{ttbox}
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   117
{\out [| \dots f a \dots; P a; ALL x. P x --> f x = g x |] ==> \dots}
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   118
\end{ttbox}
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   119
\verb$Asm_full_simp_tac$ will not simplify the \texttt{f a} on the left.
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   120
This problem can be overcome by reordering assumptions (see
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   121
\S\ref{sec:reordering-asms}). Future versions of \verb$Asm_full_simp_tac$
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   122
will not suffer from this deficiency.
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   123
\end{warn}
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   124
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   125
\medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   126
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   127
Using the simplifier effectively may take a bit of experimentation.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   128
Set the \verb$trace_simp$\index{tracing!of simplification} flag to get
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   129
a better idea of what is going on.  The resulting output can be
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   130
enormous, especially since invocations of the simplifier are often
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   131
nested (e.g.\ when solving conditions of rewrite rules).
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   132
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   133
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   134
\subsection{Modifying the current simpset}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   135
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   136
Addsimps    : thm list -> unit
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   137
Delsimps    : thm list -> unit
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   138
Addsimprocs : simproc list -> unit
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   139
Delsimprocs : simproc list -> unit
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   140
Addcongs    : thm list -> unit
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   141
Delcongs    : thm list -> unit
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   142
Addsplits   : thm list -> unit
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   143
Delsplits   : thm list -> unit
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   144
\end{ttbox}
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   145
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   146
Depending on the theory context, the \texttt{Add} and \texttt{Del}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   147
functions manipulate basic components of the associated current
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   148
simpset.  Internally, all rewrite rules have to be expressed as
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   149
(conditional) meta-equalities.  This form is derived automatically
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   150
from object-level equations that are supplied by the user.  Another
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   151
source of rewrite rules are \emph{simplification procedures}, that is
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   152
\ML\ functions that produce suitable theorems on demand, depending on
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   153
the current redex.  Congruences are a more advanced feature; see
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   154
\S\ref{sec:simp-congs}.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   155
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   156
\begin{ttdescription}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   157
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   158
\item[\ttindexbold{Addsimps} $thms$;] adds rewrite rules derived from
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   159
  $thms$ to the current simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   160
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   161
\item[\ttindexbold{Delsimps} $thms$;] deletes rewrite rules derived
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   162
  from $thms$ from the current simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   163
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   164
\item[\ttindexbold{Addsimprocs} $procs$;] adds simplification
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   165
  procedures $procs$ to the current simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   166
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   167
\item[\ttindexbold{Delsimprocs} $procs$;] deletes simplification
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   168
  procedures $procs$ from the current simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   169
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   170
\item[\ttindexbold{Addcongs} $thms$;] adds congruence rules to the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   171
  current simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   172
  
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   173
\item[\ttindexbold{Delcongs} $thms$;] deletes congruence rules from the
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   174
  current simpset.
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   175
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   176
\item[\ttindexbold{Addsplits} $thms$;] adds splitting rules to the
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   177
  current simpset.
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   178
  
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   179
\item[\ttindexbold{Delsplits} $thms$;] deletes splitting rules from the
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   180
  current simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   181
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   182
\end{ttdescription}
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   183
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   184
When a new theory is built, its implicit simpset is initialized by the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   185
union of the respective simpsets of its parent theories.  In addition,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   186
certain theory definition constructs (e.g.\ \ttindex{datatype} and
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   187
\ttindex{primrec} in \HOL) implicitly augment the current simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   188
Ordinary definitions are not added automatically!
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   189
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   190
It is up the user to manipulate the current simpset further by
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   191
explicitly adding or deleting theorems and simplification procedures.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   192
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   193
\medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   194
5205
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   195
Good simpsets are hard to design.  Rules that obviously simplify,
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   196
like $\Var{n}+0 = \Var{n}$, should be added to the current simpset right after
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   197
they have been proved.  More specific ones (such as distributive laws, which
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   198
duplicate subterms) should be added only for specific proofs and deleted
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   199
afterwards.  Conversely, sometimes a rule needs
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   200
to be removed for a certain proof and restored afterwards.  The need of
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   201
frequent additions or deletions may indicate a badly designed
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   202
simpset.
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   203
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   204
\begin{warn}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   205
  The union of the parent simpsets (as described above) is not always
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   206
  a good starting point for the new theory.  If some ancestors have
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   207
  deleted simplification rules because they are no longer wanted,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   208
  while others have left those rules in, then the union will contain
5205
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   209
  the unwanted rules.  After this union is formed, changes to 
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   210
  a parent simpset have no effect on the child simpset.
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   211
\end{warn}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   212
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   213
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   214
\section{Simplification sets}\index{simplification sets} 
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   215
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   216
The simplifier is controlled by information contained in {\bf
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   217
  simpsets}.  These consist of several components, including rewrite
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   218
rules, simplification procedures, congruence rules, and the subgoaler,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   219
solver and looper tactics.  The simplifier should be set up with
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   220
sensible defaults so that most simplifier calls specify only rewrite
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   221
rules or simplification procedures.  Experienced users can exploit the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   222
other components to streamline proofs in more sophisticated manners.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   223
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   224
\subsection{Inspecting simpsets}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   225
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   226
print_ss : simpset -> unit
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   227
rep_ss   : simpset -> \{mss        : meta_simpset, 
4664
05d33fc7aa08 added minimal description of rep_ss
oheimb
parents: 4597
diff changeset
   228
                       subgoal_tac: simpset  -> int -> tactic,
7620
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   229
                       loop_tacs  : (string * (int -> tactic))list,
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   230
                       finish_tac : solver list,
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   231
                unsafe_finish_tac : solver list\}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   232
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   233
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   234
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   235
\item[\ttindexbold{print_ss} $ss$;] displays the printable contents of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   236
  simpset $ss$.  This includes the rewrite rules and congruences in
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   237
  their internal form expressed as meta-equalities.  The names of the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   238
  simplification procedures and the patterns they are invoked on are
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   239
  also shown.  The other parts, functions and tactics, are
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   240
  non-printable.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   241
4664
05d33fc7aa08 added minimal description of rep_ss
oheimb
parents: 4597
diff changeset
   242
\item[\ttindexbold{rep_ss} $ss$;] decomposes $ss$ as a record of its internal 
05d33fc7aa08 added minimal description of rep_ss
oheimb
parents: 4597
diff changeset
   243
  components, namely the meta_simpset, the subgoaler, the loop, and the safe
05d33fc7aa08 added minimal description of rep_ss
oheimb
parents: 4597
diff changeset
   244
  and unsafe solvers.
05d33fc7aa08 added minimal description of rep_ss
oheimb
parents: 4597
diff changeset
   245
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   246
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   247
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   248
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   249
\subsection{Building simpsets}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   250
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   251
empty_ss : simpset
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   252
merge_ss : simpset * simpset -> simpset
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   253
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   254
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   255
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   256
\item[\ttindexbold{empty_ss}] is the empty simpset.  This is not very
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   257
  useful under normal circumstances because it doesn't contain
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   258
  suitable tactics (subgoaler etc.).  When setting up the simplifier
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   259
  for a particular object-logic, one will typically define a more
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   260
  appropriate ``almost empty'' simpset.  For example, in \HOL\ this is
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   261
  called \ttindexbold{HOL_basic_ss}.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   262
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   263
\item[\ttindexbold{merge_ss} ($ss@1$, $ss@2$)] merges simpsets $ss@1$
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   264
  and $ss@2$ by building the union of their respective rewrite rules,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   265
  simplification procedures and congruences.  The other components
4557
wenzelm
parents: 4395
diff changeset
   266
  (tactics etc.) cannot be merged, though; they are taken from either
wenzelm
parents: 4395
diff changeset
   267
  simpset\footnote{Actually from $ss@1$, but it would unwise to count
wenzelm
parents: 4395
diff changeset
   268
    on that.}.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   269
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   270
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   271
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   272
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   273
\subsection{Accessing the current simpset}
5575
9ea449586464 improved indentation
oheimb
parents: 5574
diff changeset
   274
\label{sec:access-current-simpset}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   275
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   276
\begin{ttbox}
5575
9ea449586464 improved indentation
oheimb
parents: 5574
diff changeset
   277
simpset        : unit   -> simpset
9ea449586464 improved indentation
oheimb
parents: 5574
diff changeset
   278
simpset_ref    : unit   -> simpset ref
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   279
simpset_of     : theory -> simpset
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   280
simpset_ref_of : theory -> simpset ref
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   281
print_simpset  : theory -> unit
5575
9ea449586464 improved indentation
oheimb
parents: 5574
diff changeset
   282
SIMPSET        :(simpset ->       tactic) ->       tactic
9ea449586464 improved indentation
oheimb
parents: 5574
diff changeset
   283
SIMPSET'       :(simpset -> 'a -> tactic) -> 'a -> tactic
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   284
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   285
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   286
Each theory contains a current simpset\index{simpset!current} stored
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   287
within a private ML reference variable.  This can be retrieved and
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   288
modified as follows.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   289
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   290
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   291
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   292
\item[\ttindexbold{simpset}();] retrieves the simpset value from the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   293
  current theory context.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   294
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   295
\item[\ttindexbold{simpset_ref}();] retrieves the simpset reference
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   296
  variable from the current theory context.  This can be assigned to
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   297
  by using \texttt{:=} in ML.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   298
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   299
\item[\ttindexbold{simpset_of} $thy$;] retrieves the simpset value
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   300
  from theory $thy$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   301
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   302
\item[\ttindexbold{simpset_ref_of} $thy$;] retrieves the simpset
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   303
  reference variable from theory $thy$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   304
5575
9ea449586464 improved indentation
oheimb
parents: 5574
diff changeset
   305
\item[\ttindexbold{print_simpset} $thy$;] prints the current simpset
9ea449586464 improved indentation
oheimb
parents: 5574
diff changeset
   306
  of theory $thy$ in the same way as \texttt{print_ss}.
9ea449586464 improved indentation
oheimb
parents: 5574
diff changeset
   307
5574
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   308
\item[\ttindexbold{SIMPSET} $tacf$, \ttindexbold{SIMPSET'} $tacf'$]
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   309
  are tacticals that make a tactic depend on the implicit current
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   310
  simpset of the theory associated with the proof state they are
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   311
  applied on.
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   312
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   313
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   314
5574
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   315
\begin{warn}
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   316
  There is a small difference between \texttt{(SIMPSET'~$tacf$)} and
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   317
  \texttt{($tacf\,$(simpset()))}.  For example \texttt{(SIMPSET'
5574
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   318
    simp_tac)} would depend on the theory of the proof state it is
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   319
  applied to, while \texttt{(simp_tac (simpset()))} implicitly refers
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   320
  to the current theory context.  Both are usually the same in proof
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   321
  scripts, provided that goals are only stated within the current
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   322
  theory.  Robust programs would not count on that, of course.
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   323
\end{warn}
620130d6b8e6 rearranged SIMPSET(');
wenzelm
parents: 5549
diff changeset
   324
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   325
332
01b87a921967 final Springer copy
lcp
parents: 323
diff changeset
   326
\subsection{Rewrite rules}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   327
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   328
addsimps : simpset * thm list -> simpset \hfill{\bf infix 4}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   329
delsimps : simpset * thm list -> simpset \hfill{\bf infix 4}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   330
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   331
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   332
\index{rewrite rules|(} Rewrite rules are theorems expressing some
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   333
form of equality, for example:
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   334
\begin{eqnarray*}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   335
  Suc(\Var{m}) + \Var{n} &=&      \Var{m} + Suc(\Var{n}) \\
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   336
  \Var{P}\conj\Var{P}    &\bimp&  \Var{P} \\
714
015ec0a9563a Updated description of valid lhss.
nipkow
parents: 698
diff changeset
   337
  \Var{A} \un \Var{B} &\equiv& \{x.x\in \Var{A} \disj x\in \Var{B}\}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   338
\end{eqnarray*}
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   339
Conditional rewrites such as $\Var{m}<\Var{n} \Imp \Var{m}/\Var{n} =
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   340
0$ are also permitted; the conditions can be arbitrary formulas.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   341
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   342
Internally, all rewrite rules are translated into meta-equalities,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   343
theorems with conclusion $lhs \equiv rhs$.  Each simpset contains a
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   344
function for extracting equalities from arbitrary theorems.  For
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   345
example, $\lnot(\Var{x}\in \{\})$ could be turned into $\Var{x}\in \{\}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   346
\equiv False$.  This function can be installed using
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   347
\ttindex{setmksimps} but only the definer of a logic should need to do
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   348
this; see \S\ref{sec:setmksimps}.  The function processes theorems
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   349
added by \texttt{addsimps} as well as local assumptions.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   350
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   351
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   352
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   353
\item[$ss$ \ttindexbold{addsimps} $thms$] adds rewrite rules derived
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   354
  from $thms$ to the simpset $ss$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   355
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   356
\item[$ss$ \ttindexbold{delsimps} $thms$] deletes rewrite rules
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   357
  derived from $thms$ from the simpset $ss$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   358
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   359
\end{ttdescription}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   360
332
01b87a921967 final Springer copy
lcp
parents: 323
diff changeset
   361
\begin{warn}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   362
  The simplifier will accept all standard rewrite rules: those where
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   363
  all unknowns are of base type.  Hence ${\Var{i}+(\Var{j}+\Var{k})} =
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   364
  {(\Var{i}+\Var{j})+\Var{k}}$ is OK.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   365
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   366
  It will also deal gracefully with all rules whose left-hand sides
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   367
  are so-called {\em higher-order patterns}~\cite{nipkow-patterns}.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   368
  \indexbold{higher-order pattern}\indexbold{pattern, higher-order}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   369
  These are terms in $\beta$-normal form (this will always be the case
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   370
  unless you have done something strange) where each occurrence of an
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   371
  unknown is of the form $\Var{F}(x@1,\dots,x@n)$, where the $x@i$ are
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   372
  distinct bound variables. Hence $(\forall x.\Var{P}(x) \land
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   373
  \Var{Q}(x)) \bimp (\forall x.\Var{P}(x)) \land (\forall
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   374
  x.\Var{Q}(x))$ is also OK, in both directions.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   375
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   376
  In some rare cases the rewriter will even deal with quite general
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   377
  rules: for example ${\Var{f}(\Var{x})\in range(\Var{f})} = True$
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   378
  rewrites $g(a) \in range(g)$ to $True$, but will fail to match
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   379
  $g(h(b)) \in range(\lambda x.g(h(x)))$.  However, you can replace
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   380
  the offending subterms (in our case $\Var{f}(\Var{x})$, which is not
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   381
  a pattern) by adding new variables and conditions: $\Var{y} =
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   382
  \Var{f}(\Var{x}) \Imp \Var{y}\in range(\Var{f}) = True$ is
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   383
  acceptable as a conditional rewrite rule since conditions can be
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   384
  arbitrary terms.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   385
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   386
  There is basically no restriction on the form of the right-hand
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   387
  sides.  They may not contain extraneous term or type variables,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   388
  though.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   389
\end{warn}
332
01b87a921967 final Springer copy
lcp
parents: 323
diff changeset
   390
\index{rewrite rules|)}
01b87a921967 final Springer copy
lcp
parents: 323
diff changeset
   391
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   392
4947
15fd948d6c69 Small mods.
nipkow
parents: 4889
diff changeset
   393
\subsection{*Simplification procedures}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   394
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   395
addsimprocs : simpset * simproc list -> simpset
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   396
delsimprocs : simpset * simproc list -> simpset
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   397
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   398
4557
wenzelm
parents: 4395
diff changeset
   399
Simplification procedures are {\ML} objects of abstract type
wenzelm
parents: 4395
diff changeset
   400
\texttt{simproc}.  Basically they are just functions that may produce
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   401
\emph{proven} rewrite rules on demand.  They are associated with
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   402
certain patterns that conceptually represent left-hand sides of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   403
equations; these are shown by \texttt{print_ss}.  During its
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   404
operation, the simplifier may offer a simplification procedure the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   405
current redex and ask for a suitable rewrite rule.  Thus rules may be
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   406
specifically fashioned for particular situations, resulting in a more
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   407
powerful mechanism than term rewriting by a fixed set of rules.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   408
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   409
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   410
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   411
  
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
   412
\item[$ss$ \ttindexbold{addsimprocs} $procs$] adds the simplification
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   413
  procedures $procs$ to the current simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   414
  
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
   415
\item[$ss$ \ttindexbold{delsimprocs} $procs$] deletes the simplification
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   416
  procedures $procs$ from the current simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   417
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   418
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   419
4557
wenzelm
parents: 4395
diff changeset
   420
For example, simplification procedures \ttindexbold{nat_cancel} of
wenzelm
parents: 4395
diff changeset
   421
\texttt{HOL/Arith} cancel common summands and constant factors out of
wenzelm
parents: 4395
diff changeset
   422
several relations of sums over natural numbers.
wenzelm
parents: 4395
diff changeset
   423
wenzelm
parents: 4395
diff changeset
   424
Consider the following goal, which after cancelling $a$ on both sides
wenzelm
parents: 4395
diff changeset
   425
contains a factor of $2$.  Simplifying with the simpset of
wenzelm
parents: 4395
diff changeset
   426
\texttt{Arith.thy} will do the cancellation automatically:
wenzelm
parents: 4395
diff changeset
   427
\begin{ttbox}
wenzelm
parents: 4395
diff changeset
   428
{\out 1. x + a + x < y + y + 2 + a + a + a + a + a}
wenzelm
parents: 4395
diff changeset
   429
by (Simp_tac 1);
wenzelm
parents: 4395
diff changeset
   430
{\out 1. x < Suc (a + (a + y))}
wenzelm
parents: 4395
diff changeset
   431
\end{ttbox}
wenzelm
parents: 4395
diff changeset
   432
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   433
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   434
\subsection{*Congruence rules}\index{congruence rules}\label{sec:simp-congs}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   435
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   436
addcongs   : simpset * thm list -> simpset \hfill{\bf infix 4}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   437
delcongs   : simpset * thm list -> simpset \hfill{\bf infix 4}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   438
addeqcongs : simpset * thm list -> simpset \hfill{\bf infix 4}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   439
deleqcongs : simpset * thm list -> simpset \hfill{\bf infix 4}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   440
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   441
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   442
Congruence rules are meta-equalities of the form
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   443
\[ \dots \Imp
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   444
   f(\Var{x@1},\ldots,\Var{x@n}) \equiv f(\Var{y@1},\ldots,\Var{y@n}).
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   445
\]
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   446
This governs the simplification of the arguments of~$f$.  For
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   447
example, some arguments can be simplified under additional assumptions:
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   448
\[ \List{\Var{P@1} \bimp \Var{Q@1};\; \Var{Q@1} \Imp \Var{P@2} \bimp \Var{Q@2}}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   449
   \Imp (\Var{P@1} \imp \Var{P@2}) \equiv (\Var{Q@1} \imp \Var{Q@2})
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   450
\]
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   451
Given this rule, the simplifier assumes $Q@1$ and extracts rewrite
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   452
rules from it when simplifying~$P@2$.  Such local assumptions are
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   453
effective for rewriting formulae such as $x=0\imp y+x=y$.  The local
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   454
assumptions are also provided as theorems to the solver; see
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   455
\S~\ref{sec:simp-solver} below.
698
23734672dc12 updated discussion of congruence rules in first section
lcp
parents: 332
diff changeset
   456
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   457
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   458
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   459
\item[$ss$ \ttindexbold{addcongs} $thms$] adds congruence rules to the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   460
  simpset $ss$.  These are derived from $thms$ in an appropriate way,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   461
  depending on the underlying object-logic.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   462
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   463
\item[$ss$ \ttindexbold{delcongs} $thms$] deletes congruence rules
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   464
  derived from $thms$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   465
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   466
\item[$ss$ \ttindexbold{addeqcongs} $thms$] adds congruence rules in
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   467
  their internal form (conclusions using meta-equality) to simpset
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   468
  $ss$.  This is the basic mechanism that \texttt{addcongs} is built
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   469
  on.  It should be rarely used directly.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   470
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   471
\item[$ss$ \ttindexbold{deleqcongs} $thms$] deletes congruence rules
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   472
  in internal form from simpset $ss$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   473
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   474
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   475
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   476
\medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   477
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   478
Here are some more examples.  The congruence rule for bounded
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   479
quantifiers also supplies contextual information, this time about the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   480
bound variable:
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   481
\begin{eqnarray*}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   482
  &&\List{\Var{A}=\Var{B};\; 
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   483
          \Forall x. x\in \Var{B} \Imp \Var{P}(x) = \Var{Q}(x)} \Imp{} \\
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   484
 &&\qquad\qquad
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   485
    (\forall x\in \Var{A}.\Var{P}(x)) = (\forall x\in \Var{B}.\Var{Q}(x))
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   486
\end{eqnarray*}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   487
The congruence rule for conditional expressions can supply contextual
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   488
information for simplifying the arms:
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   489
\[ \List{\Var{p}=\Var{q};~ \Var{q} \Imp \Var{a}=\Var{c};~
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   490
         \lnot\Var{q} \Imp \Var{b}=\Var{d}} \Imp
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   491
   if(\Var{p},\Var{a},\Var{b}) \equiv if(\Var{q},\Var{c},\Var{d})
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   492
\]
698
23734672dc12 updated discussion of congruence rules in first section
lcp
parents: 332
diff changeset
   493
A congruence rule can also {\em prevent\/} simplification of some arguments.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   494
Here is an alternative congruence rule for conditional expressions:
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   495
\[ \Var{p}=\Var{q} \Imp
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   496
   if(\Var{p},\Var{a},\Var{b}) \equiv if(\Var{q},\Var{a},\Var{b})
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   497
\]
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   498
Only the first argument is simplified; the others remain unchanged.
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   499
This can make simplification much faster, but may require an extra case split
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   500
to prove the goal.  
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   501
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   502
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   503
\subsection{*The subgoaler}\label{sec:simp-subgoaler}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   504
\begin{ttbox}
7990
0a604b2fc2b1 updated;
wenzelm
parents: 7920
diff changeset
   505
setsubgoaler :
0a604b2fc2b1 updated;
wenzelm
parents: 7920
diff changeset
   506
  simpset *  (simpset -> int -> tactic) -> simpset \hfill{\bf infix 4}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   507
prems_of_ss  : simpset -> thm list
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   508
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   509
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   510
The subgoaler is the tactic used to solve subgoals arising out of
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   511
conditional rewrite rules or congruence rules.  The default should be
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   512
simplification itself.  Occasionally this strategy needs to be
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   513
changed.  For example, if the premise of a conditional rule is an
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   514
instance of its conclusion, as in $Suc(\Var{m}) < \Var{n} \Imp \Var{m}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   515
< \Var{n}$, the default strategy could loop.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   516
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   517
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   518
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   519
\item[$ss$ \ttindexbold{setsubgoaler} $tacf$] sets the subgoaler of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   520
  $ss$ to $tacf$.  The function $tacf$ will be applied to the current
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   521
  simplifier context expressed as a simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   522
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   523
\item[\ttindexbold{prems_of_ss} $ss$] retrieves the current set of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   524
  premises from simplifier context $ss$.  This may be non-empty only
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   525
  if the simplifier has been told to utilize local assumptions in the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   526
  first place, e.g.\ if invoked via \texttt{asm_simp_tac}.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   527
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   528
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   529
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   530
As an example, consider the following subgoaler:
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   531
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   532
fun subgoaler ss =
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   533
    assume_tac ORELSE'
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   534
    resolve_tac (prems_of_ss ss) ORELSE'
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   535
    asm_simp_tac ss;
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   536
\end{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   537
This tactic first tries to solve the subgoal by assumption or by
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   538
resolving with with one of the premises, calling simplification only
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   539
if that fails.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   540
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   541
698
23734672dc12 updated discussion of congruence rules in first section
lcp
parents: 332
diff changeset
   542
\subsection{*The solver}\label{sec:simp-solver}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   543
\begin{ttbox}
7620
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   544
mk_solver  : string -> (thm list -> int -> tactic) -> solver
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   545
setSolver  : simpset * solver -> simpset \hfill{\bf infix 4}
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   546
addSolver  : simpset * solver -> simpset \hfill{\bf infix 4}
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   547
setSSolver : simpset * solver -> simpset \hfill{\bf infix 4}
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   548
addSSolver : simpset * solver -> simpset \hfill{\bf infix 4}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   549
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   550
7620
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   551
A solver is a tactic that attempts to solve a subgoal after
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   552
simplification.  Typically it just proves trivial subgoals such as
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
   553
\texttt{True} and $t=t$.  It could use sophisticated means such as {\tt
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   554
  blast_tac}, though that could make simplification expensive.
7620
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   555
To keep things more abstract, solvers are packaged up in type
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   556
\texttt{solver}. The only way to create a solver is via \texttt{mk_solver}.
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   557
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   558
Rewriting does not instantiate unknowns.  For example, rewriting
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   559
cannot prove $a\in \Var{A}$ since this requires
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   560
instantiating~$\Var{A}$.  The solver, however, is an arbitrary tactic
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   561
and may instantiate unknowns as it pleases.  This is the only way the
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   562
simplifier can handle a conditional rewrite rule whose condition
3485
f27a30a18a17 Now there are TWO spaces after each full stop, so that the Emacs sentence
paulson
parents: 3134
diff changeset
   563
contains extra variables.  When a simplification tactic is to be
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   564
combined with other provers, especially with the classical reasoner,
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   565
it is important whether it can be considered safe or not.  For this
7620
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   566
reason a simpset contains two solvers, a safe and an unsafe one.
2628
1fe7c9f599c2 description of del(eq)congs, safe and unsafe solver
oheimb
parents: 2613
diff changeset
   567
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   568
The standard simplification strategy solely uses the unsafe solver,
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   569
which is appropriate in most cases.  For special applications where
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   570
the simplification process is not allowed to instantiate unknowns
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   571
within the goal, simplification starts with the safe solver, but may
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   572
still apply the ordinary unsafe one in nested simplifications for
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   573
conditional rules or congruences. Note that in this way the overall
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   574
tactic is not totally safe:  it may instantiate unknowns that appear also 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   575
in other subgoals.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   576
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   577
\begin{ttdescription}
7620
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   578
\item[\ttindexbold{mk_solver} $s$ $tacf$] converts $tacf$ into a new solver;
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   579
  the string $s$ is only attached as a comment and has no other significance.
8d721c3f4acb documented type solver
nipkow
parents: 6569
diff changeset
   580
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   581
\item[$ss$ \ttindexbold{setSSolver} $tacf$] installs $tacf$ as the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   582
  \emph{safe} solver of $ss$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   583
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   584
\item[$ss$ \ttindexbold{addSSolver} $tacf$] adds $tacf$ as an
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   585
  additional \emph{safe} solver; it will be tried after the solvers
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   586
  which had already been present in $ss$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   587
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   588
\item[$ss$ \ttindexbold{setSolver} $tacf$] installs $tacf$ as the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   589
  unsafe solver of $ss$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   590
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   591
\item[$ss$ \ttindexbold{addSolver} $tacf$] adds $tacf$ as an
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   592
  additional unsafe solver; it will be tried after the solvers which
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   593
  had already been present in $ss$.
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   594
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   595
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   596
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   597
\medskip
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   598
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   599
\index{assumptions!in simplification} The solver tactic is invoked
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   600
with a list of theorems, namely assumptions that hold in the local
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   601
context.  This may be non-empty only if the simplifier has been told
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   602
to utilize local assumptions in the first place, e.g.\ if invoked via
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   603
\texttt{asm_simp_tac}.  The solver is also presented the full goal
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   604
including its assumptions in any case.  Thus it can use these (e.g.\ 
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   605
by calling \texttt{assume_tac}), even if the list of premises is not
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   606
passed.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   607
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   608
\medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   609
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   610
As explained in \S\ref{sec:simp-subgoaler}, the subgoaler is also used
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   611
to solve the premises of congruence rules.  These are usually of the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   612
form $s = \Var{x}$, where $s$ needs to be simplified and $\Var{x}$
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   613
needs to be instantiated with the result.  Typically, the subgoaler
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   614
will invoke the simplifier at some point, which will eventually call
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   615
the solver.  For this reason, solver tactics must be prepared to solve
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   616
goals of the form $t = \Var{x}$, usually by reflexivity.  In
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   617
particular, reflexivity should be tried before any of the fancy
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
   618
tactics like \texttt{blast_tac}.
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   619
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   620
It may even happen that due to simplification the subgoal is no longer
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   621
an equality.  For example $False \bimp \Var{Q}$ could be rewritten to
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   622
$\lnot\Var{Q}$.  To cover this case, the solver could try resolving
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   623
with the theorem $\lnot False$.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   624
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   625
\medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   626
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   627
\begin{warn}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   628
  If the simplifier aborts with the message \texttt{Failed congruence
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   629
    proof!}, then the subgoaler or solver has failed to prove a
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   630
  premise of a congruence rule.  This should never occur under normal
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   631
  circumstances; it indicates that some congruence rule, or possibly
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   632
  the subgoaler or solver, is faulty.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   633
\end{warn}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   634
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   635
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   636
\subsection{*The looper}\label{sec:simp-looper}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   637
\begin{ttbox}
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   638
setloop   : simpset *           (int -> tactic)  -> simpset \hfill{\bf infix 4}
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   639
addloop   : simpset * (string * (int -> tactic)) -> simpset \hfill{\bf infix 4}
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   640
delloop   : simpset *  string                    -> simpset \hfill{\bf infix 4}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   641
addsplits : simpset * thm list -> simpset \hfill{\bf infix 4}
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   642
delsplits : simpset * thm list -> simpset \hfill{\bf infix 4}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   643
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   644
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   645
The looper is a list of tactics that are applied after simplification, in case
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   646
the solver failed to solve the simplified goal.  If the looper
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   647
succeeds, the simplification process is started all over again.  Each
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   648
of the subgoals generated by the looper is attacked in turn, in
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   649
reverse order.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   650
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   651
A typical looper is \index{case splitting}: the expansion of a conditional.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   652
Another possibility is to apply an elimination rule on the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   653
assumptions.  More adventurous loopers could start an induction.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   654
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   655
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   656
  
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   657
\item[$ss$ \ttindexbold{setloop} $tacf$] installs $tacf$ as the only looper
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   658
  tactic of $ss$.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   659
  
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   660
\item[$ss$ \ttindexbold{addloop} $(name,tacf)$] adds $tacf$ as an additional
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   661
  looper tactic with name $name$; it will be tried after the looper tactics
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   662
  that had already been present in $ss$.
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   663
  
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   664
\item[$ss$ \ttindexbold{delloop} $name$] deletes the looper tactic $name$
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   665
  from $ss$.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   666
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   667
\item[$ss$ \ttindexbold{addsplits} $thms$] adds
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   668
  split tactics for $thms$ as additional looper tactics of $ss$.
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   669
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   670
\item[$ss$ \ttindexbold{addsplits} $thms$] deletes the
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   671
  split tactics for $thms$ from the looper tactics of $ss$.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   672
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   673
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   674
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   675
The splitter replaces applications of a given function; the right-hand side
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   676
of the replacement can be anything.  For example, here is a splitting rule
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   677
for conditional expressions:
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   678
\[ \Var{P}(if(\Var{Q},\Var{x},\Var{y})) \bimp (\Var{Q} \imp \Var{P}(\Var{x}))
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   679
\conj (\lnot\Var{Q} \imp \Var{P}(\Var{y})) 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   680
\] 
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   681
Another example is the elimination operator for Cartesian products (which
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   682
happens to be called~$split$):  
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   683
\[ \Var{P}(split(\Var{f},\Var{p})) \bimp (\forall a~b. \Var{p} =
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   684
\langle a,b\rangle \imp \Var{P}(\Var{f}(a,b))) 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   685
\] 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   686
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   687
For technical reasons, there is a distinction between case splitting in the 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   688
conclusion and in the premises of a subgoal. The former is done by
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   689
\texttt{split_tac} with rules like \texttt{split_if} or \texttt{option.split}, 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   690
which do not split the subgoal, while the latter is done by 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   691
\texttt{split_asm_tac} with rules like \texttt{split_if_asm} or 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   692
\texttt{option.split_asm}, which split the subgoal.
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   693
The operator \texttt{addsplits} automatically takes care of which tactic to
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   694
call, analyzing the form of the rules given as argument.
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   695
\begin{warn}
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   696
Due to \texttt{split_asm_tac}, the simplifier may split subgoals!
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   697
\end{warn}
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   698
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   699
Case splits should be allowed only when necessary; they are expensive
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   700
and hard to control.  Here is an example of use, where \texttt{split_if}
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   701
is the first rule above:
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   702
\begin{ttbox}
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   703
by (simp_tac (simpset() 
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   704
                 addloop ("split if", split_tac [split_if])) 1);
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   705
\end{ttbox}
5776
wenzelm
parents: 5575
diff changeset
   706
Users would usually prefer the following shortcut using \texttt{addsplits}:
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   707
\begin{ttbox}
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   708
by (simp_tac (simpset() addsplits [split_if]) 1);
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
   709
\end{ttbox}
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   710
Case-splitting on conditional expressions is usually beneficial, so it is
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   711
enabled by default in the object-logics \texttt{HOL} and \texttt{FOL}.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   712
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   713
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   714
\section{The simplification tactics}\label{simp-tactics}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   715
\index{simplification!tactics}\index{tactics!simplification}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   716
\begin{ttbox}
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   717
generic_simp_tac       : bool -> bool * bool * bool -> 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   718
                         simpset -> int -> tactic
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   719
simp_tac               : simpset -> int -> tactic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   720
asm_simp_tac           : simpset -> int -> tactic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   721
full_simp_tac          : simpset -> int -> tactic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   722
asm_full_simp_tac      : simpset -> int -> tactic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   723
safe_asm_full_simp_tac : simpset -> int -> tactic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   724
\end{ttbox}
2567
7a28e02e10b7 added addloop (and also documentation of addsolver
oheimb
parents: 2479
diff changeset
   725
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   726
\texttt{generic_simp_tac} is the basic tactic that is underlying any actual
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   727
simplification work. The others are just instantiations of it. The rewriting 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   728
strategy is always strictly bottom up, except for congruence rules, 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   729
which are applied while descending into a term.  Conditions in conditional 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   730
rewrite rules are solved recursively before the rewrite rule is applied.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   731
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   732
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   733
  
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   734
\item[\ttindexbold{generic_simp_tac} $safe$ ($simp\_asm$, $use\_asm$, $mutual$)] 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   735
  gives direct access to the various simplification modes: 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   736
  \begin{itemize}
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   737
  \item if $safe$ is {\tt true}, the safe solver is used as explained in
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   738
  \S\ref{sec:simp-solver},  
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   739
  \item $simp\_asm$ determines whether the local assumptions are simplified,
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   740
  \item $use\_asm$ determines whether the assumptions are used as local rewrite 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   741
   rules, and
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   742
  \item $mutual$ determines whether assumptions can simplify each other rather
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   743
  than being processed from left to right. 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   744
  \end{itemize}
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   745
  This generic interface is intended 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   746
  for building special tools, e.g.\ for combining the simplifier with the 
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   747
  classical reasoner. It is rarely used directly.
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
   748
  
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   749
\item[\ttindexbold{simp_tac}, \ttindexbold{asm_simp_tac},
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   750
  \ttindexbold{full_simp_tac}, \ttindexbold{asm_full_simp_tac}] are
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   751
  the basic simplification tactics that work exactly like their
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   752
  namesakes in \S\ref{sec:simp-for-dummies}, except that they are
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   753
  explicitly supplied with a simpset.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   754
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   755
\end{ttdescription}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   756
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   757
\medskip
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   758
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   759
Local modifications of simpsets within a proof are often much cleaner
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   760
by using above tactics in conjunction with explicit simpsets, rather
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   761
than their capitalized counterparts.  For example
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   762
\begin{ttbox}
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   763
Addsimps \(thms\);
2479
57109c1a653d Updated account of implicit simpsets and clasets
paulson
parents: 2020
diff changeset
   764
by (Simp_tac \(i\));
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   765
Delsimps \(thms\);
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   766
\end{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   767
can be expressed more appropriately as
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   768
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   769
by (simp_tac (simpset() addsimps \(thms\)) \(i\));
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   770
\end{ttbox}
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   771
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   772
\medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   773
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   774
Also note that functions depending implicitly on the current theory
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   775
context (like capital \texttt{Simp_tac} and the other commands of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   776
\S\ref{sec:simp-for-dummies}) should be considered harmful outside of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   777
actual proof scripts.  In particular, ML programs like theory
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   778
definition packages or special tactics should refer to simpsets only
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   779
explicitly, via the above tactics used in conjunction with
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   780
\texttt{simpset_of} or the \texttt{SIMPSET} tacticals.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   781
1860
71bfeecfa96c Documented simplification tactics which make use of the implicit simpset.
nipkow
parents: 1387
diff changeset
   782
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   783
\section{Forward rules and conversions}
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   784
\index{simplification!forward rules}\index{simplification!conversions}
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   785
\begin{ttbox}\index{*simplify}\index{*asm_simplify}\index{*full_simplify}\index{*asm_full_simplify}\index{*Simplifier.rewrite}\index{*Simplifier.asm_rewrite}\index{*Simplifier.full_rewrite}\index{*Simplifier.asm_full_rewrite}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   786
simplify          : simpset -> thm -> thm
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   787
asm_simplify      : simpset -> thm -> thm
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   788
full_simplify     : simpset -> thm -> thm
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   789
asm_full_simplify : simpset -> thm -> thm\medskip
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   790
Simplifier.rewrite           : simpset -> cterm -> thm
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   791
Simplifier.asm_rewrite       : simpset -> cterm -> thm
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   792
Simplifier.full_rewrite      : simpset -> cterm -> thm
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   793
Simplifier.asm_full_rewrite  : simpset -> cterm -> thm
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   794
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   795
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   796
The first four of these functions provide \emph{forward} rules for
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   797
simplification.  Their effect is analogous to the corresponding
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   798
tactics described in \S\ref{simp-tactics}, but affect the whole
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   799
theorem instead of just a certain subgoal.  Also note that the
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   800
looper~/ solver process as described in \S\ref{sec:simp-looper} and
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   801
\S\ref{sec:simp-solver} is omitted in forward simplification.
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   802
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   803
The latter four are \emph{conversions}, establishing proven equations
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   804
of the form $t \equiv u$ where the l.h.s.\ $t$ has been given as
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   805
argument.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   806
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   807
\begin{warn}
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   808
  Forward simplification rules and conversions should be used rarely
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   809
  in ordinary proof scripts.  The main intention is to provide an
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   810
  internal interface to the simplifier for special utilities.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   811
\end{warn}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   812
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   813
7990
0a604b2fc2b1 updated;
wenzelm
parents: 7920
diff changeset
   814
\section{Examples of using the Simplifier}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   815
\index{examples!of simplification} Assume we are working within {\tt
5205
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   816
  FOL} (see the file \texttt{FOL/ex/Nat}) and that
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   817
\begin{ttdescription}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   818
\item[Nat.thy] 
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   819
  is a theory including the constants $0$, $Suc$ and $+$,
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   820
\item[add_0]
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   821
  is the rewrite rule $0+\Var{n} = \Var{n}$,
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   822
\item[add_Suc]
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   823
  is the rewrite rule $Suc(\Var{m})+\Var{n} = Suc(\Var{m}+\Var{n})$,
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   824
\item[induct]
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   825
  is the induction rule $\List{\Var{P}(0);\; \Forall x. \Var{P}(x)\Imp
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   826
    \Var{P}(Suc(x))} \Imp \Var{P}(\Var{n})$.
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   827
\end{ttdescription}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   828
We augment the implicit simpset inherited from \texttt{Nat} with the
4557
wenzelm
parents: 4395
diff changeset
   829
basic rewrite rules for addition of natural numbers:
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   830
\begin{ttbox}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   831
Addsimps [add_0, add_Suc];
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   832
\end{ttbox}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   833
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   834
\subsection{A trivial example}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   835
Proofs by induction typically involve simplification.  Here is a proof
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   836
that~0 is a right identity:
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   837
\begin{ttbox}
5205
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   838
Goal "m+0 = m";
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   839
{\out Level 0}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   840
{\out m + 0 = m}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   841
{\out  1. m + 0 = m}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   842
\end{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   843
The first step is to perform induction on the variable~$m$.  This returns a
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   844
base case and inductive step as two subgoals:
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   845
\begin{ttbox}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   846
by (res_inst_tac [("n","m")] induct 1);
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   847
{\out Level 1}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   848
{\out m + 0 = m}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   849
{\out  1. 0 + 0 = 0}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   850
{\out  2. !!x. x + 0 = x ==> Suc(x) + 0 = Suc(x)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   851
\end{ttbox}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   852
Simplification solves the first subgoal trivially:
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   853
\begin{ttbox}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   854
by (Simp_tac 1);
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   855
{\out Level 2}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   856
{\out m + 0 = m}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   857
{\out  1. !!x. x + 0 = x ==> Suc(x) + 0 = Suc(x)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   858
\end{ttbox}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   859
The remaining subgoal requires \ttindex{Asm_simp_tac} in order to use the
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   860
induction hypothesis as a rewrite rule:
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   861
\begin{ttbox}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   862
by (Asm_simp_tac 1);
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   863
{\out Level 3}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   864
{\out m + 0 = m}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   865
{\out No subgoals!}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   866
\end{ttbox}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   867
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   868
\subsection{An example of tracing}
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   869
\index{tracing!of simplification|(}\index{*trace_simp}
4557
wenzelm
parents: 4395
diff changeset
   870
wenzelm
parents: 4395
diff changeset
   871
Let us prove a similar result involving more complex terms.  We prove
wenzelm
parents: 4395
diff changeset
   872
that addition is commutative.
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   873
\begin{ttbox}
5205
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
   874
Goal "m+Suc(n) = Suc(m+n)";
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   875
{\out Level 0}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   876
{\out m + Suc(n) = Suc(m + n)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   877
{\out  1. m + Suc(n) = Suc(m + n)}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   878
\end{ttbox}
4557
wenzelm
parents: 4395
diff changeset
   879
Performing induction on~$m$ yields two subgoals:
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   880
\begin{ttbox}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   881
by (res_inst_tac [("n","m")] induct 1);
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   882
{\out Level 1}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   883
{\out m + Suc(n) = Suc(m + n)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   884
{\out  1. 0 + Suc(n) = Suc(0 + n)}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   885
{\out  2. !!x. x + Suc(n) = Suc(x + n) ==>}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   886
{\out          Suc(x) + Suc(n) = Suc(Suc(x) + n)}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   887
\end{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   888
Simplification solves the first subgoal, this time rewriting two
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   889
occurrences of~0:
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   890
\begin{ttbox}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   891
by (Simp_tac 1);
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   892
{\out Level 2}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   893
{\out m + Suc(n) = Suc(m + n)}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   894
{\out  1. !!x. x + Suc(n) = Suc(x + n) ==>}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   895
{\out          Suc(x) + Suc(n) = Suc(Suc(x) + n)}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   896
\end{ttbox}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   897
Switching tracing on illustrates how the simplifier solves the remaining
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   898
subgoal: 
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   899
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   900
set trace_simp;
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   901
by (Asm_simp_tac 1);
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   902
\ttbreak
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   903
{\out Adding rewrite rule:}
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   904
{\out .x + Suc n == Suc (.x + n)}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   905
\ttbreak
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   906
{\out Applying instance of rewrite rule:}
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   907
{\out ?m + Suc ?n == Suc (?m + ?n)}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   908
{\out Rewriting:}
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   909
{\out Suc .x + Suc n == Suc (Suc .x + n)}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   910
\ttbreak
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   911
{\out Applying instance of rewrite rule:}
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   912
{\out Suc ?m + ?n == Suc (?m + ?n)}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   913
{\out Rewriting:}
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   914
{\out Suc .x + n == Suc (.x + n)}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   915
\ttbreak
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   916
{\out Applying instance of rewrite rule:}
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   917
{\out Suc ?m + ?n == Suc (?m + ?n)}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   918
{\out Rewriting:}
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   919
{\out Suc .x + n == Suc (.x + n)}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   920
\ttbreak
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   921
{\out Applying instance of rewrite rule:}
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   922
{\out ?x = ?x == True}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   923
{\out Rewriting:}
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
   924
{\out Suc (Suc (.x + n)) = Suc (Suc (.x + n)) == True}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   925
\ttbreak
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   926
{\out Level 3}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   927
{\out m + Suc(n) = Suc(m + n)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   928
{\out No subgoals!}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   929
\end{ttbox}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   930
Many variations are possible.  At Level~1 (in either example) we could have
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   931
solved both subgoals at once using the tactical \ttindex{ALLGOALS}:
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   932
\begin{ttbox}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   933
by (ALLGOALS Asm_simp_tac);
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   934
{\out Level 2}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   935
{\out m + Suc(n) = Suc(m + n)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   936
{\out No subgoals!}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   937
\end{ttbox}
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
   938
\index{tracing!of simplification|)}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   939
4557
wenzelm
parents: 4395
diff changeset
   940
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   941
\subsection{Free variables and simplification}
4557
wenzelm
parents: 4395
diff changeset
   942
wenzelm
parents: 4395
diff changeset
   943
Here is a conjecture to be proved for an arbitrary function~$f$
wenzelm
parents: 4395
diff changeset
   944
satisfying the law $f(Suc(\Var{n})) = Suc(f(\Var{n}))$:
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   945
\begin{ttbox}
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   946
val [prem] = Goal
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
   947
               "(!!n. f(Suc(n)) = Suc(f(n))) ==> f(i+j) = i+f(j)";
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   948
{\out Level 0}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   949
{\out f(i + j) = i + f(j)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   950
{\out  1. f(i + j) = i + f(j)}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   951
\ttbreak
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   952
{\out val prem = "f(Suc(?n)) = Suc(f(?n))}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
   953
{\out             [!!n. f(Suc(n)) = Suc(f(n))]" : thm}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   954
\end{ttbox}
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
   955
In the theorem~\texttt{prem}, note that $f$ is a free variable while
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   956
$\Var{n}$ is a schematic variable.
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
   957
\begin{ttbox}
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   958
by (res_inst_tac [("n","i")] induct 1);
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   959
{\out Level 1}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   960
{\out f(i + j) = i + f(j)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   961
{\out  1. f(0 + j) = 0 + f(j)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   962
{\out  2. !!x. f(x + j) = x + f(j) ==> f(Suc(x) + j) = Suc(x) + f(j)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   963
\end{ttbox}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   964
We simplify each subgoal in turn.  The first one is trivial:
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   965
\begin{ttbox}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   966
by (Simp_tac 1);
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   967
{\out Level 2}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   968
{\out f(i + j) = i + f(j)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   969
{\out  1. !!x. f(x + j) = x + f(j) ==> f(Suc(x) + j) = Suc(x) + f(j)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   970
\end{ttbox}
3112
0f764be1583a fixed simplifier examples;
wenzelm
parents: 3108
diff changeset
   971
The remaining subgoal requires rewriting by the premise, so we add it
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   972
to the current simpset:
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   973
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   974
by (asm_simp_tac (simpset() addsimps [prem]) 1);
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   975
{\out Level 3}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   976
{\out f(i + j) = i + f(j)}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   977
{\out No subgoals!}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   978
\end{ttbox}
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
   979
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   980
\subsection{Reordering assumptions}
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   981
\label{sec:reordering-asms}
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   982
\index{assumptions!reordering}
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   983
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   984
As mentioned in \S\ref{sec:simp-for-dummies-tacs},
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   985
\ttindex{asm_full_simp_tac} may require the assumptions to be permuted
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
   986
to be more effective.  Given the subgoal
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   987
\begin{ttbox}
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   988
{\out 1. [| ALL x. P x --> f x = g x; Q(f a); P a; R |] ==> S}
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   989
\end{ttbox}
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   990
we can rotate the assumptions two positions to the right
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   991
\begin{ttbox}
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   992
by (rotate_tac ~2 1);
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   993
\end{ttbox}
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   994
to obtain
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   995
\begin{ttbox}
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   996
{\out 1. [| P a; R; ALL x. P x --> f x = g x; Q(f a) |] ==> S}
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
   997
\end{ttbox}
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   998
which enables \verb$asm_full_simp_tac$ to simplify \verb$Q(f a)$ to
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
   999
\verb$Q(g a)$ because now all required assumptions are to the left of
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
  1000
\verb$Q(f a)$.
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
  1001
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
  1002
Since rotation alone cannot produce arbitrary permutations, you can also pick
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
  1003
out a particular assumption which needs to be rewritten and move it the the
3485
f27a30a18a17 Now there are TWO spaces after each full stop, so that the Emacs sentence
paulson
parents: 3134
diff changeset
  1004
right end of the assumptions.  In the above case rotation can be replaced by
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
  1005
\begin{ttbox}
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
  1006
by (dres_inst_tac [("psi","Q(f a)")] asm_rl 1);
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
  1007
\end{ttbox}
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
  1008
which is more directed and leads to
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
  1009
\begin{ttbox}
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
  1010
{\out 1. [| ALL x. P x --> f x = g x; P a; R; Q(f a) |] ==> S}
1213
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
  1011
\end{ttbox}
a8f6d0fa2a59 added section on "Reordering assumptions".
nipkow
parents: 1101
diff changeset
  1012
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1013
\begin{warn}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1014
  Reordering assumptions usually leads to brittle proofs and should be
4889
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
  1015
  avoided.  Future versions of \verb$asm_full_simp_tac$ will completely
72cbd13deb16 New behaviour of asm_full_simp_tac.
nipkow
parents: 4798
diff changeset
  1016
  remove the need for such manipulations.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1017
\end{warn}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1018
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1019
332
01b87a921967 final Springer copy
lcp
parents: 323
diff changeset
  1020
\section{Permutative rewrite rules}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1021
\index{rewrite rules!permutative|(}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1022
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1023
A rewrite rule is {\bf permutative} if the left-hand side and right-hand
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1024
side are the same up to renaming of variables.  The most common permutative
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1025
rule is commutativity: $x+y = y+x$.  Other examples include $(x-y)-z =
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1026
(x-z)-y$ in arithmetic and $insert(x,insert(y,A)) = insert(y,insert(x,A))$
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1027
for sets.  Such rules are common enough to merit special attention.
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1028
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1029
Because ordinary rewriting loops given such rules, the simplifier
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1030
employs a special strategy, called {\bf ordered
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1031
  rewriting}\index{rewriting!ordered}.  There is a standard
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1032
lexicographic ordering on terms.  This should be perfectly OK in most
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1033
cases, but can be changed for special applications.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1034
4947
15fd948d6c69 Small mods.
nipkow
parents: 4889
diff changeset
  1035
\begin{ttbox}
15fd948d6c69 Small mods.
nipkow
parents: 4889
diff changeset
  1036
settermless : simpset * (term * term -> bool) -> simpset \hfill{\bf infix 4}
15fd948d6c69 Small mods.
nipkow
parents: 4889
diff changeset
  1037
\end{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1038
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1039
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1040
\item[$ss$ \ttindexbold{settermless} $rel$] installs relation $rel$ as
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1041
  term order in simpset $ss$.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1042
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1043
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1044
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1045
\medskip
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1046
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1047
A permutative rewrite rule is applied only if it decreases the given
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1048
term with respect to this ordering.  For example, commutativity
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1049
rewrites~$b+a$ to $a+b$, but then stops because $a+b$ is strictly less
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1050
than $b+a$.  The Boyer-Moore theorem prover~\cite{bm88book} also
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1051
employs ordered rewriting.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1052
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1053
Permutative rewrite rules are added to simpsets just like other
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1054
rewrite rules; the simplifier recognizes their special status
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1055
automatically.  They are most effective in the case of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1056
associative-commutative operators.  (Associativity by itself is not
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1057
permutative.)  When dealing with an AC-operator~$f$, keep the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1058
following points in mind:
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1059
\begin{itemize}\index{associative-commutative operators}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1060
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1061
\item The associative law must always be oriented from left to right,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1062
  namely $f(f(x,y),z) = f(x,f(y,z))$.  The opposite orientation, if
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1063
  used with commutativity, leads to looping in conjunction with the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1064
  standard term order.
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1065
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1066
\item To complete your set of rewrite rules, you must add not just
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1067
  associativity~(A) and commutativity~(C) but also a derived rule, {\bf
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1068
    left-com\-mut\-ativ\-ity} (LC): $f(x,f(y,z)) = f(y,f(x,z))$.
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1069
\end{itemize}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1070
Ordered rewriting with the combination of A, C, and~LC sorts a term
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1071
lexicographically:
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1072
\[\def\maps#1{\stackrel{#1}{\longmapsto}}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1073
 (b+c)+a \maps{A} b+(c+a) \maps{C} b+(a+c) \maps{LC} a+(b+c) \]
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1074
Martin and Nipkow~\cite{martin-nipkow} discuss the theory and give many
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1075
examples; other algebraic structures are amenable to ordered rewriting,
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1076
such as boolean rings.
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1077
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1078
\subsection{Example: sums of natural numbers}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1079
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1080
This example is again set in \HOL\ (see \texttt{HOL/ex/NatSum}).
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1081
Theory \thydx{Arith} contains natural numbers arithmetic.  Its
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1082
associated simpset contains many arithmetic laws including
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1083
distributivity of~$\times$ over~$+$, while \texttt{add_ac} is a list
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1084
consisting of the A, C and LC laws for~$+$ on type \texttt{nat}.  Let
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1085
us prove the theorem
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1086
\[ \sum@{i=1}^n i = n\times(n+1)/2. \]
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1087
%
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1088
A functional~\texttt{sum} represents the summation operator under the
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1089
interpretation $\texttt{sum} \, f \, (n + 1) = \sum@{i=0}^n f\,i$.  We
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1090
extend \texttt{Arith} as follows:
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1091
\begin{ttbox}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1092
NatSum = Arith +
1387
9bcad9c22fd4 removed quotes from syntax and consts sections
clasohm
parents: 1213
diff changeset
  1093
consts sum     :: [nat=>nat, nat] => nat
9445
6c93b1eb11f8 Corrected example which still used old primrec syntax.
berghofe
parents: 9398
diff changeset
  1094
primrec 
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1095
  "sum f 0 = 0"
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1096
  "sum f (Suc n) = f(n) + sum f n"
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1097
end
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1098
\end{ttbox}
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1099
The \texttt{primrec} declaration automatically adds rewrite rules for
4557
wenzelm
parents: 4395
diff changeset
  1100
\texttt{sum} to the default simpset.  We now remove the
wenzelm
parents: 4395
diff changeset
  1101
\texttt{nat_cancel} simplification procedures (in order not to spoil
wenzelm
parents: 4395
diff changeset
  1102
the example) and insert the AC-rules for~$+$:
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1103
\begin{ttbox}
4557
wenzelm
parents: 4395
diff changeset
  1104
Delsimprocs nat_cancel;
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1105
Addsimps add_ac;
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1106
\end{ttbox}
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1107
Our desired theorem now reads $\texttt{sum} \, (\lambda i.i) \, (n+1) =
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1108
n\times(n+1)/2$.  The Isabelle goal has both sides multiplied by~$2$:
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1109
\begin{ttbox}
5205
602354039306 Changed "goal" to "Goal"
paulson
parents: 4947
diff changeset
  1110
Goal "2 * sum (\%i.i) (Suc n) = n * Suc n";
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1111
{\out Level 0}
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1112
{\out 2 * sum (\%i. i) (Suc n) = n * Suc n}
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1113
{\out  1. 2 * sum (\%i. i) (Suc n) = n * Suc n}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1114
\end{ttbox}
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1115
Induction should not be applied until the goal is in the simplest
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1116
form:
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1117
\begin{ttbox}
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1118
by (Simp_tac 1);
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1119
{\out Level 1}
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1120
{\out 2 * sum (\%i. i) (Suc n) = n * Suc n}
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1121
{\out  1. n + (sum (\%i. i) n + sum (\%i. i) n) = n * n}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1122
\end{ttbox}
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1123
Ordered rewriting has sorted the terms in the left-hand side.  The
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1124
subgoal is now ready for induction:
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1125
\begin{ttbox}
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1126
by (induct_tac "n" 1);
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1127
{\out Level 2}
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1128
{\out 2 * sum (\%i. i) (Suc n) = n * Suc n}
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1129
{\out  1. 0 + (sum (\%i. i) 0 + sum (\%i. i) 0) = 0 * 0}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1130
\ttbreak
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1131
{\out  2. !!n. n + (sum (\%i. i) n + sum (\%i. i) n) = n * n}
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1132
{\out           ==> Suc n + (sum (\%i. i) (Suc n) + sum (\%i.\,i) (Suc n)) =}
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1133
{\out               Suc n * Suc n}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1134
\end{ttbox}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1135
Simplification proves both subgoals immediately:\index{*ALLGOALS}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1136
\begin{ttbox}
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1137
by (ALLGOALS Asm_simp_tac);
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1138
{\out Level 3}
3108
335efc3f5632 misc updates, tuning, cleanup;
wenzelm
parents: 3087
diff changeset
  1139
{\out 2 * sum (\%i. i) (Suc n) = n * Suc n}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1140
{\out No subgoals!}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1141
\end{ttbox}
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1142
Simplification cannot prove the induction step if we omit \texttt{add_ac} from
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1143
the simpset.  Observe that like terms have not been collected:
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1144
\begin{ttbox}
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1145
{\out Level 3}
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1146
{\out 2 * sum (\%i. i) (Suc n) = n * Suc n}
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1147
{\out  1. !!n. n + sum (\%i. i) n + (n + sum (\%i. i) n) = n + n * n}
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1148
{\out           ==> n + (n + sum (\%i. i) n) + (n + (n + sum (\%i.\,i) n)) =}
4245
b9ce25073cc0 Updated the NatSum example
paulson
parents: 3950
diff changeset
  1149
{\out               n + (n + (n + n * n))}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1150
\end{ttbox}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1151
Ordered rewriting proves this by sorting the left-hand side.  Proving
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1152
arithmetic theorems without ordered rewriting requires explicit use of
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1153
commutativity.  This is tedious; try it and see!
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1154
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1155
Ordered rewriting is equally successful in proving
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1156
$\sum@{i=1}^n i^3 = n^2\times(n+1)^2/4$.
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1157
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1158
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1159
\subsection{Re-orienting equalities}
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1160
Ordered rewriting with the derived rule \texttt{symmetry} can reverse
4557
wenzelm
parents: 4395
diff changeset
  1161
equations:
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1162
\begin{ttbox}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1163
val symmetry = prove_goal HOL.thy "(x=y) = (y=x)"
3128
d01d4c0c4b44 New acknowledgements; fixed overfull lines and tables
paulson
parents: 3112
diff changeset
  1164
                 (fn _ => [Blast_tac 1]);
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1165
\end{ttbox}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1166
This is frequently useful.  Assumptions of the form $s=t$, where $t$ occurs
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1167
in the conclusion but not~$s$, can often be brought into the right form.
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1168
For example, ordered rewriting with \texttt{symmetry} can prove the goal
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1169
\[ f(a)=b \conj f(a)=c \imp b=c. \]
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1170
Here \texttt{symmetry} reverses both $f(a)=b$ and $f(a)=c$
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1171
because $f(a)$ is lexicographically greater than $b$ and~$c$.  These
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1172
re-oriented equations, as rewrite rules, replace $b$ and~$c$ in the
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1173
conclusion by~$f(a)$. 
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1174
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
  1175
Another example is the goal $\lnot(t=u) \imp \lnot(u=t)$.
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1176
The differing orientations make this appear difficult to prove.  Ordered
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1177
rewriting with \texttt{symmetry} makes the equalities agree.  (Without
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1178
knowing more about~$t$ and~$u$ we cannot say whether they both go to $t=u$
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1179
or~$u=t$.)  Then the simplifier can prove the goal outright.
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1180
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1181
\index{rewrite rules!permutative|)}
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1182
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1183
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1184
\section{*Coding simplification procedures}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1185
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1186
mk_simproc: string -> cterm list ->
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1187
              (Sign.sg -> thm list -> term -> thm option) -> simproc
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1188
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1189
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1190
\begin{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1191
\item[\ttindexbold{mk_simproc}~$name$~$lhss$~$proc$] makes $proc$ a
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1192
  simplification procedure for left-hand side patterns $lhss$.  The
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1193
  name just serves as a comment.  The function $proc$ may be invoked
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1194
  by the simplifier for redex positions matched by one of $lhss$ as
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1195
  described below.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1196
\end{ttdescription}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1197
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1198
Simplification procedures are applied in a two-stage process as
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1199
follows: The simplifier tries to match the current redex position
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1200
against any one of the $lhs$ patterns of any simplification procedure.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1201
If this succeeds, it invokes the corresponding {\ML} function, passing
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1202
with the current signature, local assumptions and the (potential)
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1203
redex.  The result may be either \texttt{None} (indicating failure) or
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1204
\texttt{Some~$thm$}.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1205
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1206
Any successful result is supposed to be a (possibly conditional)
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1207
rewrite rule $t \equiv u$ that is applicable to the current redex.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1208
The rule will be applied just as any ordinary rewrite rule.  It is
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1209
expected to be already in \emph{internal form}, though, bypassing the
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1210
automatic preprocessing of object-level equivalences.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1211
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1212
\medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1213
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1214
As an example of how to write your own simplification procedures,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1215
consider eta-expansion of pair abstraction (see also
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1216
\texttt{HOL/Modelcheck/MCSyn} where this is used to provide external
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1217
model checker syntax).
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1218
  
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1219
The {\HOL} theory of tuples (see \texttt{HOL/Prod}) provides an
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1220
operator \texttt{split} together with some concrete syntax supporting
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1221
$\lambda\,(x,y).b$ abstractions.  Assume that we would like to offer a
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1222
tactic that rewrites any function $\lambda\,p.f\,p$ (where $p$ is of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1223
some pair type) to $\lambda\,(x,y).f\,(x,y)$.  The corresponding rule
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1224
is:
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1225
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1226
pair_eta_expand:  (f::'a*'b=>'c) = (\%(x, y). f (x, y))
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1227
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1228
Unfortunately, term rewriting using this rule directly would not
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1229
terminate!  We now use the simplification procedure mechanism in order
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1230
to stop the simplifier from applying this rule over and over again,
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1231
making it rewrite only actual abstractions.  The simplification
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1232
procedure \texttt{pair_eta_expand_proc} is defined as follows:
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1233
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1234
local
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1235
  val lhss =
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1236
    [read_cterm (sign_of Prod.thy) 
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1237
                ("f::'a*'b=>'c", TVar (("'z", 0), []))];
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1238
  val rew = mk_meta_eq pair_eta_expand; \medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1239
  fun proc _ _ (Abs _) = Some rew
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1240
    | proc _ _ _ = None;
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1241
in
4560
wenzelm
parents: 4557
diff changeset
  1242
  val pair_eta_expand_proc = mk_simproc "pair_eta_expand" lhss proc;
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1243
end;
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1244
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1245
This is an example of using \texttt{pair_eta_expand_proc}:
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1246
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1247
{\out 1. P (\%p::'a * 'a. fst p + snd p + z)}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1248
by (simp_tac (simpset() addsimprocs [pair_eta_expand_proc]) 1);
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1249
{\out 1. P (\%(x::'a,y::'a). x + y + z)}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1250
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1251
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1252
\medskip
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1253
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1254
In the above example the simplification procedure just did fine
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1255
grained control over rule application, beyond higher-order pattern
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1256
matching.  Usually, procedures would do some more work, in particular
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1257
prove particular theorems depending on the current redex.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1258
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1259
7990
0a604b2fc2b1 updated;
wenzelm
parents: 7920
diff changeset
  1260
\section{*Setting up the Simplifier}\label{sec:setting-up-simp}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1261
\index{simplification!setting up}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1262
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1263
Setting up the simplifier for new logics is complicated.  This section
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1264
describes how the simplifier is installed for intuitionistic
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1265
first-order logic; the code is largely taken from {\tt
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1266
  FOL/simpdata.ML} of the Isabelle sources.
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1267
6569
wenzelm
parents: 5776
diff changeset
  1268
The simplifier and the case splitting tactic, which reside on separate files,
wenzelm
parents: 5776
diff changeset
  1269
are not part of Pure Isabelle.  They must be loaded explicitly by the
wenzelm
parents: 5776
diff changeset
  1270
object-logic as follows (below \texttt{\~\relax\~\relax} refers to
wenzelm
parents: 5776
diff changeset
  1271
\texttt{\$ISABELLE_HOME}):
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1272
\begin{ttbox}
6569
wenzelm
parents: 5776
diff changeset
  1273
use "\~\relax\~\relax/src/Provers/simplifier.ML";
wenzelm
parents: 5776
diff changeset
  1274
use "\~\relax\~\relax/src/Provers/splitter.ML";
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1275
\end{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1276
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1277
Simplification requires converting object-equalities to meta-level rewrite
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1278
rules.  This demands rules stating that equal terms and equivalent formulae
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1279
are also equal at the meta-level.  The rule declaration part of the file
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1280
\texttt{FOL/IFOL.thy} contains the two lines
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1281
\begin{ttbox}\index{*eq_reflection theorem}\index{*iff_reflection theorem}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1282
eq_reflection   "(x=y)   ==> (x==y)"
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1283
iff_reflection  "(P<->Q) ==> (P==Q)"
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1284
\end{ttbox}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1285
Of course, you should only assert such rules if they are true for your
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1286
particular logic.  In Constructive Type Theory, equality is a ternary
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1287
relation of the form $a=b\in A$; the type~$A$ determines the meaning
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1288
of the equality essentially as a partial equivalence relation.  The
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1289
present simplifier cannot be used.  Rewriting in \texttt{CTT} uses
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1290
another simplifier, which resides in the file {\tt
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1291
  Provers/typedsimp.ML} and is not documented.  Even this does not
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1292
work for later variants of Constructive Type Theory that use
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1293
intensional equality~\cite{nordstrom90}.
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1294
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1295
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1296
\subsection{A collection of standard rewrite rules}
4557
wenzelm
parents: 4395
diff changeset
  1297
wenzelm
parents: 4395
diff changeset
  1298
We first prove lots of standard rewrite rules about the logical
wenzelm
parents: 4395
diff changeset
  1299
connectives.  These include cancellation and associative laws.  We
wenzelm
parents: 4395
diff changeset
  1300
define a function that echoes the desired law and then supplies it the
wenzelm
parents: 4395
diff changeset
  1301
prover for intuitionistic \FOL:
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1302
\begin{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1303
fun int_prove_fun s = 
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1304
 (writeln s;  
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1305
  prove_goal IFOL.thy s
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1306
   (fn prems => [ (cut_facts_tac prems 1), 
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1307
                  (IntPr.fast_tac 1) ]));
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1308
\end{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1309
The following rewrite rules about conjunction are a selection of those
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1310
proved on \texttt{FOL/simpdata.ML}.  Later, these will be supplied to the
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1311
standard simpset.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1312
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1313
val conj_simps = map int_prove_fun
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1314
 ["P & True <-> P",      "True & P <-> P",
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1315
  "P & False <-> False", "False & P <-> False",
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1316
  "P & P <-> P",
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1317
  "P & ~P <-> False",    "~P & P <-> False",
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1318
  "(P & Q) & R <-> P & (Q & R)"];
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1319
\end{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1320
The file also proves some distributive laws.  As they can cause exponential
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1321
blowup, they will not be included in the standard simpset.  Instead they
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1322
are merely bound to an \ML{} identifier, for user reference.
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1323
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1324
val distrib_simps  = map int_prove_fun
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1325
 ["P & (Q | R) <-> P&Q | P&R", 
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1326
  "(Q | R) & P <-> Q&P | R&P",
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1327
  "(P | Q --> R) <-> (P --> R) & (Q --> R)"];
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1328
\end{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1329
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1330
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1331
\subsection{Functions for preprocessing the rewrite rules}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1332
\label{sec:setmksimps}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1333
\begin{ttbox}\indexbold{*setmksimps}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1334
setmksimps : simpset * (thm -> thm list) -> simpset \hfill{\bf infix 4}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1335
\end{ttbox}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1336
The next step is to define the function for preprocessing rewrite rules.
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1337
This will be installed by calling \texttt{setmksimps} below.  Preprocessing
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1338
occurs whenever rewrite rules are added, whether by user command or
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1339
automatically.  Preprocessing involves extracting atomic rewrites at the
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1340
object-level, then reflecting them to the meta-level.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1341
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1342
To start, the function \texttt{gen_all} strips any meta-level
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1343
quantifiers from the front of the given theorem.  Usually there are none
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1344
anyway.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1345
\begin{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1346
fun gen_all th = forall_elim_vars (#maxidx(rep_thm th)+1) th;
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1347
\end{ttbox}
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1348
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1349
The function \texttt{atomize} analyses a theorem in order to extract
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1350
atomic rewrite rules.  The head of all the patterns, matched by the
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1351
wildcard~\texttt{_}, is the coercion function \texttt{Trueprop}.
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1352
\begin{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1353
fun atomize th = case concl_of th of 
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1354
    _ $ (Const("op &",_) $ _ $ _)   => atomize(th RS conjunct1) \at
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1355
                                       atomize(th RS conjunct2)
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1356
  | _ $ (Const("op -->",_) $ _ $ _) => atomize(th RS mp)
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1357
  | _ $ (Const("All",_) $ _)        => atomize(th RS spec)
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1358
  | _ $ (Const("True",_))           => []
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1359
  | _ $ (Const("False",_))          => []
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1360
  | _                               => [th];
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1361
\end{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1362
There are several cases, depending upon the form of the conclusion:
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1363
\begin{itemize}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1364
\item Conjunction: extract rewrites from both conjuncts.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1365
\item Implication: convert $P\imp Q$ to the meta-implication $P\Imp Q$ and
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1366
  extract rewrites from~$Q$; these will be conditional rewrites with the
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1367
  condition~$P$.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1368
\item Universal quantification: remove the quantifier, replacing the bound
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1369
  variable by a schematic variable, and extract rewrites from the body.
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1370
\item \texttt{True} and \texttt{False} contain no useful rewrites.
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1371
\item Anything else: return the theorem in a singleton list.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1372
\end{itemize}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1373
The resulting theorems are not literally atomic --- they could be
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1374
disjunctive, for example --- but are broken down as much as possible. 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1375
See the file \texttt{ZF/simpdata.ML} for a sophisticated translation of
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1376
set-theoretic formulae into rewrite rules. 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1377
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1378
For standard situations like the above,
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1379
there is a generic auxiliary function \ttindexbold{mk_atomize} that takes a 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1380
list of pairs $(name, thms)$, where $name$ is an operator name and
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1381
$thms$ is a list of theorems to resolve with in case the pattern matches, 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1382
and returns a suitable \texttt{atomize} function.
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1383
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
  1384
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1385
The simplified rewrites must now be converted into meta-equalities.  The
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1386
rule \texttt{eq_reflection} converts equality rewrites, while {\tt
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1387
  iff_reflection} converts if-and-only-if rewrites.  The latter possibility
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
  1388
can arise in two other ways: the negative theorem~$\lnot P$ is converted to
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1389
$P\equiv\texttt{False}$, and any other theorem~$P$ is converted to
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1390
$P\equiv\texttt{True}$.  The rules \texttt{iff_reflection_F} and {\tt
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1391
  iff_reflection_T} accomplish this conversion.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1392
\begin{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1393
val P_iff_F = int_prove_fun "~P ==> (P <-> False)";
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1394
val iff_reflection_F = P_iff_F RS iff_reflection;
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1395
\ttbreak
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1396
val P_iff_T = int_prove_fun "P ==> (P <-> True)";
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1397
val iff_reflection_T = P_iff_T RS iff_reflection;
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1398
\end{ttbox}
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1399
The function \texttt{mk_eq} converts a theorem to a meta-equality
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1400
using the case analysis described above.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1401
\begin{ttbox}
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1402
fun mk_eq th = case concl_of th of
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1403
    _ $ (Const("op =",_)$_$_)   => th RS eq_reflection
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1404
  | _ $ (Const("op <->",_)$_$_) => th RS iff_reflection
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1405
  | _ $ (Const("Not",_)$_)      => th RS iff_reflection_F
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1406
  | _                           => th RS iff_reflection_T;
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1407
\end{ttbox}
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1408
The three functions \texttt{gen_all}, \texttt{atomize} and \texttt{mk_eq} 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1409
will be composed together and supplied below to \texttt{setmksimps}.
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1410
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1411
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1412
\subsection{Making the initial simpset}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1413
4798
7cfc85fc6fd7 no open Simplifier;
wenzelm
parents: 4664
diff changeset
  1414
It is time to assemble these items.  We define the infix operator
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1415
\ttindex{addcongs} to insert congruence rules; given a list of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1416
theorems, it converts their conclusions into meta-equalities and
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1417
passes them to \ttindex{addeqcongs}.
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1418
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1419
infix 4 addcongs;
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1420
fun ss addcongs congs =
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1421
    ss addeqcongs (congs RL [eq_reflection,iff_reflection]);
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1422
\end{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1423
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1424
The list \texttt{IFOL_simps} contains the default rewrite rules for
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1425
intuitionistic first-order logic.  The first of these is the reflexive law
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1426
expressed as the equivalence $(a=a)\bimp\texttt{True}$; the rewrite rule $a=a$ is
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1427
clearly useless.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1428
\begin{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1429
val IFOL_simps =
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1430
   [refl RS P_iff_T] \at conj_simps \at disj_simps \at not_simps \at 
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1431
    imp_simps \at iff_simps \at quant_simps;
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1432
\end{ttbox}
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1433
The list \texttt{triv_rls} contains trivial theorems for the solver.  Any
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1434
subgoal that is simplified to one of these will be removed.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1435
\begin{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1436
val notFalseI = int_prove_fun "~False";
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1437
val triv_rls = [TrueI,refl,iff_refl,notFalseI];
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1438
\end{ttbox}
323
361a71713176 penultimate Springer draft
lcp
parents: 286
diff changeset
  1439
%
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1440
The basic simpset for intuitionistic \FOL{} is
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1441
\ttindexbold{FOL_basic_ss}.  It preprocess rewrites using {\tt
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1442
  gen_all}, \texttt{atomize} and \texttt{mk_eq}.  It solves simplified
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1443
subgoals using \texttt{triv_rls} and assumptions, and by detecting
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1444
contradictions.  It uses \ttindex{asm_simp_tac} to tackle subgoals of
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1445
conditional rewrites.
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1446
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1447
Other simpsets built from \texttt{FOL_basic_ss} will inherit these items.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1448
In particular, \ttindexbold{IFOL_ss}, which introduces {\tt
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1449
  IFOL_simps} as rewrite rules.  \ttindexbold{FOL_ss} will later
9398
0ee9b2819155 removed safe_asm_full_simp_tac, added generic_simp_tac
oheimb
parents: 8136
diff changeset
  1450
extend \texttt{IFOL_ss} with classical rewrite rules such as $\lnot\lnot
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1451
P\bimp P$.
2628
1fe7c9f599c2 description of del(eq)congs, safe and unsafe solver
oheimb
parents: 2613
diff changeset
  1452
\index{*setmksimps}\index{*setSSolver}\index{*setSolver}\index{*setsubgoaler}
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1453
\index{*addsimps}\index{*addcongs}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1454
\begin{ttbox}
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1455
fun unsafe_solver prems = FIRST'[resolve_tac (triv_rls {\at} prems),
2628
1fe7c9f599c2 description of del(eq)congs, safe and unsafe solver
oheimb
parents: 2613
diff changeset
  1456
                                 atac, etac FalseE];
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1457
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1458
fun safe_solver prems = FIRST'[match_tac (triv_rls {\at} prems),
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1459
                               eq_assume_tac, ematch_tac [FalseE]];
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1460
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1461
val FOL_basic_ss = 
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1462
      empty_ss setsubgoaler asm_simp_tac
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1463
               addsimprocs [defALL_regroup, defEX_regroup]
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1464
               setSSolver   safe_solver
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1465
               setSolver  unsafe_solver
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1466
               setmksimps (map mk_eq o atomize o gen_all);
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1467
8136
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1468
val IFOL_ss = 
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1469
      FOL_basic_ss addsimps (IFOL_simps {\at} 
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1470
                             int_ex_simps {\at} int_all_simps)
8c65f3ca13f2 fixed many bad line & page breaks
paulson
parents: 7990
diff changeset
  1471
                   addcongs [imp_cong];
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1472
\end{ttbox}
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1473
This simpset takes \texttt{imp_cong} as a congruence rule in order to use
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1474
contextual information to simplify the conclusions of implications:
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1475
\[ \List{\Var{P}\bimp\Var{P'};\; \Var{P'} \Imp \Var{Q}\bimp\Var{Q'}} \Imp
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1476
   (\Var{P}\imp\Var{Q}) \bimp (\Var{P'}\imp\Var{Q'})
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1477
\]
4597
a0bdee64194c Fixed a lot of overfull and underfull lines (hboxes)
paulson
parents: 4560
diff changeset
  1478
By adding the congruence rule \texttt{conj_cong}, we could obtain a similar
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1479
effect for conjunctions.
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1480
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1481
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1482
\subsection{Splitter setup}\index{simplification!setting up the splitter}
4557
wenzelm
parents: 4395
diff changeset
  1483
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1484
To set up case splitting, we have to call the \ML{} functor \ttindex{
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1485
SplitterFun}, which takes the argument signature \texttt{SPLITTER_DATA}. 
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1486
So we prove the theorem \texttt{meta_eq_to_iff} below and store it, together
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1487
with the \texttt{mk_eq} function described above and several standard
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1488
theorems, in the structure \texttt{SplitterData}. Calling the functor with
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1489
this data yields a new instantiation of the splitter for our logic.
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1490
\begin{ttbox}
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1491
val meta_eq_to_iff = prove_goal IFOL.thy "x==y ==> x<->y"
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1492
  (fn [prem] => [rewtac prem, rtac iffI 1, atac 1, atac 1]);
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1493
\ttbreak
5549
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1494
structure SplitterData =
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1495
  struct
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1496
  structure Simplifier = Simplifier
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1497
  val mk_eq          = mk_eq
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1498
  val meta_eq_to_iff = meta_eq_to_iff
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1499
  val iffD           = iffD2
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1500
  val disjE          = disjE
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1501
  val conjE          = conjE
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1502
  val exE            = exE
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1503
  val contrapos      = contrapos
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1504
  val contrapos2     = contrapos2
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1505
  val notnotD        = notnotD
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1506
  end;
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1507
\ttbreak
7e91d450fd6f improved description of looper and splitter
oheimb
parents: 5370
diff changeset
  1508
structure Splitter = SplitterFun(SplitterData);
286
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1509
\end{ttbox}
e7efbf03562b first draft of Springer book
lcp
parents: 133
diff changeset
  1510
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
  1511
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1512
\subsection{Theory setup}\index{simplification!setting up the theory}
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1513
\begin{ttbox}\indexbold{*Simplifier.setup}\index{*setup!simplifier}
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1514
Simplifier.setup: (theory -> theory) list
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1515
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1516
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1517
Advanced theory related features of the simplifier (e.g.\ implicit
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1518
simpset support) have to be set up explicitly.  The simplifier already
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1519
provides a suitable setup function definition.  This has to be
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1520
installed into the base theory of any new object-logic via a
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1521
\texttt{setup} declaration.
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1522
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1523
For example, this is done in \texttt{FOL/IFOL.thy} as follows:
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1524
\begin{ttbox}
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1525
setup Simplifier.setup
4395
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1526
\end{ttbox}
a2b726277050 major update;
wenzelm
parents: 4317
diff changeset
  1527
104
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
  1528
d8205bb279a7 Initial revision
lcp
parents:
diff changeset
  1529
\index{simplification|)}
5370
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1530
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1531
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1532
%%% Local Variables: 
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1533
%%% mode: latex
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1534
%%% TeX-master: "ref"
ba0470fe09fc emacs local vars;
wenzelm
parents: 5205
diff changeset
  1535
%%% End: