| author | haftmann | 
| Wed, 11 Aug 2010 13:31:29 +0200 | |
| changeset 38343 | e5418eec375c | 
| parent 36452 | d37c6eed8117 | 
| child 40004 | 9f6ed6840e8d | 
| permissions | -rw-r--r-- | 
| 2640 | 1 | (* Title: HOLCF/Fix.thy | 
| 1479 | 2 | Author: Franz Regensburger | 
| 35794 | 3 | Author: Brian Huffman | 
| 243 
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
 nipkow parents: diff
changeset | 4 | *) | 
| 
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
 nipkow parents: diff
changeset | 5 | |
| 15577 | 6 | header {* Fixed point operator and admissibility *}
 | 
| 7 | ||
| 8 | theory Fix | |
| 35939 | 9 | imports Cfun | 
| 15577 | 10 | begin | 
| 243 
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
 nipkow parents: diff
changeset | 11 | |
| 36452 | 12 | default_sort pcpo | 
| 16082 | 13 | |
| 18093 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 14 | subsection {* Iteration *}
 | 
| 16005 | 15 | |
| 34941 | 16 | primrec iterate :: "nat \<Rightarrow> ('a::cpo \<rightarrow> 'a) \<rightarrow> ('a \<rightarrow> 'a)" where
 | 
| 17 | "iterate 0 = (\<Lambda> F x. x)" | |
| 18 | | "iterate (Suc n) = (\<Lambda> F x. F\<cdot>(iterate n\<cdot>F\<cdot>x))" | |
| 5192 | 19 | |
| 18093 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 20 | text {* Derive inductive properties of iterate from primitive recursion *}
 | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 21 | |
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 22 | lemma iterate_0 [simp]: "iterate 0\<cdot>F\<cdot>x = x" | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 23 | by simp | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 24 | |
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 25 | lemma iterate_Suc [simp]: "iterate (Suc n)\<cdot>F\<cdot>x = F\<cdot>(iterate n\<cdot>F\<cdot>x)" | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 26 | by simp | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 27 | |
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 28 | declare iterate.simps [simp del] | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 29 | |
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 30 | lemma iterate_Suc2: "iterate (Suc n)\<cdot>F\<cdot>x = iterate n\<cdot>F\<cdot>(F\<cdot>x)" | 
| 27270 | 31 | by (induct n) simp_all | 
| 32 | ||
| 33 | lemma iterate_iterate: | |
| 34 | "iterate m\<cdot>F\<cdot>(iterate n\<cdot>F\<cdot>x) = iterate (m + n)\<cdot>F\<cdot>x" | |
| 35 | by (induct m) simp_all | |
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 36 | |
| 36075 
2e0370c03066
tuned proof (no induction needed); removed unused lemma and fuzzy comment
 krauss parents: 
35939diff
changeset | 37 | text {* The sequence of function iterations is a chain. *}
 | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 38 | |
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 39 | lemma chain_iterate [simp]: "chain (\<lambda>i. iterate i\<cdot>F\<cdot>\<bottom>)" | 
| 36075 
2e0370c03066
tuned proof (no induction needed); removed unused lemma and fuzzy comment
 krauss parents: 
35939diff
changeset | 40 | by (rule chainI, unfold iterate_Suc2, rule monofun_cfun_arg, rule minimal) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 41 | |
| 18093 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 42 | |
| 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 43 | subsection {* Least fixed point operator *}
 | 
| 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 44 | |
| 25131 
2c8caac48ade
modernized specifications ('definition', 'abbreviation', 'notation');
 wenzelm parents: 
18095diff
changeset | 45 | definition | 
| 
2c8caac48ade
modernized specifications ('definition', 'abbreviation', 'notation');
 wenzelm parents: 
18095diff
changeset | 46 |   "fix" :: "('a \<rightarrow> 'a) \<rightarrow> 'a" where
 | 
| 
2c8caac48ade
modernized specifications ('definition', 'abbreviation', 'notation');
 wenzelm parents: 
18095diff
changeset | 47 | "fix = (\<Lambda> F. \<Squnion>i. iterate i\<cdot>F\<cdot>\<bottom>)" | 
| 18093 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 48 | |
| 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 49 | text {* Binder syntax for @{term fix} *}
 | 
| 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 50 | |
| 27316 
9e74019041d4
use new-style abbreviation/notation for fix syntax
 huffman parents: 
27270diff
changeset | 51 | abbreviation | 
| 
9e74019041d4
use new-style abbreviation/notation for fix syntax
 huffman parents: 
27270diff
changeset | 52 |   fix_syn :: "('a \<Rightarrow> 'a) \<Rightarrow> 'a"  (binder "FIX " 10) where
 | 
| 
9e74019041d4
use new-style abbreviation/notation for fix syntax
 huffman parents: 
27270diff
changeset | 53 | "fix_syn (\<lambda>x. f x) \<equiv> fix\<cdot>(\<Lambda> x. f x)" | 
| 18093 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 54 | |
| 27316 
9e74019041d4
use new-style abbreviation/notation for fix syntax
 huffman parents: 
27270diff
changeset | 55 | notation (xsymbols) | 
| 
9e74019041d4
use new-style abbreviation/notation for fix syntax
 huffman parents: 
27270diff
changeset | 56 | fix_syn (binder "\<mu> " 10) | 
| 18093 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 57 | |
| 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 58 | text {* Properties of @{term fix} *}
 | 
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 59 | |
| 18090 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 60 | text {* direct connection between @{term fix} and iteration *}
 | 
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 61 | |
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 62 | lemma fix_def2: "fix\<cdot>F = (\<Squnion>i. iterate i\<cdot>F\<cdot>\<bottom>)" | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 63 | apply (unfold fix_def) | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 64 | apply (rule beta_cfun) | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 65 | apply (rule cont2cont_lub) | 
| 18092 
2c5d5da79a1e
renamed and added ch2ch, cont2cont, mono2mono theorems ending in _fun, _lambda, _LAM
 huffman parents: 
18090diff
changeset | 66 | apply (rule ch2ch_lambda) | 
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 67 | apply (rule chain_iterate) | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 68 | apply simp | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 69 | done | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 70 | |
| 35055 | 71 | lemma iterate_below_fix: "iterate n\<cdot>f\<cdot>\<bottom> \<sqsubseteq> fix\<cdot>f" | 
| 72 | unfolding fix_def2 | |
| 73 | using chain_iterate by (rule is_ub_thelub) | |
| 74 | ||
| 15637 
d2a06007ebfa
changed comments to text blocks, cleaned up a few proofs
 huffman parents: 
15577diff
changeset | 75 | text {*
 | 
| 
d2a06007ebfa
changed comments to text blocks, cleaned up a few proofs
 huffman parents: 
15577diff
changeset | 76 | Kleene's fixed point theorems for continuous functions in pointed | 
| 
d2a06007ebfa
changed comments to text blocks, cleaned up a few proofs
 huffman parents: 
15577diff
changeset | 77 | omega cpo's | 
| 
d2a06007ebfa
changed comments to text blocks, cleaned up a few proofs
 huffman parents: 
15577diff
changeset | 78 | *} | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 79 | |
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 80 | lemma fix_eq: "fix\<cdot>F = F\<cdot>(fix\<cdot>F)" | 
| 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 81 | apply (simp add: fix_def2) | 
| 16005 | 82 | apply (subst lub_range_shift [of _ 1, symmetric]) | 
| 83 | apply (rule chain_iterate) | |
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 84 | apply (subst contlub_cfun_arg) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 85 | apply (rule chain_iterate) | 
| 16005 | 86 | apply simp | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 87 | done | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 88 | |
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 89 | lemma fix_least_below: "F\<cdot>x \<sqsubseteq> x \<Longrightarrow> fix\<cdot>F \<sqsubseteq> x" | 
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 90 | apply (simp add: fix_def2) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 91 | apply (rule is_lub_thelub) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 92 | apply (rule chain_iterate) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 93 | apply (rule ub_rangeI) | 
| 16005 | 94 | apply (induct_tac i) | 
| 95 | apply simp | |
| 96 | apply simp | |
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 97 | apply (erule rev_below_trans) | 
| 16214 | 98 | apply (erule monofun_cfun_arg) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 99 | done | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 100 | |
| 16214 | 101 | lemma fix_least: "F\<cdot>x = x \<Longrightarrow> fix\<cdot>F \<sqsubseteq> x" | 
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 102 | by (rule fix_least_below, simp) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 103 | |
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 104 | lemma fix_eqI: | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 105 | assumes fixed: "F\<cdot>x = x" and least: "\<And>z. F\<cdot>z = z \<Longrightarrow> x \<sqsubseteq> z" | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 106 | shows "fix\<cdot>F = x" | 
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 107 | apply (rule below_antisym) | 
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 108 | apply (rule fix_least [OF fixed]) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 109 | apply (rule least [OF fix_eq [symmetric]]) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 110 | done | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 111 | |
| 16214 | 112 | lemma fix_eq2: "f \<equiv> fix\<cdot>F \<Longrightarrow> f = F\<cdot>f" | 
| 15637 
d2a06007ebfa
changed comments to text blocks, cleaned up a few proofs
 huffman parents: 
15577diff
changeset | 113 | by (simp add: fix_eq [symmetric]) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 114 | |
| 16214 | 115 | lemma fix_eq3: "f \<equiv> fix\<cdot>F \<Longrightarrow> f\<cdot>x = F\<cdot>f\<cdot>x" | 
| 15637 
d2a06007ebfa
changed comments to text blocks, cleaned up a few proofs
 huffman parents: 
15577diff
changeset | 116 | by (erule fix_eq2 [THEN cfun_fun_cong]) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 117 | |
| 16214 | 118 | lemma fix_eq4: "f = fix\<cdot>F \<Longrightarrow> f = F\<cdot>f" | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 119 | apply (erule ssubst) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 120 | apply (rule fix_eq) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 121 | done | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 122 | |
| 16214 | 123 | lemma fix_eq5: "f = fix\<cdot>F \<Longrightarrow> f\<cdot>x = F\<cdot>f\<cdot>x" | 
| 124 | by (erule fix_eq4 [THEN cfun_fun_cong]) | |
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 125 | |
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 126 | text {* strictness of @{term fix} *}
 | 
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 127 | |
| 16917 | 128 | lemma fix_defined_iff: "(fix\<cdot>F = \<bottom>) = (F\<cdot>\<bottom> = \<bottom>)" | 
| 129 | apply (rule iffI) | |
| 130 | apply (erule subst) | |
| 131 | apply (rule fix_eq [symmetric]) | |
| 132 | apply (erule fix_least [THEN UU_I]) | |
| 133 | done | |
| 134 | ||
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 135 | lemma fix_strict: "F\<cdot>\<bottom> = \<bottom> \<Longrightarrow> fix\<cdot>F = \<bottom>" | 
| 16917 | 136 | by (simp add: fix_defined_iff) | 
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 137 | |
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 138 | lemma fix_defined: "F\<cdot>\<bottom> \<noteq> \<bottom> \<Longrightarrow> fix\<cdot>F \<noteq> \<bottom>" | 
| 16917 | 139 | by (simp add: fix_defined_iff) | 
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 140 | |
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 141 | text {* @{term fix} applied to identity and constant functions *}
 | 
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 142 | |
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 143 | lemma fix_id: "(\<mu> x. x) = \<bottom>" | 
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 144 | by (simp add: fix_strict) | 
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 145 | |
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 146 | lemma fix_const: "(\<mu> x. c) = c" | 
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 147 | by (subst fix_eq, simp) | 
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 148 | |
| 18090 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 149 | subsection {* Fixed point induction *}
 | 
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 150 | |
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 151 | lemma fix_ind: "\<lbrakk>adm P; P \<bottom>; \<And>x. P x \<Longrightarrow> P (F\<cdot>x)\<rbrakk> \<Longrightarrow> P (fix\<cdot>F)" | 
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 152 | unfolding fix_def2 | 
| 25925 | 153 | apply (erule admD) | 
| 18090 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 154 | apply (rule chain_iterate) | 
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 155 | apply (rule nat_induct, simp_all) | 
| 18090 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 156 | done | 
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 157 | |
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 158 | lemma def_fix_ind: | 
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 159 | "\<lbrakk>f \<equiv> fix\<cdot>F; adm P; P \<bottom>; \<And>x. P x \<Longrightarrow> P (F\<cdot>x)\<rbrakk> \<Longrightarrow> P f" | 
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 160 | by (simp add: fix_ind) | 
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 161 | |
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 162 | lemma fix_ind2: | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 163 | assumes adm: "adm P" | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 164 | assumes 0: "P \<bottom>" and 1: "P (F\<cdot>\<bottom>)" | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 165 | assumes step: "\<And>x. \<lbrakk>P x; P (F\<cdot>x)\<rbrakk> \<Longrightarrow> P (F\<cdot>(F\<cdot>x))" | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 166 | shows "P (fix\<cdot>F)" | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 167 | unfolding fix_def2 | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 168 | apply (rule admD [OF adm chain_iterate]) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 169 | apply (rule nat_less_induct) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 170 | apply (case_tac n) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 171 | apply (simp add: 0) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 172 | apply (case_tac nat) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 173 | apply (simp add: 1) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 174 | apply (frule_tac x=nat in spec) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 175 | apply (simp add: step) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 176 | done | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 177 | |
| 33590 | 178 | lemma parallel_fix_ind: | 
| 179 | assumes adm: "adm (\<lambda>x. P (fst x) (snd x))" | |
| 180 | assumes base: "P \<bottom> \<bottom>" | |
| 181 | assumes step: "\<And>x y. P x y \<Longrightarrow> P (F\<cdot>x) (G\<cdot>y)" | |
| 182 | shows "P (fix\<cdot>F) (fix\<cdot>G)" | |
| 183 | proof - | |
| 184 | from adm have adm': "adm (split P)" | |
| 185 | unfolding split_def . | |
| 186 | have "\<And>i. P (iterate i\<cdot>F\<cdot>\<bottom>) (iterate i\<cdot>G\<cdot>\<bottom>)" | |
| 187 | by (induct_tac i, simp add: base, simp add: step) | |
| 188 | hence "\<And>i. split P (iterate i\<cdot>F\<cdot>\<bottom>, iterate i\<cdot>G\<cdot>\<bottom>)" | |
| 189 | by simp | |
| 190 | hence "split P (\<Squnion>i. (iterate i\<cdot>F\<cdot>\<bottom>, iterate i\<cdot>G\<cdot>\<bottom>))" | |
| 191 | by - (rule admD [OF adm'], simp, assumption) | |
| 192 | hence "split P (\<Squnion>i. iterate i\<cdot>F\<cdot>\<bottom>, \<Squnion>i. iterate i\<cdot>G\<cdot>\<bottom>)" | |
| 193 | by (simp add: thelub_Pair) | |
| 194 | hence "P (\<Squnion>i. iterate i\<cdot>F\<cdot>\<bottom>) (\<Squnion>i. iterate i\<cdot>G\<cdot>\<bottom>)" | |
| 195 | by simp | |
| 196 | thus "P (fix\<cdot>F) (fix\<cdot>G)" | |
| 197 | by (simp add: fix_def2) | |
| 198 | qed | |
| 199 | ||
| 35932 
86559356502d
move letrec stuff to new file HOLCF/ex/Letrec.thy
 huffman parents: 
35923diff
changeset | 200 | subsection {* Fixed-points on product types *}
 | 
| 18093 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 201 | |
| 18095 | 202 | text {*
 | 
| 203 | Bekic's Theorem: Simultaneous fixed points over pairs | |
| 204 | can be written in terms of separate fixed points. | |
| 205 | *} | |
| 206 | ||
| 207 | lemma fix_cprod: | |
| 208 | "fix\<cdot>(F::'a \<times> 'b \<rightarrow> 'a \<times> 'b) = | |
| 35921 | 209 | (\<mu> x. fst (F\<cdot>(x, \<mu> y. snd (F\<cdot>(x, y)))), | 
| 210 | \<mu> y. snd (F\<cdot>(\<mu> x. fst (F\<cdot>(x, \<mu> y. snd (F\<cdot>(x, y)))), y)))" | |
| 211 | (is "fix\<cdot>F = (?x, ?y)") | |
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 212 | proof (rule fix_eqI) | 
| 35921 | 213 | have 1: "fst (F\<cdot>(?x, ?y)) = ?x" | 
| 18095 | 214 | by (rule trans [symmetric, OF fix_eq], simp) | 
| 35921 | 215 | have 2: "snd (F\<cdot>(?x, ?y)) = ?y" | 
| 18095 | 216 | by (rule trans [symmetric, OF fix_eq], simp) | 
| 35921 | 217 | from 1 2 show "F\<cdot>(?x, ?y) = (?x, ?y)" by (simp add: Pair_fst_snd_eq) | 
| 18095 | 218 | next | 
| 219 | fix z assume F_z: "F\<cdot>z = z" | |
| 35921 | 220 | obtain x y where z: "z = (x,y)" by (rule prod.exhaust) | 
| 221 | from F_z z have F_x: "fst (F\<cdot>(x, y)) = x" by simp | |
| 222 | from F_z z have F_y: "snd (F\<cdot>(x, y)) = y" by simp | |
| 223 | let ?y1 = "\<mu> y. snd (F\<cdot>(x, y))" | |
| 18095 | 224 | have "?y1 \<sqsubseteq> y" by (rule fix_least, simp add: F_y) | 
| 35921 | 225 | hence "fst (F\<cdot>(x, ?y1)) \<sqsubseteq> fst (F\<cdot>(x, y))" | 
| 226 | by (simp add: fst_monofun monofun_cfun) | |
| 227 | hence "fst (F\<cdot>(x, ?y1)) \<sqsubseteq> x" using F_x by simp | |
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 228 | hence 1: "?x \<sqsubseteq> x" by (simp add: fix_least_below) | 
| 35921 | 229 | hence "snd (F\<cdot>(?x, y)) \<sqsubseteq> snd (F\<cdot>(x, y))" | 
| 230 | by (simp add: snd_monofun monofun_cfun) | |
| 231 | hence "snd (F\<cdot>(?x, y)) \<sqsubseteq> y" using F_y by simp | |
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 232 | hence 2: "?y \<sqsubseteq> y" by (simp add: fix_least_below) | 
| 35921 | 233 | show "(?x, ?y) \<sqsubseteq> z" using z 1 2 by simp | 
| 18095 | 234 | qed | 
| 235 | ||
| 243 
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
 nipkow parents: diff
changeset | 236 | end |