| 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: 
209diff
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: 
209diff
changeset | 5 | section {* The Gory Details *} 
 | 
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 6 | |
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 7 | subsection {* Definitions *}
 | 
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 8 | |
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
177diff
changeset | 11 | |
| 
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
 Christian Urban <urbanc@in.tum.de> parents: 
177diff
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: 
177diff
changeset | 13 | |
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
189diff
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: 
180diff
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: 
177diff
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: 
177diff
changeset | 18 | *} | 
| 
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
 Christian Urban <urbanc@in.tum.de> parents: 
177diff
changeset | 19 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
163diff
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: 
177diff
changeset | 22 | val arg = ((predname, syn), (Attrib.empty_binding, trm)) | 
| 176 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
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: 
163diff
changeset | 24 | in | 
| 176 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 25 | (thm, lthy') | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 26 | end*} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 27 | |
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 28 | text {*
 | 
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
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: 
209diff
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: 
173diff
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: 
180diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 36 | function is | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 37 | *} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
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: 
177diff
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: 
177diff
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: 
209diff
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: 
177diff
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: 
177diff
changeset | 45 | end *} | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 46 | |
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 47 | text {*
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
194diff
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: 
194diff
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: 
180diff
changeset | 51 |   command \isacommand{thm}:
 | 
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 52 | |
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 53 |   \begin{isabelle}
 | 
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 54 |   \isacommand{thm}~@{text "MyTrue_def"}\\
 | 
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 55 |   @{text "> MyTrue \<equiv> True"}
 | 
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 56 |   \end{isabelle}
 | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 57 | |
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
194diff
changeset | 59 | which are terms of the form | 
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 60 | |
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
178diff
changeset | 62 | |
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
194diff
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: 
194diff
changeset | 65 | "preds"}. | 
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 66 | |
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
changeset | 67 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
189diff
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: 
194diff
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: 
163diff
changeset | 72 | *} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 73 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
163diff
changeset | 75 | let | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
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: 
163diff
changeset | 77 | |
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 78 | val fresh_args = | 
| 176 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 79 | arg_tys | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 80 | |> map (pair "z") | 
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 81 | |> Variable.variant_frees lthy (preds @ orules) | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 82 | |> map Free | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 83 | in | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 84 | list_comb (pred, fresh_args) | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 85 | |> fold_rev (curry HOLogic.mk_imp) orules | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 86 | |> fold_rev mk_all preds | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 87 | |> fold_rev lambda fresh_args | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 88 | end*} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 89 | |
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
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: 
189diff
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: 
189diff
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: 
163diff
changeset | 98 | |
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
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: 
180diff
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: 
180diff
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: 
194diff
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: 
189diff
changeset | 103 | predicate. A testcase for this function is | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 104 | *} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 105 | |
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 106 | local_setup %gray{* fn lthy =>
 | 
| 176 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 107 | let | 
| 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 108 |   val pred = @{term "even::nat\<Rightarrow>bool"}
 | 
| 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 109 |   val arg_tys = [@{typ "nat"}]
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
165diff
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: 
177diff
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: 
178diff
changeset | 113 | end *} | 
| 173 
d820cb5873ea
used latex package boxedminipage
 Christian Urban <urbanc@in.tum.de> parents: 
165diff
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: 
209diff
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: 
194diff
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: 
178diff
changeset | 118 | |
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 119 |   @{text [display] 
 | 
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
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: 
178diff
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: 
178diff
changeset | 122 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 124 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 125 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 126 | local_setup %gray{* fn lthy =>
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 127 | (warning (Syntax.string_of_term lthy | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 129 | lthy) *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 130 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 131 | text {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 132 | we obtain | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 133 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 134 |   @{term [display] 
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 139 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 140 | |
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
209diff
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: 
163diff
changeset | 147 | *} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 148 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
163diff
changeset | 150 | let | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 151 | val thy = ProofContext.theory_of lthy | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
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: 
209diff
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: 
163diff
changeset | 154 | in | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 155 | fold_map make_defn (prednames ~~ syns ~~ defs) lthy | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 156 | end*} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 157 | |
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
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: 
209diff
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: 
189diff
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: 
189diff
changeset | 168 | this function is | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 169 | *} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 170 | |
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
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: 
177diff
changeset | 172 | let | 
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 173 | val (defs, lthy') = | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
177diff
changeset | 175 | in | 
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
178diff
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: 
177diff
changeset | 178 | |
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
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: 
178diff
changeset | 183 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 184 |   @{text [display, break]
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
177diff
changeset | 189 | |
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
194diff
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: 
209diff
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: 
209diff
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: 
194diff
changeset | 194 |   and @{text "odd"}.
 | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 195 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
194diff
changeset | 197 | the induction principles. | 
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 198 | *} | 
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 199 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 200 | subsection {* Induction Principles *}
 | 
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 201 | |
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 202 | text {*
 | 
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
178diff
changeset | 205 | *} | 
| 176 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 206 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
173diff
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: 
173diff
changeset | 212 | apply(unfold even_def) | 
| 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 213 | apply(drule spec[where x=P]) | 
| 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 214 | apply(drule spec[where x=Q]) | 
| 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 215 | apply(assumption) | 
| 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 216 | done | 
| 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 217 | |
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 218 | text {* 
 | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
189diff
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: 
180diff
changeset | 222 | |
| 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
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: 
178diff
changeset | 225 | *} | 
| 176 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 226 | |
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 227 | ML{*fun inst_spec ctrm = 
 | 
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
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: 
163diff
changeset | 229 | |
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
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: 
194diff
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: 
194diff
changeset | 233 | in the tactic: | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 234 | *} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 235 | |
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
changeset | 236 | ML{*fun inst_spec_tac ctrms = 
 | 
| 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
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: 
180diff
changeset | 238 | |
| 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
changeset | 239 | text {*
 | 
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
180diff
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: 
173diff
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: 
178diff
changeset | 249 | txt {* 
 | 
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
changeset | 250 | We obtain the goal state | 
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 251 | |
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 252 |   \begin{minipage}{\textwidth}
 | 
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 253 |   @{subgoals} 
 | 
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 254 |   \end{minipage}*}
 | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 255 | (*<*)oops(*>*) | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 256 | |
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 257 | text {*
 | 
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
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: 
180diff
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: 
124diff
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: 
124diff
changeset | 261 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 262 | ML %linenosgray{*fun ind_tac defs prem insts =
 | 
| 176 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
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: 
194diff
changeset | 264 | cut_facts_tac prem, | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 265 | K (rewrite_goals_tac defs), | 
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
changeset | 266 | inst_spec_tac insts, | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 267 | assume_tac]*} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 268 | |
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 269 | text {*
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
180diff
changeset | 276 | *} | 
| 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
changeset | 277 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
194diff
changeset | 279 | assumes prem: "even z" | 
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 283 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 284 | lemma automatic_ind_prin_fresh: | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 285 | assumes prem: "fresh z za" | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 291 |                     [@{cterm "P::string\<Rightarrow>trm\<Rightarrow>bool"}] *})
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 292 | |
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 293 | |
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 294 | text {*
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 310 | a goal of the form | 
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 311 | |
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 312 |   @{text [display] 
 | 
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
179diff
changeset | 314 | |
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
194diff
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: 
194diff
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: 
194diff
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: 
189diff
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: 
194diff
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: 
189diff
changeset | 321 | |
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
194diff
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: 
194diff
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: 
194diff
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: 
209diff
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: 
194diff
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: 
194diff
changeset | 328 | types of this predicate. | 
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 329 | *} | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 330 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
177diff
changeset | 332 | let | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
178diff
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: 
189diff
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: 
177diff
changeset | 336 | |
| 
fb8f22dd8ad0
adapted to latest Attrib.setup changes and more work on the simple induct chapter
 Christian Urban <urbanc@in.tum.de> parents: 
177diff
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: 
177diff
changeset | 338 | val goal = Logic.list_implies | 
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
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: 
177diff
changeset | 340 | in | 
| 179 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 341 | Goal.prove lthy' [] [prem] goal | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
178diff
changeset | 343 | |> singleton (ProofContext.export lthy' lthy) | 
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 344 | end *} | 
| 
75381fa516cd
more work on the simple-induct. chapter
 Christian Urban <urbanc@in.tum.de> parents: 
178diff
changeset | 345 | |
| 180 
9c25418db6f0
added a recipy about SAT solvers
 Christian Urban <urbanc@in.tum.de> parents: 
179diff
changeset | 346 | text {* 
 | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
180diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
194diff
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: 
189diff
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: 
189diff
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: 
180diff
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: 
180diff
changeset | 358 | mechanism will fail. | 
| 180 
9c25418db6f0
added a recipy about SAT solvers
 Christian Urban <urbanc@in.tum.de> parents: 
179diff
changeset | 359 | |
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
194diff
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: 
194diff
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: 
194diff
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: 
194diff
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: 
209diff
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: 
194diff
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: 
194diff
changeset | 369 | A testcase for this function is | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 370 | *} | 
| 180 
9c25418db6f0
added a recipy about SAT solvers
 Christian Urban <urbanc@in.tum.de> parents: 
179diff
changeset | 371 | |
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 372 | local_setup %gray{* fn lthy =>
 | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 373 | let | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
189diff
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: 
209diff
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: 
189diff
changeset | 377 |   val newpred = @{term "P::nat\<Rightarrow>bool"}
 | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 378 | val intro = | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
189diff
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: 
209diff
changeset | 382 | end *} | 
| 184 | 383 | |
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 384 | text {*
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 385 | This prints out the theorem: | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 386 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 387 |   @{text [display]
 | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
189diff
changeset | 389 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
194diff
changeset | 393 | schematic. | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 394 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
209diff
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: 
194diff
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: 
179diff
changeset | 398 | *} | 
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 399 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
163diff
changeset | 401 | let | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
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: 
180diff
changeset | 403 | val (newprednames, lthy') = Variable.variant_fixes Ps lthy | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 404 | |
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
changeset | 405 | val thy = ProofContext.theory_of lthy' | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
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: 
164diff
changeset | 408 | val newpreds = map Free (newprednames ~~ tyss') | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
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: 
163diff
changeset | 411 | |
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 412 | in | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
180diff
changeset | 415 | |> ProofContext.export lthy' lthy | 
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 416 | end*} | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 417 | |
| 184 | 418 | text {*
 | 
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
189diff
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: 
194diff
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: 
189diff
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: 
189diff
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: 
189diff
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: 
189diff
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: 
194diff
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: 
209diff
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: 
189diff
changeset | 441 | end *} | 
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 442 | |
| 176 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
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: 
209diff
changeset | 448 | "even ?z \<Longrightarrow> ?P1 0 \<Longrightarrow> | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 450 | odd ?z \<Longrightarrow> ?P1 0 \<Longrightarrow> | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
194diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
194diff
changeset | 459 | *} | 
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 460 | |
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 461 | subsection {* Introduction Rules *}
 | 
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 462 | |
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 463 | text {*
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
194diff
changeset | 467 | functions. | 
| 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 468 | |
| 184 | 469 | *} | 
| 470 | ||
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
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: 
164diff
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: 
164diff
changeset | 473 | |
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 474 | text {* 
 | 
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
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: 
189diff
changeset | 476 | theorems. | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 477 | *} | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 478 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 479 | lemma all_elims_test: | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
189diff
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: 
189diff
changeset | 482 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 483 | lemma imp_elims_test: | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 484 | shows "A \<longrightarrow> B \<longrightarrow> C" sorry | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 485 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 486 | lemma imp_elims_test': | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 487 | shows "A" "B" sorry | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 488 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 489 | text {*
 | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
189diff
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: 
209diff
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: 
189diff
changeset | 493 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 494 |   @{ML_response_fake [display, gray]
 | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 495 | "let | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
189diff
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: 
189diff
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: 
189diff
changeset | 500 | end" | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 501 | "P a b c"} | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 502 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
209diff
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: 
209diff
changeset | 505 |   @{thm [source] imp_elims_test}:
 | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 506 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
189diff
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: 
189diff
changeset | 510 | "C"} | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 511 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 513 | the rule: | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 514 | |
| 209 | 515 |   \begin{isabelle}
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
189diff
changeset | 520 | *} | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 521 | |
| 192 | 522 | lemma fresh_App: | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 524 | (*<*)oops(*>*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 525 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 526 | text {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 529 | will use the tactic | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 530 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 531 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 532 | ML{*fun expand_tac defs =
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 533 | ObjectLogic.rulify_tac 1 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 534 | THEN rewrite_goals_tac defs | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 536 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 537 | text {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 539 | later on. Applying this tactic | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 540 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 541 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 542 | (*<*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 543 | lemma fresh_App: | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 545 | (*>*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 549 | we end up in the goal state | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 550 | |
| 209 | 551 |   \begin{isabelle}
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 552 |   @{subgoals [display]}
 | 
| 209 | 553 |   \end{isabelle}
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 554 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 559 | Similarly, there are preconditions | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 561 | definition. We need to treat these | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 566 |   @{ML SUBPROOF}, since this tactic provides us
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 572 | we use the following modified tactic: | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 573 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 574 | (*<*)oops(*>*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 576 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 577 | text {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 580 | all necessary proof steps. | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 581 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 582 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 583 | text_raw {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 584 | \begin{figure}[t]
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 585 | \begin{minipage}{\textwidth}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 586 | \begin{isabelle}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 587 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 589 | let | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 594 | in | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 595 | s |> separate "\n" | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 596 | |> implode | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 597 | |> warning | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 598 | end*} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 599 | text_raw{*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 600 | \end{isabelle}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 601 | \end{minipage}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 602 | \caption{FIXME\label{fig:chopprint}}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 603 | \end{figure}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 604 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 605 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 606 | text {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 612 |   separate them using the function @{ML chop}. 
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 613 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 614 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 615 | ML{*fun chop_test_tac preds rules =
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 616 |   SUBPROOF_test (fn {params, prems, context, ...} =>
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 617 | let | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 620 | in | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 622 | end) *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 623 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 624 | text {* 
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 636 | (*<*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 637 | lemma fresh_App: | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 639 | apply(tactic {* expand_tac @{thms fresh_def} *})
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 640 | (*>*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 642 | (*<*)oops(*>*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 643 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 644 | text {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 645 | gives | 
| 209 | 646 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 647 |   \begin{isabelle}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 648 |   @{text "Params1 from the rule:"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 649 |   @{text "a, b, t"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 650 |   @{text "Params2 from the predicate:"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 651 |   @{text "fresh"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 652 |   @{text "Prems1 from the rule:"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 653 |   @{term "a \<noteq> b"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 654 |   @{text [break]
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 655 | "\<forall>fresh. | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 660 |    @{text "Prems2 from the predicate:"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 665 |   \end{isabelle}
 | 
| 208 
0634d42bb69f
a bit more work on the simple-inductive package
 Christian Urban <urbanc@in.tum.de> parents: 
194diff
changeset | 666 | |
| 192 | 667 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 670 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 672 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 675 |   introduction rule (using @{ML "ObjectLogic.rulify"}. 
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 677 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 678 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 680 |   SUBPROOF_test (fn {params, prems, context, ...} =>
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 681 | let | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 684 | in | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 686 | THEN print_tac "" | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 687 | THEN no_tac | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 688 | end) *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 689 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 690 | text {* and apply it with *}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 691 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 692 | (*<*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 693 | lemma fresh_App: | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 695 | apply(tactic {* expand_tac @{thms fresh_def} *})
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 696 | (*>*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 698 | (*<*)oops(*>*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 699 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 700 | text {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 702 | the goal state has the two subgoals | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 703 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 704 |   \begin{isabelle}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 705 |   @{text "1."}~@{prop "a \<noteq> b"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 706 |   @{text "2."}~@{prop "fresh a t"}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 707 |   \end{isabelle}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 708 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 713 | namely | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 714 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 715 |   @{term [break,display]
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 716 | "\<forall>fresh. | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 721 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
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: 
209diff
changeset | 728 | we can implement the following function | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 729 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 730 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 731 | ML{*fun prepare_prem params2 prems2 prem =  
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 732 | rtac (case prop_of prem of | 
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 733 |            _ $ (Const (@{const_name All}, _) $ _) =>
 | 
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 734 | prem |> all_elims params2 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 735 | |> imp_elims prems2 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 736 | | _ => prem) *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 737 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 738 | text {* 
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 740 | outermost universial quantification, instantiates it first with | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 742 | will therefore prove the lemma. | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 743 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 744 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 746 |   SUBPROOF (fn {params, prems, context, ...} =>
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 747 | let | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 750 | in | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 753 | end) *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 754 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 755 | text {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 757 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 758 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 759 | (*<*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 760 | lemma fresh_App: | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 762 | apply(tactic {* expand_tac @{thms fresh_def} *})
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 763 | (*>*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 765 | done | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 766 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 767 | text {* 
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 768 | Unfortunately, not everything is done yet. | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 769 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 770 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 771 | lemma accpartI: | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 773 | apply(tactic {* expand_tac @{thms accpart_def} *})
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 776 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 777 | txt {*
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 778 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 779 |   @{subgoals [display]}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 780 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 781 |   \begin{isabelle}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 782 |   @{text "Params1 from the rule:"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 783 |   @{text "x"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 784 |   @{text "Params2 from the predicate:"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 785 |   @{text "P"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 786 |   @{text "Prems1 from the rule:"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 788 |   @{text "Prems2 from the predicate:"}\\
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 790 |   \end{isabelle}
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 791 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 792 | *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 793 | (*<*)oops(*>*) | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 794 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 795 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 797 |   SUBPROOF (fn {prems, ...} =>
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 798 | let | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 799 | val prem' = prems MRS prem | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 800 | in | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 801 | rtac (case prop_of prem' of | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 802 |            _ $ (Const (@{const_name All}, _) $ _) =>
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 803 | prem' |> all_elims params2 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 804 | |> imp_elims prems2 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 805 | | _ => prem') 1 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 806 | end) ctxt *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 807 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 809 |   SUBPROOF (fn {params, prems, context, ...} =>
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 810 | let | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 813 | in | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
changeset | 816 | end) *} | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 817 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 818 | lemma accpartI: | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 820 | apply(tactic {* expand_tac @{thms accpart_def} *})
 | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
changeset | 822 | done | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 823 | |
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 824 | |
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 825 | |
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 826 | text {*
 | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 827 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 828 | *} | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 829 | |
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 830 | ML{*
 | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
164diff
changeset | 832 | EVERY1 [ObjectLogic.rulify_tac, | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
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: 
209diff
changeset | 835 | prove_intro_tac i preds rules ctxt]*} | 
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 836 | |
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 837 | text {*
 | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 838 | A test case | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 839 | *} | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 840 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
194diff
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: 
189diff
changeset | 843 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 844 | lemma intro0: | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 845 | shows "even 0" | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 846 | apply(tactic {* intros_tac_test @{context} 0 *})
 | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 847 | done | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 848 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 849 | lemma intro1: | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
189diff
changeset | 851 | apply(tactic {* intros_tac_test @{context} 1 *})
 | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 852 | done | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 853 | |
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
changeset | 854 | lemma intro2: | 
| 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
189diff
changeset | 856 | apply(tactic {* intros_tac_test @{context} 2 *})
 | 
| 173 
d820cb5873ea
used latex package boxedminipage
 Christian Urban <urbanc@in.tum.de> parents: 
165diff
changeset | 857 | done | 
| 
d820cb5873ea
used latex package boxedminipage
 Christian Urban <urbanc@in.tum.de> parents: 
165diff
changeset | 858 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
changeset | 859 | ML{*fun intros rules preds defs lthy = 
 | 
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 860 | let | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 861 | fun prove_intro (i, goal) = | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 862 | Goal.prove lthy [] [] goal | 
| 190 
ca0ac2e75f6d
more one the simple-inductive chapter
 Christian Urban <urbanc@in.tum.de> parents: 
189diff
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: 
164diff
changeset | 864 | in | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 865 | map_index prove_intro rules | 
| 164 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 866 | end*} | 
| 
3f617d7a2691
more work on simple_inductive
 Christian Urban <urbanc@in.tum.de> parents: 
163diff
changeset | 867 | |
| 176 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 868 | text {* main internal function *}
 | 
| 
3da5f3f07d8b
updated to new read_specification
 Christian Urban <urbanc@in.tum.de> parents: 
173diff
changeset | 869 | |
| 186 
371e4375c994
made the Ackermann function example safer and included suggestions from MW
 Christian Urban <urbanc@in.tum.de> parents: 
185diff
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: 
164diff
changeset | 871 | let | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 872 | val syns = map snd pred_specs | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 873 | val pred_specs' = map fst pred_specs | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 874 | val prednames = map fst pred_specs' | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
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: 
124diff
changeset | 876 | |
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
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: 
164diff
changeset | 878 | val (attrs, rules) = split_list rule_specs | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 879 | |
| 210 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
209diff
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: 
209diff
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: 
164diff
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: 
164diff
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: 
164diff
changeset | 886 | in | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 887 | lthy' | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
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: 
164diff
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: 
164diff
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: 
185diff
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: 
164diff
changeset | 892 | |>> snd | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
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: 
185diff
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: 
164diff
changeset | 895 | [Attrib.internal (K (RuleCases.case_names case_names)), | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 896 | Attrib.internal (K (RuleCases.consumes 1)), | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 897 | Attrib.internal (K (Induct.induct_pred ""))]), [([th], [])])) | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 898 | (pred_specs ~~ ind_rules)) #>> maps snd) | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 899 | |> snd | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
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: 
185diff
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: 
164diff
changeset | 903 | let | 
| 183 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
changeset | 904 | val ((pred_specs', rule_specs'), _) = | 
| 
8bb4eaa2ec92
a simplification suggested by Stefan and some polishing
 Christian Urban <urbanc@in.tum.de> parents: 
180diff
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: 
164diff
changeset | 906 | in | 
| 186 
371e4375c994
made the Ackermann function example safer and included suggestions from MW
 Christian Urban <urbanc@in.tum.de> parents: 
185diff
changeset | 907 | add_inductive pred_specs' rule_specs' lthy | 
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 908 | end*} | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 909 | |
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 910 | ML{*val spec_parser = 
 | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 911 | OuterParse.fixes -- | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 912 | Scan.optional | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 913 | (OuterParse.$$$ "where" |-- | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 914 | OuterParse.!!! | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 915 | (OuterParse.enum1 "|" | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 916 | (SpecParse.opt_thm_name ":" -- OuterParse.prop))) []*} | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 917 | |
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 918 | ML{*val specification =
 | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 919 | spec_parser >> | 
| 186 
371e4375c994
made the Ackermann function example safer and included suggestions from MW
 Christian Urban <urbanc@in.tum.de> parents: 
185diff
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: 
164diff
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: 
118diff
changeset | 926 | text {*
 | 
| 
0b9fa606a746
added to the first-steps section
 Christian Urban <urbanc@in.tum.de> parents: 
118diff
changeset | 927 | Things to include at the end: | 
| 
0b9fa606a746
added to the first-steps section
 Christian Urban <urbanc@in.tum.de> parents: 
118diff
changeset | 928 | |
| 
0b9fa606a746
added to the first-steps section
 Christian Urban <urbanc@in.tum.de> parents: 
118diff
changeset | 929 |   \begin{itemize}
 | 
| 
0b9fa606a746
added to the first-steps section
 Christian Urban <urbanc@in.tum.de> parents: 
118diff
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: 
118diff
changeset | 931 | the rules | 
| 
0b9fa606a746
added to the first-steps section
 Christian Urban <urbanc@in.tum.de> parents: 
118diff
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: 
118diff
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: 
209diff
changeset | 935 | \item exercise about strong induction principles | 
| 
db8e302f44c8
more work on the simple inductive section
 Christian Urban <urbanc@in.tum.de> parents: 
209diff
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: 
118diff
changeset | 937 |   \end{itemize}
 | 
| 
0b9fa606a746
added to the first-steps section
 Christian Urban <urbanc@in.tum.de> parents: 
118diff
changeset | 938 | |
| 
0b9fa606a746
added to the first-steps section
 Christian Urban <urbanc@in.tum.de> parents: 
118diff
changeset | 939 | *} | 
| 
0b9fa606a746
added to the first-steps section
 Christian Urban <urbanc@in.tum.de> parents: 
118diff
changeset | 940 | |
| 165 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 941 | simple_inductive | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 942 | Even and Odd | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 943 | where | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 944 | Even0: "Even 0" | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 945 | | EvenS: "Odd n \<Longrightarrow> Even (Suc n)" | 
| 
890fbfef6d6b
partially adapted to new antiquotation infrastructure
 Christian Urban <urbanc@in.tum.de> parents: 
164diff
changeset | 946 | | OddS: "Even n \<Longrightarrow> Odd (Suc n)" | 
| 124 
0b9fa606a746
added to the first-steps section
 Christian Urban <urbanc@in.tum.de> parents: 
118diff
changeset | 947 | |
| 91 
667a0943c40b
added a section that will eventually describe the code
 Christian Urban <urbanc@in.tum.de> parents: diff
changeset | 948 | end |