| author | huffman | 
| Wed, 10 Nov 2010 13:08:42 -0800 | |
| changeset 40498 | 5718fb91d2d8 | 
| parent 40321 | d065b195ec89 | 
| child 40500 | ee9c8d36318e | 
| 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>)" | 
| 40004 
9f6ed6840e8d
reformulate lemma cont2cont_lub and move to Cont.thy
 huffman parents: 
36452diff
changeset | 63 | unfolding fix_def by simp | 
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 64 | |
| 35055 | 65 | lemma iterate_below_fix: "iterate n\<cdot>f\<cdot>\<bottom> \<sqsubseteq> fix\<cdot>f" | 
| 66 | unfolding fix_def2 | |
| 67 | using chain_iterate by (rule is_ub_thelub) | |
| 68 | ||
| 15637 
d2a06007ebfa
changed comments to text blocks, cleaned up a few proofs
 huffman parents: 
15577diff
changeset | 69 | text {*
 | 
| 
d2a06007ebfa
changed comments to text blocks, cleaned up a few proofs
 huffman parents: 
15577diff
changeset | 70 | 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 | 71 | omega cpo's | 
| 
d2a06007ebfa
changed comments to text blocks, cleaned up a few proofs
 huffman parents: 
15577diff
changeset | 72 | *} | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 73 | |
| 18074 
a92b7c5133de
reorganized; removed intermediate constant Ifix; changed iterate to a continuous type; added theorem fix_least_less
 huffman parents: 
17816diff
changeset | 74 | 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 | 75 | apply (simp add: fix_def2) | 
| 16005 | 76 | apply (subst lub_range_shift [of _ 1, symmetric]) | 
| 77 | apply (rule chain_iterate) | |
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 78 | apply (subst contlub_cfun_arg) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 79 | apply (rule chain_iterate) | 
| 16005 | 80 | apply simp | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 81 | done | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 82 | |
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 83 | 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 | 84 | apply (simp add: fix_def2) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 85 | apply (rule is_lub_thelub) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 86 | apply (rule chain_iterate) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 87 | apply (rule ub_rangeI) | 
| 16005 | 88 | apply (induct_tac i) | 
| 89 | apply simp | |
| 90 | 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 | 91 | apply (erule rev_below_trans) | 
| 16214 | 92 | apply (erule monofun_cfun_arg) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 93 | done | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 94 | |
| 16214 | 95 | 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 | 96 | by (rule fix_least_below, simp) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 97 | |
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 98 | lemma fix_eqI: | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 99 | 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 | 100 | 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 | 101 | apply (rule below_antisym) | 
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 102 | apply (rule fix_least [OF fixed]) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 103 | apply (rule least [OF fix_eq [symmetric]]) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 104 | done | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 105 | |
| 16214 | 106 | 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 | 107 | by (simp add: fix_eq [symmetric]) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 108 | |
| 16214 | 109 | 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 | 110 | by (erule fix_eq2 [THEN cfun_fun_cong]) | 
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 111 | |
| 16214 | 112 | 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 | 113 | apply (erule ssubst) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 114 | apply (rule fix_eq) | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 115 | done | 
| 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 116 | |
| 16214 | 117 | lemma fix_eq5: "f = fix\<cdot>F \<Longrightarrow> f\<cdot>x = F\<cdot>f\<cdot>x" | 
| 118 | by (erule fix_eq4 [THEN cfun_fun_cong]) | |
| 15576 
efb95d0d01f7
converted to new-style theories, and combined numbered files
 huffman parents: 
14981diff
changeset | 119 | |
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 120 | text {* strictness of @{term fix} *}
 | 
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 121 | |
| 40321 
d065b195ec89
rename lemmas *_defined_iff and *_strict_iff to *_bottom_iff
 huffman parents: 
40004diff
changeset | 122 | lemma fix_bottom_iff: "(fix\<cdot>F = \<bottom>) = (F\<cdot>\<bottom> = \<bottom>)" | 
| 16917 | 123 | apply (rule iffI) | 
| 124 | apply (erule subst) | |
| 125 | apply (rule fix_eq [symmetric]) | |
| 126 | apply (erule fix_least [THEN UU_I]) | |
| 127 | done | |
| 128 | ||
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 129 | lemma fix_strict: "F\<cdot>\<bottom> = \<bottom> \<Longrightarrow> fix\<cdot>F = \<bottom>" | 
| 40321 
d065b195ec89
rename lemmas *_defined_iff and *_strict_iff to *_bottom_iff
 huffman parents: 
40004diff
changeset | 130 | by (simp add: fix_bottom_iff) | 
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 131 | |
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 132 | lemma fix_defined: "F\<cdot>\<bottom> \<noteq> \<bottom> \<Longrightarrow> fix\<cdot>F \<noteq> \<bottom>" | 
| 40321 
d065b195ec89
rename lemmas *_defined_iff and *_strict_iff to *_bottom_iff
 huffman parents: 
40004diff
changeset | 133 | by (simp add: fix_bottom_iff) | 
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 134 | |
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 135 | text {* @{term fix} applied to identity and constant functions *}
 | 
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 136 | |
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 137 | lemma fix_id: "(\<mu> x. x) = \<bottom>" | 
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 138 | by (simp add: fix_strict) | 
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 139 | |
| 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 140 | 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 | 141 | by (subst fix_eq, simp) | 
| 16556 
a0c8d0499b5f
added theorems fix_strict, fix_defined, fix_id, fix_const
 huffman parents: 
16388diff
changeset | 142 | |
| 18090 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 143 | 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 | 144 | |
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 145 | 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 | 146 | unfolding fix_def2 | 
| 25925 | 147 | 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 | 148 | apply (rule chain_iterate) | 
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 149 | 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 | 150 | done | 
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 151 | |
| 
9d5cfd71f510
moved adm_chfindom from Fix.thy to Cfun.thy; moved admw-related stuff to its own section
 huffman parents: 
18078diff
changeset | 152 | 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 | 153 | "\<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 | 154 | 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 | 155 | |
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 156 | lemma fix_ind2: | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 157 | assumes adm: "adm P" | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 158 | 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 | 159 | 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 | 160 | shows "P (fix\<cdot>F)" | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 161 | unfolding fix_def2 | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 162 | apply (rule admD [OF adm chain_iterate]) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 163 | apply (rule nat_less_induct) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 164 | apply (case_tac n) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 165 | apply (simp add: 0) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 166 | apply (case_tac nat) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 167 | apply (simp add: 1) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 168 | apply (frule_tac x=nat in spec) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 169 | apply (simp add: step) | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 170 | done | 
| 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 171 | |
| 33590 | 172 | lemma parallel_fix_ind: | 
| 173 | assumes adm: "adm (\<lambda>x. P (fst x) (snd x))" | |
| 174 | assumes base: "P \<bottom> \<bottom>" | |
| 175 | assumes step: "\<And>x y. P x y \<Longrightarrow> P (F\<cdot>x) (G\<cdot>y)" | |
| 176 | shows "P (fix\<cdot>F) (fix\<cdot>G)" | |
| 177 | proof - | |
| 178 | from adm have adm': "adm (split P)" | |
| 179 | unfolding split_def . | |
| 180 | have "\<And>i. P (iterate i\<cdot>F\<cdot>\<bottom>) (iterate i\<cdot>G\<cdot>\<bottom>)" | |
| 181 | by (induct_tac i, simp add: base, simp add: step) | |
| 182 | hence "\<And>i. split P (iterate i\<cdot>F\<cdot>\<bottom>, iterate i\<cdot>G\<cdot>\<bottom>)" | |
| 183 | by simp | |
| 184 | hence "split P (\<Squnion>i. (iterate i\<cdot>F\<cdot>\<bottom>, iterate i\<cdot>G\<cdot>\<bottom>))" | |
| 185 | by - (rule admD [OF adm'], simp, assumption) | |
| 186 | hence "split P (\<Squnion>i. iterate i\<cdot>F\<cdot>\<bottom>, \<Squnion>i. iterate i\<cdot>G\<cdot>\<bottom>)" | |
| 187 | by (simp add: thelub_Pair) | |
| 188 | hence "P (\<Squnion>i. iterate i\<cdot>F\<cdot>\<bottom>) (\<Squnion>i. iterate i\<cdot>G\<cdot>\<bottom>)" | |
| 189 | by simp | |
| 190 | thus "P (fix\<cdot>F) (fix\<cdot>G)" | |
| 191 | by (simp add: fix_def2) | |
| 192 | qed | |
| 193 | ||
| 35932 
86559356502d
move letrec stuff to new file HOLCF/ex/Letrec.thy
 huffman parents: 
35923diff
changeset | 194 | subsection {* Fixed-points on product types *}
 | 
| 18093 
587692219f69
put iterate and fix in separate sections; added Letrec
 huffman parents: 
18092diff
changeset | 195 | |
| 18095 | 196 | text {*
 | 
| 197 | Bekic's Theorem: Simultaneous fixed points over pairs | |
| 198 | can be written in terms of separate fixed points. | |
| 199 | *} | |
| 200 | ||
| 201 | lemma fix_cprod: | |
| 202 | "fix\<cdot>(F::'a \<times> 'b \<rightarrow> 'a \<times> 'b) = | |
| 35921 | 203 | (\<mu> x. fst (F\<cdot>(x, \<mu> y. snd (F\<cdot>(x, y)))), | 
| 204 | \<mu> y. snd (F\<cdot>(\<mu> x. fst (F\<cdot>(x, \<mu> y. snd (F\<cdot>(x, y)))), y)))" | |
| 205 | (is "fix\<cdot>F = (?x, ?y)") | |
| 27185 
0407630909ef
change orientation of fix_eqI and convert to rule_format;
 huffman parents: 
25927diff
changeset | 206 | proof (rule fix_eqI) | 
| 35921 | 207 | have 1: "fst (F\<cdot>(?x, ?y)) = ?x" | 
| 18095 | 208 | by (rule trans [symmetric, OF fix_eq], simp) | 
| 35921 | 209 | have 2: "snd (F\<cdot>(?x, ?y)) = ?y" | 
| 18095 | 210 | by (rule trans [symmetric, OF fix_eq], simp) | 
| 35921 | 211 | from 1 2 show "F\<cdot>(?x, ?y) = (?x, ?y)" by (simp add: Pair_fst_snd_eq) | 
| 18095 | 212 | next | 
| 213 | fix z assume F_z: "F\<cdot>z = z" | |
| 35921 | 214 | obtain x y where z: "z = (x,y)" by (rule prod.exhaust) | 
| 215 | from F_z z have F_x: "fst (F\<cdot>(x, y)) = x" by simp | |
| 216 | from F_z z have F_y: "snd (F\<cdot>(x, y)) = y" by simp | |
| 217 | let ?y1 = "\<mu> y. snd (F\<cdot>(x, y))" | |
| 18095 | 218 | have "?y1 \<sqsubseteq> y" by (rule fix_least, simp add: F_y) | 
| 35921 | 219 | hence "fst (F\<cdot>(x, ?y1)) \<sqsubseteq> fst (F\<cdot>(x, y))" | 
| 220 | by (simp add: fst_monofun monofun_cfun) | |
| 221 | 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 | 222 | hence 1: "?x \<sqsubseteq> x" by (simp add: fix_least_below) | 
| 35921 | 223 | hence "snd (F\<cdot>(?x, y)) \<sqsubseteq> snd (F\<cdot>(x, y))" | 
| 224 | by (simp add: snd_monofun monofun_cfun) | |
| 225 | 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 | 226 | hence 2: "?y \<sqsubseteq> y" by (simp add: fix_least_below) | 
| 35921 | 227 | show "(?x, ?y) \<sqsubseteq> z" using z 1 2 by simp | 
| 18095 | 228 | qed | 
| 229 | ||
| 243 
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
 nipkow parents: diff
changeset | 230 | end |