author | Christian Urban <urbanc@in.tum.de> |
Thu, 26 Mar 2009 19:00:51 +0000 | |
changeset 210 | db8e302f44c8 |
parent 209 | 17b1512f51af |
child 211 | d5accbc67e1b |
permissions | -rw-r--r-- |
91
667a0943c40b
added a section that will eventually describe the code
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
1 |
theory Ind_Code |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
2 |
imports "../Base" "../FirstSteps" Ind_General_Scheme |
91
667a0943c40b
added a section that will eventually describe the code
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
3 |
begin |
667a0943c40b
added a section that will eventually describe the code
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
4 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
5 |
section {* The Gory Details *} |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
6 |
|
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
7 |
subsection {* Definitions *} |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
8 |
|
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
9 |
text {* |
209 | 10 |
We first have to produce for each predicate the definition, whose general form is |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
11 |
|
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
12 |
@{text [display] "pred \<equiv> \<lambda>zs. \<forall>preds. orules \<longrightarrow> pred zs"} |
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
13 |
|
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
14 |
and then ``register'' the definition inside a local theory. |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
15 |
To do the latter, we use the following wrapper for |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
16 |
@{ML LocalTheory.define}. The wrapper takes a predicate name, a syntax |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
17 |
annotation and a term representing the right-hand side of the definition. |
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
18 |
*} |
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
19 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
20 |
ML %linenosgray{*fun make_defn ((predname, syn), trm) lthy = |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
21 |
let |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
22 |
val arg = ((predname, syn), (Attrib.empty_binding, trm)) |
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
23 |
val ((_, (_ , thm)), lthy') = LocalTheory.define Thm.internalK arg lthy |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
24 |
in |
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
25 |
(thm, lthy') |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
26 |
end*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
27 |
|
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
28 |
text {* |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
29 |
It returns the definition (as a theorem) and the local theory in which this definition has |
184 | 30 |
been made. In Line 4, @{ML internalK in Thm} is a flag attached to the |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
31 |
theorem (others possibile flags are @{ML definitionK in Thm} and @{ML axiomK in Thm}). |
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
32 |
These flags just classify theorems and have no significant meaning, except |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
33 |
for tools that, for example, find theorems in the theorem database. We also |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
34 |
use @{ML empty_binding in Attrib} in Line 3, since for our inductive predicates |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
35 |
the definitions do not need to have any theorem attributes. A testcase for this |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
36 |
function is |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
37 |
*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
38 |
|
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
39 |
local_setup %gray {* fn lthy => |
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
40 |
let |
209 | 41 |
val arg = ((@{binding "MyTrue"}, NoSyn), @{term True}) |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
42 |
val (def, lthy') = make_defn arg lthy |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
43 |
in |
194 | 44 |
warning (str_of_thm_no_vars lthy' def); lthy' |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
45 |
end *} |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
46 |
|
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
47 |
text {* |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
48 |
which introduces the definition @{prop "MyTrue \<equiv> True"} and then prints it out. |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
49 |
Since we are testing the function inside \isacommand{local\_setup}, i.e., make |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
50 |
changes to the ambient theory, we can query the definition with the usual |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
51 |
command \isacommand{thm}: |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
52 |
|
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
53 |
\begin{isabelle} |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
54 |
\isacommand{thm}~@{text "MyTrue_def"}\\ |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
55 |
@{text "> MyTrue \<equiv> True"} |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
56 |
\end{isabelle} |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
57 |
|
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
58 |
The next two functions construct the right-hand sides of the definitions, |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
59 |
which are terms of the form |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
60 |
|
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
61 |
@{text [display] "\<lambda>zs. \<forall>preds. orules \<longrightarrow> pred zs"} |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
62 |
|
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
63 |
When constructing them, the variables @{text "zs"} need to be chosen so that |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
64 |
they do not occur in the @{text orules} and also be distinct from the @{text |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
65 |
"preds"}. |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
66 |
|
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
67 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
68 |
The first function constructs the term for one particular predicate (the |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
69 |
argument @{text "pred"} in the code belo). The number of arguments of this predicate is |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
70 |
determined by the number of argument types given in @{text "arg_tys"}. |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
71 |
The other arguments are all the @{text "preds"} and the @{text "orules"}. |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
72 |
*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
73 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
74 |
ML %linenosgray{*fun defn_aux lthy orules preds (pred, arg_tys) = |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
75 |
let |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
76 |
fun mk_all x P = HOLogic.all_const (fastype_of x) $ lambda x P |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
77 |
|
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
78 |
val fresh_args = |
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
79 |
arg_tys |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
80 |
|> map (pair "z") |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
81 |
|> Variable.variant_frees lthy (preds @ orules) |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
82 |
|> map Free |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
83 |
in |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
84 |
list_comb (pred, fresh_args) |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
85 |
|> fold_rev (curry HOLogic.mk_imp) orules |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
86 |
|> fold_rev mk_all preds |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
87 |
|> fold_rev lambda fresh_args |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
88 |
end*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
89 |
|
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
90 |
text {* |
184 | 91 |
The function in Line 3 is just a helper function for constructing universal |
92 |
quantifications. The code in Lines 5 to 9 produces the fresh @{text |
|
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
93 |
"zs"}. For this it pairs every argument type with the string |
184 | 94 |
@{text [quotes] "z"} (Line 7); then generates variants for all these strings |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
95 |
so that they are unique w.r.t.~to the predicates and @{text "orules"} (Line 8); |
184 | 96 |
in Line 9 it generates the corresponding variable terms for the unique |
97 |
strings. |
|
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
98 |
|
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
99 |
The unique free variables are applied to the predicate (Line 11) using the |
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
100 |
function @{ML list_comb}; then the @{text orules} are prefixed (Line 12); in |
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
101 |
Line 13 we quantify over all predicates; and in line 14 we just abstract |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
102 |
over all the @{text "zs"}, i.e., the fresh arguments of the |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
103 |
predicate. A testcase for this function is |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
104 |
*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
105 |
|
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
106 |
local_setup %gray{* fn lthy => |
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
107 |
let |
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
108 |
val pred = @{term "even::nat\<Rightarrow>bool"} |
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
109 |
val arg_tys = [@{typ "nat"}] |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
110 |
val def = defn_aux lthy eo_orules eo_preds (pred, arg_tys) |
173
d820cb5873ea
used latex package boxedminipage
Christian Urban <urbanc@in.tum.de>
parents:
165
diff
changeset
|
111 |
in |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
112 |
warning (Syntax.string_of_term lthy def); lthy |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
113 |
end *} |
173
d820cb5873ea
used latex package boxedminipage
Christian Urban <urbanc@in.tum.de>
parents:
165
diff
changeset
|
114 |
|
91
667a0943c40b
added a section that will eventually describe the code
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
115 |
text {* |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
116 |
The testcase calls @{ML defn_aux} for the predicate @{text "even"} and prints |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
117 |
out the generated definition. So we obtain as printout |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
118 |
|
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
119 |
@{text [display] |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
120 |
"\<lambda>z. \<forall>even odd. (even 0) \<longrightarrow> (\<forall>n. odd n \<longrightarrow> even (Suc n)) |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
121 |
\<longrightarrow> (\<forall>n. even n \<longrightarrow> odd (Suc n)) \<longrightarrow> even z"} |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
122 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
123 |
If we try out the function for the definition of freshness |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
124 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
125 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
126 |
local_setup %gray{* fn lthy => |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
127 |
(warning (Syntax.string_of_term lthy |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
128 |
(defn_aux lthy fresh_orules [fresh_pred] (fresh_pred, fresh_arg_tys))); |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
129 |
lthy) *} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
130 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
131 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
132 |
we obtain |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
133 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
134 |
@{term [display] |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
135 |
"\<lambda>z za. \<forall>fresh. (\<forall>a b. \<not> a = b \<longrightarrow> fresh a (Var b)) \<longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
136 |
(\<forall>a s t. fresh a t \<longrightarrow> fresh a s \<longrightarrow> fresh a (App t s)) \<longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
137 |
(\<forall>a t. fresh a (Lam a t)) \<longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
138 |
(\<forall>a b t. \<not> a = b \<longrightarrow> fresh a t \<longrightarrow> fresh a (Lam b t)) \<longrightarrow> fresh z za"} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
139 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
140 |
|
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
141 |
The second function for the definitions has to just iterate the function |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
142 |
@{ML defn_aux} over all predicates. The argument @{text "preds"} is again |
184 | 143 |
the the list of predicates as @{ML_type term}s; the argument @{text |
209 | 144 |
"prednames"} is the list of names of the predicates; @{text syns} are the |
145 |
syntax annotations for each predicate; @{text "arg_tyss"} is |
|
184 | 146 |
the list of argument-type-lists for each predicate. |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
147 |
*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
148 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
149 |
ML %linenosgray{*fun defns rules preds prednames syns arg_typss lthy = |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
150 |
let |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
151 |
val thy = ProofContext.theory_of lthy |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
152 |
val orules = map (ObjectLogic.atomize_term thy) rules |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
153 |
val defs = map (defn_aux lthy orules preds) (preds ~~ arg_typss) |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
154 |
in |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
155 |
fold_map make_defn (prednames ~~ syns ~~ defs) lthy |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
156 |
end*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
157 |
|
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
158 |
text {* |
184 | 159 |
The user will state the introduction rules using meta-implications and |
160 |
meta-quanti\-fications. In Line 4, we transform these introduction rules into |
|
161 |
the object logic (since definitions cannot be stated with |
|
162 |
meta-connectives). To do this transformation we have to obtain the theory |
|
163 |
behind the local theory (Line 3); with this theory we can use the function |
|
164 |
@{ML ObjectLogic.atomize_term} to make the transformation (Line 4). The call |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
165 |
to @{ML defn_aux} in Line 5 produces all right-hand sides of the |
184 | 166 |
definitions. The actual definitions are then made in Line 7. The result |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
167 |
of the function is a list of theorems and a local theory. A testcase for |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
168 |
this function is |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
169 |
*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
170 |
|
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
171 |
local_setup %gray {* fn lthy => |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
172 |
let |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
173 |
val (defs, lthy') = |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
174 |
defns eo_rules eo_preds eo_prednames eo_syns eo_arg_tyss lthy |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
175 |
in |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
176 |
warning (str_of_thms_no_vars lthy' defs); lthy |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
177 |
end *} |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
178 |
|
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
179 |
text {* |
184 | 180 |
where we feed into the functions all parameters corresponding to |
181 |
the @{text even}-@{text odd} example. The definitions we obtain |
|
182 |
are: |
|
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
183 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
184 |
@{text [display, break] |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
185 |
"even \<equiv> \<lambda>z. \<forall>even odd. (even 0) \<longrightarrow> (\<forall>n. odd n \<longrightarrow> even (Suc n)) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
186 |
\<longrightarrow> (\<forall>n. even n \<longrightarrow> odd (Suc n)) \<longrightarrow> even z, |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
187 |
odd \<equiv> \<lambda>z. \<forall>even odd. (even 0) \<longrightarrow> (\<forall>n. odd n \<longrightarrow> even (Suc n)) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
188 |
\<longrightarrow> (\<forall>n. even n \<longrightarrow> odd (Suc n)) \<longrightarrow> odd z"} |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
189 |
|
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
190 |
Note that in the testcase we return the local theory @{text lthy} |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
191 |
(not the modified @{text lthy'}). As a result the test case has no effect |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
192 |
on the ambient theory. The reason is that if we introduce the |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
193 |
definition again, we pollute the name space with two versions of @{text "even"} |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
194 |
and @{text "odd"}. |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
195 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
196 |
This completes the code for introducing the definitions. Next we deal with |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
197 |
the induction principles. |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
198 |
*} |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
199 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
200 |
subsection {* Induction Principles *} |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
201 |
|
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
202 |
text {* |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
203 |
Recall that the proof of the induction principle |
184 | 204 |
for @{text "even"} was: |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
205 |
*} |
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
206 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
207 |
lemma manual_ind_prin_even: |
209 | 208 |
assumes prem: "even z" |
209 |
shows "P 0 \<Longrightarrow> (\<And>m. Q m \<Longrightarrow> P (Suc m)) \<Longrightarrow> (\<And>m. P m \<Longrightarrow> Q (Suc m)) \<Longrightarrow> P z" |
|
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
210 |
apply(atomize (full)) |
209 | 211 |
apply(cut_tac prem) |
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
212 |
apply(unfold even_def) |
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
213 |
apply(drule spec[where x=P]) |
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
214 |
apply(drule spec[where x=Q]) |
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
215 |
apply(assumption) |
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
216 |
done |
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
217 |
|
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
218 |
text {* |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
219 |
The code for automating such induction principles has to accomplish two tasks: |
184 | 220 |
constructing the induction principles from the given introduction |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
221 |
rules and then automatically generating proofs for them using a tactic. |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
222 |
|
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
223 |
The tactic will use the following helper function for instantiating universal |
184 | 224 |
quantifiers. |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
225 |
*} |
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
226 |
|
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
227 |
ML{*fun inst_spec ctrm = |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
228 |
Drule.instantiate' [SOME (ctyp_of_term ctrm)] [NONE, SOME ctrm] @{thm spec}*} |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
229 |
|
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
230 |
text {* |
184 | 231 |
This helper function instantiates the @{text "?x"} in the theorem |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
232 |
@{thm spec} with a given @{ML_type cterm}. We call this helper function |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
233 |
in the tactic: |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
234 |
*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
235 |
|
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
236 |
ML{*fun inst_spec_tac ctrms = |
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
237 |
EVERY' (map (dtac o inst_spec) ctrms)*} |
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
238 |
|
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
239 |
text {* |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
240 |
This tactic allows us to instantiate in the following proof the |
184 | 241 |
three quantifiers in the assumption. |
242 |
*} |
|
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
243 |
|
184 | 244 |
lemma |
245 |
fixes P::"nat \<Rightarrow> nat \<Rightarrow> nat \<Rightarrow> bool" |
|
246 |
shows "\<forall>x y z. P x y z \<Longrightarrow> True" |
|
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
247 |
apply (tactic {* |
184 | 248 |
inst_spec_tac [@{cterm "a::nat"},@{cterm "b::nat"},@{cterm "c::nat"}] 1 *}) |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
249 |
txt {* |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
250 |
We obtain the goal state |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
251 |
|
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
252 |
\begin{minipage}{\textwidth} |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
253 |
@{subgoals} |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
254 |
\end{minipage}*} |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
255 |
(*<*)oops(*>*) |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
256 |
|
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
257 |
text {* |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
258 |
Now the complete tactic for proving the induction principles can |
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
259 |
be implemented as follows: |
163
2319cff107f0
removed rep_ss, and used dest_ss instead; some very slight changes to simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
124
diff
changeset
|
260 |
*} |
2319cff107f0
removed rep_ss, and used dest_ss instead; some very slight changes to simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
124
diff
changeset
|
261 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
262 |
ML %linenosgray{*fun ind_tac defs prem insts = |
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
263 |
EVERY1 [ObjectLogic.full_atomize_tac, |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
264 |
cut_facts_tac prem, |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
265 |
K (rewrite_goals_tac defs), |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
266 |
inst_spec_tac insts, |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
267 |
assume_tac]*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
268 |
|
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
269 |
text {* |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
270 |
We have to give it as arguments the definitions, the premise (this premise |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
271 |
is @{text "even n"} in lemma @{thm [source] manual_ind_prin_even}) and the |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
272 |
instantiations. Compare this tactic with the manual for the lemma @{thm |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
273 |
[source] manual_ind_prin_even}: as you can see there is almost a one-to-one |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
274 |
correspondence between the \isacommand{apply}-script and the @{ML |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
275 |
ind_tac}. Two testcases for this tactic are: |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
276 |
*} |
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
277 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
278 |
lemma automatic_ind_prin_even: |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
279 |
assumes prem: "even z" |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
280 |
shows "P 0 \<Longrightarrow> (\<And>m. Q m \<Longrightarrow> P (Suc m)) \<Longrightarrow> (\<And>m. P m \<Longrightarrow> Q (Suc m)) \<Longrightarrow> P z" |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
281 |
by (tactic {* ind_tac eo_defs @{thms prem} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
282 |
[@{cterm "P::nat\<Rightarrow>bool"}, @{cterm "Q::nat\<Rightarrow>bool"}] *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
283 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
284 |
lemma automatic_ind_prin_fresh: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
285 |
assumes prem: "fresh z za" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
286 |
shows "(\<And>a b. a \<noteq> b \<Longrightarrow> P a (Var b)) \<Longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
287 |
(\<And>a t s. \<lbrakk>P a t; P a s\<rbrakk> \<Longrightarrow> P a (App t s)) \<Longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
288 |
(\<And>a t. P a (Lam a t)) \<Longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
289 |
(\<And>a b t. \<lbrakk>a \<noteq> b; P a t\<rbrakk> \<Longrightarrow> P a (Lam b t)) \<Longrightarrow> P z za" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
290 |
by (tactic {* ind_tac @{thms fresh_def} @{thms prem} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
291 |
[@{cterm "P::string\<Rightarrow>trm\<Rightarrow>bool"}] *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
292 |
|
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
293 |
|
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
294 |
text {* |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
295 |
Let us have a closer look at the first proved theorem: |
209 | 296 |
|
297 |
\begin{isabelle} |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
298 |
\isacommand{thm}~@{thm [source] automatic_ind_prin_even}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
299 |
@{text "> "}~@{thm automatic_ind_prin_even} |
209 | 300 |
\end{isabelle} |
301 |
||
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
302 |
The variables @{text "z"}, @{text "P"} and @{text "Q"} are schematic |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
303 |
variables (since they are not quantified in the lemma). These schematic |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
304 |
variables are needed so that they can be instantiated by the user later |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
305 |
on. We have to take care to also generate these schematic variables when |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
306 |
generating the goals for the induction principles. While the tactic for |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
307 |
proving the induction principles is relatively simple, it will be a bit |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
308 |
of work to construct the goals from the introduction rules the user |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
309 |
provides. In general we have to construct for each predicate @{text "pred"} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
310 |
a goal of the form |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
311 |
|
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
312 |
@{text [display] |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
313 |
"pred ?zs \<Longrightarrow> rules[preds := ?Ps] \<Longrightarrow> ?P ?zs"} |
180
9c25418db6f0
added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents:
179
diff
changeset
|
314 |
|
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
315 |
where the predicates @{text preds} are replaced in the introduction |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
316 |
rules by new distinct variables @{text "?Ps"}. |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
317 |
We also need to generate fresh arguments @{text "?zs"} for the predicate |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
318 |
@{text "pred"} and the @{text "?P"} in the conclusion. Note |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
319 |
that the @{text "?Ps"} and @{text "?zs"} need to be |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
320 |
schematic variables that can be instantiated by the user. |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
321 |
|
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
322 |
We generate these goals in two steps. The first function expects that the |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
323 |
introduction rules are already appropriately substituted. The argument |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
324 |
@{text "srules"} stands for these substituted rules; @{text cnewpreds} are |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
325 |
the certified terms coresponding to the variables @{text "?Ps"}; @{text |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
326 |
"pred"} is the predicate for which we prove the induction principle; |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
327 |
@{text "newpred"} is its replacement and @{text "arg_tys"} are the argument |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
328 |
types of this predicate. |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
329 |
*} |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
330 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
331 |
ML %linenosgray{*fun prove_ind lthy defs srules cnewpreds ((pred, newpred), arg_tys) = |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
332 |
let |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
333 |
val zs = replicate (length arg_tys) "z" |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
334 |
val (newargnames, lthy') = Variable.variant_fixes zs lthy; |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
335 |
val newargs = map Free (newargnames ~~ arg_tys) |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
336 |
|
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
337 |
val prem = HOLogic.mk_Trueprop (list_comb (pred, newargs)) |
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
338 |
val goal = Logic.list_implies |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
339 |
(srules, HOLogic.mk_Trueprop (list_comb (newpred, newargs))) |
178
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Christian Urban <urbanc@in.tum.de>
parents:
177
diff
changeset
|
340 |
in |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
341 |
Goal.prove lthy' [] [prem] goal |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
342 |
(fn {prems, ...} => ind_tac defs prems cnewpreds) |
179
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
343 |
|> singleton (ProofContext.export lthy' lthy) |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
344 |
end *} |
75381fa516cd
more work on the simple-induct. chapter
Christian Urban <urbanc@in.tum.de>
parents:
178
diff
changeset
|
345 |
|
180
9c25418db6f0
added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents:
179
diff
changeset
|
346 |
text {* |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
347 |
In Line 3 we produce names @{text "zs"} for each type in the |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
348 |
argument type list. Line 4 makes these names unique and declares them as |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
349 |
\emph{free} (but fixed) variables in the local theory @{text "lthy'"}. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
350 |
That means they are not (yet) schematic variables. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
351 |
In Line 5 we construct the terms corresponding to these variables. |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
352 |
The variables are applied to the predicate in Line 7 (this corresponds |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
353 |
to the first premise @{text "pred zs"} of the induction principle). |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
354 |
In Line 8 and 9, we first construct the term @{text "P zs"} |
209 | 355 |
and then add the (substituted) introduction rules as premises. In case that |
184 | 356 |
no introduction rules are given, the conclusion of this implication needs |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
357 |
to be wrapped inside a @{term Trueprop}, otherwise the Isabelle's goal |
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
358 |
mechanism will fail. |
180
9c25418db6f0
added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents:
179
diff
changeset
|
359 |
|
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
360 |
In Line 11 we set up the goal to be proved; in the next line we call the |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
361 |
tactic for proving the induction principle. As mentioned before, this tactic |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
362 |
expects the definitions, the premise and the (certified) predicates with |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
363 |
which the introduction rules have been substituted. The code in these two |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
364 |
lines will return a theorem. However, it is a theorem |
184 | 365 |
proved inside the local theory @{text "lthy'"}, where the variables @{text |
209 | 366 |
"zs"} are fixed, but free (see Line 4). By exporting this theorem from @{text |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
367 |
"lthy'"} (which contains the @{text "zs"} as free variables) to @{text |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
368 |
"lthy"} (which does not), we obtain the desired schematic variables @{text "?zs"}. |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
369 |
A testcase for this function is |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
370 |
*} |
180
9c25418db6f0
added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents:
179
diff
changeset
|
371 |
|
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
372 |
local_setup %gray{* fn lthy => |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
373 |
let |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
374 |
val newpreds = [@{term "P::nat\<Rightarrow>bool"}, @{term "Q::nat\<Rightarrow>bool"}] |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
375 |
val cnewpreds = [@{cterm "P::nat\<Rightarrow>bool"}, @{cterm "Q::nat\<Rightarrow>bool"}] |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
376 |
val srules = map (subst_free (eo_preds ~~ newpreds)) eo_rules |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
377 |
val newpred = @{term "P::nat\<Rightarrow>bool"} |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
378 |
val intro = |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
379 |
prove_ind lthy eo_defs srules cnewpreds ((e_pred, newpred), e_arg_tys) |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
380 |
in |
194 | 381 |
warning (str_of_thm lthy intro); lthy |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
382 |
end *} |
184 | 383 |
|
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
384 |
text {* |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
385 |
This prints out the theorem: |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
386 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
387 |
@{text [display] |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
388 |
" \<lbrakk>even ?z; P 0; \<And>n. Q n \<Longrightarrow> P (Suc n); \<And>n. P n \<Longrightarrow> Q (Suc n)\<rbrakk> \<Longrightarrow> P ?z"} |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
389 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
390 |
The export from @{text lthy'} to @{text lthy} in Line 13 above |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
391 |
has correctly turned the free, but fixed, @{text "z"} into a schematic |
209 | 392 |
variable @{text "?z"}; the variables @{text "P"} and @{text "Q"} are not yet |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
393 |
schematic. |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
394 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
395 |
We still have to produce the new predicates with which the introduction |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
396 |
rules are substituted and iterate @{ML prove_ind} over all |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
397 |
predicates. This is what the second function does: |
180
9c25418db6f0
added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents:
179
diff
changeset
|
398 |
*} |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
399 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
400 |
ML %linenosgray{*fun inds rules defs preds arg_tyss lthy = |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
401 |
let |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
402 |
val Ps = replicate (length preds) "P" |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
403 |
val (newprednames, lthy') = Variable.variant_fixes Ps lthy |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
404 |
|
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
405 |
val thy = ProofContext.theory_of lthy' |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
406 |
|
184 | 407 |
val tyss' = map (fn tys => tys ---> HOLogic.boolT) arg_tyss |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
408 |
val newpreds = map Free (newprednames ~~ tyss') |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
409 |
val cnewpreds = map (cterm_of thy) newpreds |
184 | 410 |
val srules = map (subst_free (preds ~~ newpreds)) rules |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
411 |
|
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
412 |
in |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
413 |
map (prove_ind lthy' defs srules cnewpreds) |
184 | 414 |
(preds ~~ newpreds ~~ arg_tyss) |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
415 |
|> ProofContext.export lthy' lthy |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
416 |
end*} |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
417 |
|
184 | 418 |
text {* |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
419 |
In Line 3, we generate a string @{text [quotes] "P"} for each predicate. |
184 | 420 |
In Line 4, we use the same trick as in the previous function, that is making the |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
421 |
@{text "Ps"} fresh and declaring them as fixed, but free, in |
184 | 422 |
the new local theory @{text "lthy'"}. From the local theory we extract |
423 |
the ambient theory in Line 6. We need this theory in order to certify |
|
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
424 |
the new predicates. In Line 8, we construct the types of these new predicates |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
425 |
using the given argument types. Next we turn them into terms and subsequently |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
426 |
certify them (Line 9 and 10). We can now produce the substituted introduction rules |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
427 |
(Line 11) using the function @{ML subst_free}. Line 14 and 15 just iterate |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
428 |
the proofs for all predicates. |
184 | 429 |
From this we obtain a list of theorems. Finally we need to export the |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
430 |
fixed variables @{text "Ps"} to obtain the schematic variables @{text "?Ps"} |
184 | 431 |
(Line 16). |
432 |
||
433 |
A testcase for this function is |
|
434 |
*} |
|
435 |
||
436 |
local_setup %gray {* fn lthy => |
|
437 |
let |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
438 |
val ind_thms = inds eo_rules eo_defs eo_preds eo_arg_tyss lthy |
184 | 439 |
in |
194 | 440 |
warning (str_of_thms lthy ind_thms); lthy |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
441 |
end *} |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
442 |
|
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
443 |
|
184 | 444 |
text {* |
445 |
which prints out |
|
446 |
||
447 |
@{text [display] |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
448 |
"even ?z \<Longrightarrow> ?P1 0 \<Longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
449 |
(\<And>m. ?Pa1 m \<Longrightarrow> ?P1 (Suc m)) \<Longrightarrow> (\<And>m. ?P1 m \<Longrightarrow> ?Pa1 (Suc m)) \<Longrightarrow> ?P1 ?z, |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
450 |
odd ?z \<Longrightarrow> ?P1 0 \<Longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
451 |
(\<And>m. ?Pa1 m \<Longrightarrow> ?P1 (Suc m)) \<Longrightarrow> (\<And>m. ?P1 m \<Longrightarrow> ?Pa1 (Suc m)) \<Longrightarrow> ?Pa1 ?z"} |
184 | 452 |
|
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
453 |
Note that now both, the @{text "?Ps"} and the @{text "?zs"}, are schematic |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
454 |
variables. The numbers attached to these variables have been introduced by |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
455 |
the pretty-printer and are \emph{not} important for the user. |
184 | 456 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
457 |
This completes the code for the induction principles. The final peice |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
458 |
of reasoning infrastructure we need are the introduction rules. |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
459 |
*} |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
460 |
|
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
461 |
subsection {* Introduction Rules *} |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
462 |
|
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
463 |
text {* |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
464 |
The proofs of the introduction rules are quite a bit |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
465 |
more involved than the ones for the induction principles. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
466 |
To ease somewhat our work here, we use the following two helper |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
467 |
functions. |
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
468 |
|
184 | 469 |
*} |
470 |
||
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
471 |
ML{*val all_elims = fold (fn ct => fn th => th RS inst_spec ct) |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
472 |
val imp_elims = fold (fn th => fn th' => [th', th] MRS @{thm mp})*} |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
473 |
|
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
474 |
text {* |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
475 |
To see what these functions do, let us suppose whe have the following three |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
476 |
theorems. |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
477 |
*} |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
478 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
479 |
lemma all_elims_test: |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
480 |
fixes P::"nat \<Rightarrow> nat \<Rightarrow> nat \<Rightarrow> bool" |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
481 |
shows "\<forall>x y z. P x y z" sorry |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
482 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
483 |
lemma imp_elims_test: |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
484 |
shows "A \<longrightarrow> B \<longrightarrow> C" sorry |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
485 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
486 |
lemma imp_elims_test': |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
487 |
shows "A" "B" sorry |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
488 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
489 |
text {* |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
490 |
The function @{ML all_elims} takes a list of (certified) terms and instantiates |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
491 |
theorems of the form @{thm [source] all_elims_test}. For example we can instantiate |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
492 |
the quantifiers in this theorem with @{term a}, @{term b} and @{term c} as follows: |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
493 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
494 |
@{ML_response_fake [display, gray] |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
495 |
"let |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
496 |
val ctrms = [@{cterm \"a::nat\"}, @{cterm \"b::nat\"}, @{cterm \"c::nat\"}] |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
497 |
val new_thm = all_elims ctrms @{thm all_elims_test} |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
498 |
in |
194 | 499 |
warning (str_of_thm_no_vars @{context} new_thm) |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
500 |
end" |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
501 |
"P a b c"} |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
502 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
503 |
Similarly, the function @{ML imp_elims} eliminates preconditions from implications. |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
504 |
For example we can eliminate the preconditions @{text "A"} and @{text "B"} from |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
505 |
@{thm [source] imp_elims_test}: |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
506 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
507 |
@{ML_response_fake [display, gray] |
194 | 508 |
"warning (str_of_thm_no_vars @{context} |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
509 |
(imp_elims @{thms imp_elims_test'} @{thm imp_elims_test}))" |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
510 |
"C"} |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
511 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
512 |
To explain the proof for the introduction rule, our running example will be |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
513 |
the rule: |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
514 |
|
209 | 515 |
\begin{isabelle} |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
516 |
@{prop "\<And>a b t. \<lbrakk>a \<noteq> b; fresh a t\<rbrakk> \<Longrightarrow> fresh a (Lam b t)"} |
209 | 517 |
\end{isabelle} |
518 |
||
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
519 |
for freshness of applications. We set up the proof as follows: |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
520 |
*} |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
521 |
|
192 | 522 |
lemma fresh_App: |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
523 |
shows "\<And>a b t. \<lbrakk>a \<noteq> b; fresh a t\<rbrakk> \<Longrightarrow> fresh a (Lam b t)" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
524 |
(*<*)oops(*>*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
525 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
526 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
527 |
The first step will be to expand the definitions of freshness |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
528 |
and then introduce quantifiers and implications. For this we |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
529 |
will use the tactic |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
530 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
531 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
532 |
ML{*fun expand_tac defs = |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
533 |
ObjectLogic.rulify_tac 1 |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
534 |
THEN rewrite_goals_tac defs |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
535 |
THEN (REPEAT (resolve_tac [@{thm allI}, @{thm impI}] 1)) *} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
536 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
537 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
538 |
The first step of ``rulifying'' the lemma will turn out important |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
539 |
later on. Applying this tactic |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
540 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
541 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
542 |
(*<*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
543 |
lemma fresh_App: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
544 |
shows "\<And>a b t. \<lbrakk>a \<noteq> b; fresh a t\<rbrakk> \<Longrightarrow> fresh a (Lam b t)" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
545 |
(*>*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
546 |
apply(tactic {* expand_tac @{thms fresh_def} *}) |
209 | 547 |
|
548 |
txt {* |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
549 |
we end up in the goal state |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
550 |
|
209 | 551 |
\begin{isabelle} |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
552 |
@{subgoals [display]} |
209 | 553 |
\end{isabelle} |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
554 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
555 |
As you can see, there are parameters (namely @{text "a"}, @{text "b"} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
556 |
and @{text "t"}) which come from the introduction rule and parameters |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
557 |
(in the case above only @{text "fresh"}) which come from the universal |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
558 |
quantification in the definition @{term "fresh a (App t s)"}. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
559 |
Similarly, there are preconditions |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
560 |
that come from the premises of the rule and premises from the |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
561 |
definition. We need to treat these |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
562 |
parameters and preconditions differently. In the code below |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
563 |
we will therefore separate them into @{text "params1"} and @{text params2}, |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
564 |
respectively @{text "prems1"} and @{text "prems2"}. To do this |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
565 |
separation, it is best to open a subproof with the tactic |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
566 |
@{ML SUBPROOF}, since this tactic provides us |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
567 |
with the parameters (as list of @{ML_type cterm}s) and the premises |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
568 |
(as list of @{ML_type thm}s). The problem we have to overcome |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
569 |
with @{ML SUBPROOF} is that this tactic always expects us to completely |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
570 |
discharge with the goal (see Section ???). This is inconvenient for |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
571 |
our gradual explanation of the proof. To circumvent this inconvenience |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
572 |
we use the following modified tactic: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
573 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
574 |
(*<*)oops(*>*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
575 |
ML{*fun SUBPROOF_test tac ctxt = (SUBPROOF tac ctxt 1) ORELSE all_tac*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
576 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
577 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
578 |
If the tactic inside @{ML SUBPROOF} fails, then the overall tactic will |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
579 |
still succeed. With this testing tactic, we can gradually implement |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
580 |
all necessary proof steps. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
581 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
582 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
583 |
text_raw {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
584 |
\begin{figure}[t] |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
585 |
\begin{minipage}{\textwidth} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
586 |
\begin{isabelle} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
587 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
588 |
ML{*fun chop_print params1 params2 prems1 prems2 ctxt = |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
589 |
let |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
590 |
val s = ["Params1 from the rule:", str_of_cterms ctxt params1] |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
591 |
@ ["Params2 from the predicate:", str_of_cterms ctxt params2] |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
592 |
@ ["Prems1 from the rule:"] @ (map (str_of_thm ctxt) prems1) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
593 |
@ ["Prems2 from the predicate:"] @ (map (str_of_thm ctxt) prems2) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
594 |
in |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
595 |
s |> separate "\n" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
596 |
|> implode |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
597 |
|> warning |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
598 |
end*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
599 |
text_raw{* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
600 |
\end{isabelle} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
601 |
\end{minipage} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
602 |
\caption{FIXME\label{fig:chopprint}} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
603 |
\end{figure} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
604 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
605 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
606 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
607 |
First we calculate the values for @{text "params1/2"} and @{text "prems1/2"} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
608 |
from @{text "params"} and @{text "prems"}, respectively. To see what is |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
609 |
going in our example, we will print out the values using the printing |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
610 |
function in Figure~\ref{fig:chopprint}. Since the tactic @{ML SUBPROOF} will |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
611 |
supply us the @{text "params"} and @{text "prems"} as lists, we can |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
612 |
separate them using the function @{ML chop}. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
613 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
614 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
615 |
ML{*fun chop_test_tac preds rules = |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
616 |
SUBPROOF_test (fn {params, prems, context, ...} => |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
617 |
let |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
618 |
val (params1, params2) = chop (length params - length preds) params |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
619 |
val (prems1, prems2) = chop (length prems - length rules) prems |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
620 |
in |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
621 |
chop_print params1 params2 prems1 prems2 context; no_tac |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
622 |
end) *} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
623 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
624 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
625 |
For the separation we can rely on that Isabelle deterministically |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
626 |
produces parameter and premises in a goal state. The last parameters |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
627 |
that were introduced, come from the quantifications in the definitions. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
628 |
Therefore we only have to subtract the number of predicates (in this |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
629 |
case only @{text "1"} from the lenghts of all parameters. Similarly |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
630 |
with the @{text "prems"}. The last premises in the goal state must |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
631 |
come from unfolding of the conclusion. So we can just subtract |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
632 |
the number of rules from the number of all premises. Applying |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
633 |
this tactic in our example |
209 | 634 |
*} |
635 |
||
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
636 |
(*<*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
637 |
lemma fresh_App: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
638 |
shows "\<And>a b t. \<lbrakk>a \<noteq> b; fresh a t\<rbrakk> \<Longrightarrow> fresh a (Lam b t)" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
639 |
apply(tactic {* expand_tac @{thms fresh_def} *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
640 |
(*>*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
641 |
apply(tactic {* chop_test_tac [fresh_pred] fresh_rules @{context} *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
642 |
(*<*)oops(*>*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
643 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
644 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
645 |
gives |
209 | 646 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
647 |
\begin{isabelle} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
648 |
@{text "Params1 from the rule:"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
649 |
@{text "a, b, t"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
650 |
@{text "Params2 from the predicate:"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
651 |
@{text "fresh"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
652 |
@{text "Prems1 from the rule:"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
653 |
@{term "a \<noteq> b"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
654 |
@{text [break] |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
655 |
"\<forall>fresh. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
656 |
(\<forall>a b. a \<noteq> b \<longrightarrow> fresh a (Var b)) \<longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
657 |
(\<forall>a t s. fresh a t \<longrightarrow> fresh a s \<longrightarrow> fresh a (App t s)) \<longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
658 |
(\<forall>a t. fresh a (Lam a t)) \<longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
659 |
(\<forall>a b t. a \<noteq> b \<longrightarrow> fresh a t \<longrightarrow> fresh a (Lam b t)) \<longrightarrow> fresh a t"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
660 |
@{text "Prems2 from the predicate:"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
661 |
@{term "\<forall>a b. a \<noteq> b \<longrightarrow> fresh a (Var b)"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
662 |
@{term "\<forall>a t s. fresh a t \<longrightarrow> fresh a s \<longrightarrow> fresh a (App t s)"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
663 |
@{term "\<forall>a t. fresh a (Lam a t)"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
664 |
@{term "\<forall>a b t. a \<noteq> b \<longrightarrow> fresh a t \<longrightarrow> fresh a (Lam b t)"} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
665 |
\end{isabelle} |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
666 |
|
192 | 667 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
668 |
We now have to select from @{text prems2} the premise |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
669 |
that corresponds to the introduction rule we prove, namely: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
670 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
671 |
@{term [display] "\<forall>a t s. fresh a t \<longrightarrow> fresh a s \<longrightarrow> fresh a (App t s)"} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
672 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
673 |
To use this premise with @{ML rtac}, we need to instantiate its |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
674 |
quantifiers (with @{text params1}) and transform it into a |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
675 |
introduction rule (using @{ML "ObjectLogic.rulify"}. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
676 |
So we can modify the subproof as follows: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
677 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
678 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
679 |
ML{*fun apply_prem_tac i preds rules = |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
680 |
SUBPROOF_test (fn {params, prems, context, ...} => |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
681 |
let |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
682 |
val (params1, params2) = chop (length params - length preds) params |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
683 |
val (prems1, prems2) = chop (length prems - length rules) prems |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
684 |
in |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
685 |
rtac (ObjectLogic.rulify (all_elims params1 (nth prems2 i))) 1 |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
686 |
THEN print_tac "" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
687 |
THEN no_tac |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
688 |
end) *} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
689 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
690 |
text {* and apply it with *} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
691 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
692 |
(*<*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
693 |
lemma fresh_App: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
694 |
shows "\<And>a b t. \<lbrakk>a \<noteq> b; fresh a t\<rbrakk> \<Longrightarrow> fresh a (Lam b t)" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
695 |
apply(tactic {* expand_tac @{thms fresh_def} *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
696 |
(*>*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
697 |
apply(tactic {* apply_prem_tac 3 [fresh_pred] fresh_rules @{context} *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
698 |
(*<*)oops(*>*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
699 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
700 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
701 |
Since we print out the goal state after the @{ML rtac} we can see |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
702 |
the goal state has the two subgoals |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
703 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
704 |
\begin{isabelle} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
705 |
@{text "1."}~@{prop "a \<noteq> b"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
706 |
@{text "2."}~@{prop "fresh a t"} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
707 |
\end{isabelle} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
708 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
709 |
where the first comes from a non-recursive precondition of the rule |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
710 |
and the second comes from a recursive precondition. The first kind |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
711 |
can be solved immediately by @{text "prems1"}. The second kind |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
712 |
needs more work. It can be solved with the other premise in @{text "prems1"}, |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
713 |
namely |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
714 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
715 |
@{term [break,display] |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
716 |
"\<forall>fresh. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
717 |
(\<forall>a b. a \<noteq> b \<longrightarrow> fresh a (Var b)) \<longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
718 |
(\<forall>a t s. fresh a t \<longrightarrow> fresh a s \<longrightarrow> fresh a (App t s)) \<longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
719 |
(\<forall>a t. fresh a (Lam a t)) \<longrightarrow> |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
720 |
(\<forall>a b t. a \<noteq> b \<longrightarrow> fresh a t \<longrightarrow> fresh a (Lam b t)) \<longrightarrow> fresh a t"} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
721 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
722 |
but we have to instantiate it appropriately. These instantiations |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
723 |
come from @{text "params1"} and @{text "prems2"}. We can determine |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
724 |
whether we are in the simple or complicated case by checking whether |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
725 |
the topmost connective is @{text "\<forall>"}. The premises in the simple |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
726 |
case cannot have such a quantification, since in the first step |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
727 |
of @{ML "expand_tac"} was the ``rulification'' of the lemma. So |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
728 |
we can implement the following function |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
729 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
730 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
731 |
ML{*fun prepare_prem params2 prems2 prem = |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
732 |
rtac (case prop_of prem of |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
733 |
_ $ (Const (@{const_name All}, _) $ _) => |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
734 |
prem |> all_elims params2 |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
735 |
|> imp_elims prems2 |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
736 |
| _ => prem) *} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
737 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
738 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
739 |
which either applies the premise outright or if it had an |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
740 |
outermost universial quantification, instantiates it first with |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
741 |
@{text "params1"} and then @{text "prems1"}. The following tactic |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
742 |
will therefore prove the lemma. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
743 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
744 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
745 |
ML{*fun prove_intro_tac i preds rules = |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
746 |
SUBPROOF (fn {params, prems, context, ...} => |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
747 |
let |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
748 |
val (params1, params2) = chop (length params - length preds) params |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
749 |
val (prems1, prems2) = chop (length prems - length rules) prems |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
750 |
in |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
751 |
rtac (ObjectLogic.rulify (all_elims params1 (nth prems2 i))) 1 |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
752 |
THEN EVERY1 (map (prepare_prem params2 prems2) prems1) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
753 |
end) *} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
754 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
755 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
756 |
We can complete the proof of the introduction rule now as follows: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
757 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
758 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
759 |
(*<*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
760 |
lemma fresh_App: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
761 |
shows "\<And>a b t. \<lbrakk>a \<noteq> b; fresh a t\<rbrakk> \<Longrightarrow> fresh a (Lam b t)" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
762 |
apply(tactic {* expand_tac @{thms fresh_def} *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
763 |
(*>*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
764 |
apply(tactic {* prove_intro_tac 3 [fresh_pred] fresh_rules @{context} 1 *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
765 |
done |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
766 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
767 |
text {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
768 |
Unfortunately, not everything is done yet. |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
769 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
770 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
771 |
lemma accpartI: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
772 |
shows "\<And>x. (\<And>y. R y x \<Longrightarrow> accpart R y) \<Longrightarrow> accpart R x" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
773 |
apply(tactic {* expand_tac @{thms accpart_def} *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
774 |
apply(tactic {* chop_test_tac [acc_pred] acc_rules @{context} *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
775 |
apply(tactic {* apply_prem_tac 0 [acc_pred] acc_rules @{context} *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
776 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
777 |
txt {* |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
778 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
779 |
@{subgoals [display]} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
780 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
781 |
\begin{isabelle} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
782 |
@{text "Params1 from the rule:"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
783 |
@{text "x"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
784 |
@{text "Params2 from the predicate:"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
785 |
@{text "P"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
786 |
@{text "Prems1 from the rule:"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
787 |
@{text "R ?y x \<Longrightarrow> \<forall>P. (\<forall>x. (\<forall>y. R y x \<longrightarrow> P y) \<longrightarrow> P x) \<longrightarrow> P ?y"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
788 |
@{text "Prems2 from the predicate:"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
789 |
@{term "\<forall>x. (\<forall>y. R y x \<longrightarrow> P y) \<longrightarrow> P x"}\\ |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
790 |
\end{isabelle} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
791 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
792 |
*} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
793 |
(*<*)oops(*>*) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
794 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
795 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
796 |
ML{*fun prepare_prem params2 prems2 ctxt prem = |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
797 |
SUBPROOF (fn {prems, ...} => |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
798 |
let |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
799 |
val prem' = prems MRS prem |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
800 |
in |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
801 |
rtac (case prop_of prem' of |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
802 |
_ $ (Const (@{const_name All}, _) $ _) => |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
803 |
prem' |> all_elims params2 |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
804 |
|> imp_elims prems2 |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
805 |
| _ => prem') 1 |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
806 |
end) ctxt *} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
807 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
808 |
ML{*fun prove_intro_tac i preds rules = |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
809 |
SUBPROOF (fn {params, prems, context, ...} => |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
810 |
let |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
811 |
val (params1, params2) = chop (length params - length preds) params |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
812 |
val (prems1, prems2) = chop (length prems - length rules) prems |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
813 |
in |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
814 |
rtac (ObjectLogic.rulify (all_elims params1 (nth prems2 i))) 1 |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
815 |
THEN EVERY1 (map (prepare_prem params2 prems2 context) prems1) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
816 |
end) *} |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
817 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
818 |
lemma accpartI: |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
819 |
shows "\<And>x. (\<And>y. R y x \<Longrightarrow> accpart R y) \<Longrightarrow> accpart R x" |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
820 |
apply(tactic {* expand_tac @{thms accpart_def} *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
821 |
apply(tactic {* prove_intro_tac 0 [acc_pred] acc_rules @{context} 1 *}) |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
822 |
done |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
823 |
|
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
824 |
|
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
825 |
|
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
826 |
text {* |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
827 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
828 |
*} |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
829 |
|
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
830 |
ML{* |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
831 |
fun intros_tac defs rules preds i ctxt = |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
832 |
EVERY1 [ObjectLogic.rulify_tac, |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
833 |
K (rewrite_goals_tac defs), |
184 | 834 |
REPEAT o (resolve_tac [@{thm allI}, @{thm impI}]), |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
835 |
prove_intro_tac i preds rules ctxt]*} |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
836 |
|
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
837 |
text {* |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
838 |
A test case |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
839 |
*} |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
840 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
841 |
ML{*fun intros_tac_test ctxt i = |
208
0634d42bb69f
a bit more work on the simple-inductive package
Christian Urban <urbanc@in.tum.de>
parents:
194
diff
changeset
|
842 |
intros_tac eo_defs eo_rules eo_preds i ctxt *} |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
843 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
844 |
lemma intro0: |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
845 |
shows "even 0" |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
846 |
apply(tactic {* intros_tac_test @{context} 0 *}) |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
847 |
done |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
848 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
849 |
lemma intro1: |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
850 |
shows "\<And>m. odd m \<Longrightarrow> even (Suc m)" |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
851 |
apply(tactic {* intros_tac_test @{context} 1 *}) |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
852 |
done |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
853 |
|
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
854 |
lemma intro2: |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
855 |
shows "\<And>m. even m \<Longrightarrow> odd (Suc m)" |
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
856 |
apply(tactic {* intros_tac_test @{context} 2 *}) |
173
d820cb5873ea
used latex package boxedminipage
Christian Urban <urbanc@in.tum.de>
parents:
165
diff
changeset
|
857 |
done |
d820cb5873ea
used latex package boxedminipage
Christian Urban <urbanc@in.tum.de>
parents:
165
diff
changeset
|
858 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
859 |
ML{*fun intros rules preds defs lthy = |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
860 |
let |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
861 |
fun prove_intro (i, goal) = |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
862 |
Goal.prove lthy [] [] goal |
190
ca0ac2e75f6d
more one the simple-inductive chapter
Christian Urban <urbanc@in.tum.de>
parents:
189
diff
changeset
|
863 |
(fn {context, ...} => intros_tac defs rules preds i context) |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
864 |
in |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
865 |
map_index prove_intro rules |
164
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
866 |
end*} |
3f617d7a2691
more work on simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
163
diff
changeset
|
867 |
|
176
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
868 |
text {* main internal function *} |
3da5f3f07d8b
updated to new read_specification
Christian Urban <urbanc@in.tum.de>
parents:
173
diff
changeset
|
869 |
|
186
371e4375c994
made the Ackermann function example safer and included suggestions from MW
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
870 |
ML %linenosgray{*fun add_inductive pred_specs rule_specs lthy = |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
871 |
let |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
872 |
val syns = map snd pred_specs |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
873 |
val pred_specs' = map fst pred_specs |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
874 |
val prednames = map fst pred_specs' |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
875 |
val preds = map (fn (p, ty) => Free (Binding.name_of p, ty)) pred_specs' |
163
2319cff107f0
removed rep_ss, and used dest_ss instead; some very slight changes to simple_inductive
Christian Urban <urbanc@in.tum.de>
parents:
124
diff
changeset
|
876 |
|
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
877 |
val tyss = map (binder_types o fastype_of) preds |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
878 |
val (attrs, rules) = split_list rule_specs |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
879 |
|
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
880 |
val (defs, lthy') = defns rules preds prednames syns tyss lthy |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
881 |
val ind_rules = inds rules defs preds tyss lthy' |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
882 |
val intro_rules = intros rules preds defs lthy' |
91
667a0943c40b
added a section that will eventually describe the code
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
883 |
|
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
884 |
val mut_name = space_implode "_" (map Binding.name_of prednames) |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
885 |
val case_names = map (Binding.name_of o fst) attrs |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
886 |
in |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
887 |
lthy' |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
888 |
|> LocalTheory.notes Thm.theoremK (map (fn (((a, atts), _), th) => |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
889 |
((Binding.qualify false mut_name a, atts), [([th], [])])) (rule_specs ~~ intro_rules)) |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
890 |
|-> (fn intross => LocalTheory.note Thm.theoremK |
186
371e4375c994
made the Ackermann function example safer and included suggestions from MW
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
891 |
((Binding.qualify false mut_name (@{binding "intros"}), []), maps snd intross)) |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
892 |
|>> snd |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
893 |
||>> (LocalTheory.notes Thm.theoremK (map (fn (((R, _), _), th) => |
186
371e4375c994
made the Ackermann function example safer and included suggestions from MW
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
894 |
((Binding.qualify false (Binding.name_of R) (@{binding "induct"}), |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
895 |
[Attrib.internal (K (RuleCases.case_names case_names)), |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
896 |
Attrib.internal (K (RuleCases.consumes 1)), |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
897 |
Attrib.internal (K (Induct.induct_pred ""))]), [([th], [])])) |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
898 |
(pred_specs ~~ ind_rules)) #>> maps snd) |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
899 |
|> snd |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
900 |
end*} |
91
667a0943c40b
added a section that will eventually describe the code
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
901 |
|
186
371e4375c994
made the Ackermann function example safer and included suggestions from MW
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
902 |
ML{*fun add_inductive_cmd pred_specs rule_specs lthy = |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
903 |
let |
183
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
904 |
val ((pred_specs', rule_specs'), _) = |
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
Christian Urban <urbanc@in.tum.de>
parents:
180
diff
changeset
|
905 |
Specification.read_spec pred_specs rule_specs lthy |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
906 |
in |
186
371e4375c994
made the Ackermann function example safer and included suggestions from MW
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
907 |
add_inductive pred_specs' rule_specs' lthy |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
908 |
end*} |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
909 |
|
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
910 |
ML{*val spec_parser = |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
911 |
OuterParse.fixes -- |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
912 |
Scan.optional |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
913 |
(OuterParse.$$$ "where" |-- |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
914 |
OuterParse.!!! |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
915 |
(OuterParse.enum1 "|" |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
916 |
(SpecParse.opt_thm_name ":" -- OuterParse.prop))) []*} |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
917 |
|
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
918 |
ML{*val specification = |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
919 |
spec_parser >> |
186
371e4375c994
made the Ackermann function example safer and included suggestions from MW
Christian Urban <urbanc@in.tum.de>
parents:
185
diff
changeset
|
920 |
(fn ((pred_specs), rule_specs) => add_inductive_cmd pred_specs rule_specs)*} |
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
921 |
|
185 | 922 |
ML{*val _ = OuterSyntax.local_theory "simple_inductive" |
923 |
"define inductive predicates" |
|
924 |
OuterKeyword.thy_decl specification*} |
|
91
667a0943c40b
added a section that will eventually describe the code
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
925 |
|
124
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
926 |
text {* |
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
927 |
Things to include at the end: |
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
928 |
|
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
929 |
\begin{itemize} |
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
930 |
\item say something about add-inductive-i to return |
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
931 |
the rules |
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
932 |
\item say that the induction principle is weaker (weaker than |
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
933 |
what the standard inductive package generates) |
192 | 934 |
\item say that no conformity test is done |
210
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
935 |
\item exercise about strong induction principles |
db8e302f44c8
more work on the simple inductive section
Christian Urban <urbanc@in.tum.de>
parents:
209
diff
changeset
|
936 |
\item exercise about the test for the intro rules |
124
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
937 |
\end{itemize} |
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
938 |
|
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
939 |
*} |
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
940 |
|
165
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
941 |
simple_inductive |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
942 |
Even and Odd |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
943 |
where |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
944 |
Even0: "Even 0" |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
945 |
| EvenS: "Odd n \<Longrightarrow> Even (Suc n)" |
890fbfef6d6b
partially adapted to new antiquotation infrastructure
Christian Urban <urbanc@in.tum.de>
parents:
164
diff
changeset
|
946 |
| OddS: "Even n \<Longrightarrow> Odd (Suc n)" |
124
0b9fa606a746
added to the first-steps section
Christian Urban <urbanc@in.tum.de>
parents:
118
diff
changeset
|
947 |
|
91
667a0943c40b
added a section that will eventually describe the code
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
948 |
end |