author | wenzelm |
Wed, 28 Oct 2009 18:02:06 +0100 | |
changeset 33284 | b5347c65bcab |
parent 32960 | 69916a850301 |
child 46822 | 95f1e700b712 |
permissions | -rw-r--r-- |
1478 | 1 |
(* Title: ZF/AC/DC.thy |
2 |
Author: Krzysztof Grabczewski |
|
1196 | 3 |
|
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
4 |
The proofs concerning the Axiom of Dependent Choice. |
1196 | 5 |
*) |
6 |
||
27678 | 7 |
theory DC |
8 |
imports AC_Equiv Hartog Cardinal_aux |
|
9 |
begin |
|
12776 | 10 |
|
11 |
lemma RepFun_lepoll: "Ord(a) ==> {P(b). b \<in> a} \<lesssim> a" |
|
12 |
apply (unfold lepoll_def) |
|
13 |
apply (rule_tac x = "\<lambda>z \<in> RepFun (a,P) . LEAST i. z=P (i) " in exI) |
|
14 |
apply (rule_tac d="%z. P (z)" in lam_injective) |
|
15 |
apply (fast intro!: Least_in_Ord) |
|
16 |
apply (rule sym) |
|
17 |
apply (fast intro: LeastI Ord_in_Ord) |
|
18 |
done |
|
1196 | 19 |
|
12776 | 20 |
text{*Trivial in the presence of AC, but here we need a wellordering of X*} |
21 |
lemma image_Ord_lepoll: "[| f \<in> X->Y; Ord(X) |] ==> f``X \<lesssim> X" |
|
22 |
apply (unfold lepoll_def) |
|
23 |
apply (rule_tac x = "\<lambda>x \<in> f``X. LEAST y. f`y = x" in exI) |
|
24 |
apply (rule_tac d = "%z. f`z" in lam_injective) |
|
25 |
apply (fast intro!: Least_in_Ord apply_equality, clarify) |
|
26 |
apply (rule LeastI) |
|
27 |
apply (erule apply_equality, assumption+) |
|
28 |
apply (blast intro: Ord_in_Ord) |
|
29 |
done |
|
1196 | 30 |
|
12776 | 31 |
lemma range_subset_domain: |
32 |
"[| R \<subseteq> X*X; !!g. g \<in> X ==> \<exists>u. <g,u> \<in> R |] |
|
33 |
==> range(R) \<subseteq> domain(R)" |
|
13175
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12891
diff
changeset
|
34 |
by blast |
12776 | 35 |
|
36 |
lemma cons_fun_type: "g \<in> n->X ==> cons(<n,x>, g) \<in> succ(n) -> cons(x, X)" |
|
37 |
apply (unfold succ_def) |
|
38 |
apply (fast intro!: fun_extend elim!: mem_irrefl) |
|
39 |
done |
|
1196 | 40 |
|
12776 | 41 |
lemma cons_fun_type2: |
42 |
"[| g \<in> n->X; x \<in> X |] ==> cons(<n,x>, g) \<in> succ(n) -> X" |
|
43 |
by (erule cons_absorb [THEN subst], erule cons_fun_type) |
|
44 |
||
45 |
lemma cons_image_n: "n \<in> nat ==> cons(<n,x>, g)``n = g``n" |
|
46 |
by (fast elim!: mem_irrefl) |
|
47 |
||
48 |
lemma cons_val_n: "g \<in> n->X ==> cons(<n,x>, g)`n = x" |
|
49 |
by (fast intro!: apply_equality elim!: cons_fun_type) |
|
50 |
||
51 |
lemma cons_image_k: "k \<in> n ==> cons(<n,x>, g)``k = g``k" |
|
52 |
by (fast elim: mem_asym) |
|
1196 | 53 |
|
12776 | 54 |
lemma cons_val_k: "[| k \<in> n; g \<in> n->X |] ==> cons(<n,x>, g)`k = g`k" |
55 |
by (fast intro!: apply_equality consI2 elim!: cons_fun_type apply_Pair) |
|
56 |
||
57 |
lemma domain_cons_eq_succ: "domain(f)=x ==> domain(cons(<x,y>, f)) = succ(x)" |
|
58 |
by (simp add: domain_cons succ_def) |
|
59 |
||
60 |
lemma restrict_cons_eq: "g \<in> n->X ==> restrict(cons(<n,x>, g), n) = g" |
|
12891 | 61 |
apply (simp add: restrict_def Pi_iff) |
62 |
apply (blast intro: elim: mem_irrefl) |
|
12776 | 63 |
done |
64 |
||
65 |
lemma succ_in_succ: "[| Ord(k); i \<in> k |] ==> succ(i) \<in> succ(k)" |
|
66 |
apply (rule Ord_linear [of "succ(i)" "succ(k)", THEN disjE]) |
|
67 |
apply (fast elim: Ord_in_Ord mem_irrefl mem_asym)+ |
|
68 |
done |
|
1196 | 69 |
|
12776 | 70 |
lemma restrict_eq_imp_val_eq: |
12891 | 71 |
"[|restrict(f, domain(g)) = g; x \<in> domain(g)|] |
72 |
==> f`x = g`x" |
|
73 |
by (erule subst, simp add: restrict) |
|
12776 | 74 |
|
75 |
lemma domain_eq_imp_fun_type: "[| domain(f)=A; f \<in> B->C |] ==> f \<in> A->C" |
|
76 |
by (frule domain_of_fun, fast) |
|
77 |
||
78 |
lemma ex_in_domain: "[| R \<subseteq> A * B; R \<noteq> 0 |] ==> \<exists>x. x \<in> domain(R)" |
|
79 |
by (fast elim!: not_emptyE) |
|
80 |
||
5482 | 81 |
|
24893 | 82 |
definition |
83 |
DC :: "i => o" where |
|
12776 | 84 |
"DC(a) == \<forall>X R. R \<subseteq> Pow(X)*X & |
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
85 |
(\<forall>Y \<in> Pow(X). Y \<prec> a --> (\<exists>x \<in> X. <Y,x> \<in> R)) |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
86 |
--> (\<exists>f \<in> a->X. \<forall>b<a. <f``b,f`b> \<in> R)" |
12776 | 87 |
|
24893 | 88 |
definition |
89 |
DC0 :: o where |
|
12776 | 90 |
"DC0 == \<forall>A B R. R \<subseteq> A*B & R\<noteq>0 & range(R) \<subseteq> domain(R) |
91 |
--> (\<exists>f \<in> nat->domain(R). \<forall>n \<in> nat. <f`n,f`succ(n)>:R)" |
|
92 |
||
24893 | 93 |
definition |
94 |
ff :: "[i, i, i, i] => i" where |
|
12776 | 95 |
"ff(b, X, Q, R) == |
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
96 |
transrec(b, %c r. THE x. first(x, {x \<in> X. <r``c, x> \<in> R}, Q))" |
12776 | 97 |
|
5482 | 98 |
|
27678 | 99 |
locale DC0_imp = |
12776 | 100 |
fixes XX and RR and X and R |
101 |
||
102 |
assumes all_ex: "\<forall>Y \<in> Pow(X). Y \<prec> nat --> (\<exists>x \<in> X. <Y, x> \<in> R)" |
|
103 |
||
104 |
defines XX_def: "XX == (\<Union>n \<in> nat. {f \<in> n->X. \<forall>k \<in> n. <f``k, f`k> \<in> R})" |
|
105 |
and RR_def: "RR == {<z1,z2>:XX*XX. domain(z2)=succ(domain(z1)) |
|
106 |
& restrict(z2, domain(z1)) = z1}" |
|
107 |
||
108 |
||
109 |
(* ********************************************************************** *) |
|
110 |
(* DC ==> DC(omega) *) |
|
111 |
(* *) |
|
112 |
(* The scheme of the proof: *) |
|
113 |
(* *) |
|
114 |
(* Assume DC. Let R and X satisfy the premise of DC(omega). *) |
|
115 |
(* *) |
|
116 |
(* Define XX and RR as follows: *) |
|
117 |
(* *) |
|
118 |
(* XX = (\<Union>n \<in> nat. {f \<in> n->X. \<forall>k \<in> n. <f``k, f`k> \<in> R}) *) |
|
119 |
(* f RR g iff domain(g)=succ(domain(f)) & *) |
|
120 |
(* restrict(g, domain(f)) = f *) |
|
121 |
(* *) |
|
122 |
(* Then RR satisfies the hypotheses of DC. *) |
|
123 |
(* So applying DC: *) |
|
124 |
(* *) |
|
125 |
(* \<exists>f \<in> nat->XX. \<forall>n \<in> nat. f`n RR f`succ(n) *) |
|
126 |
(* *) |
|
127 |
(* Thence *) |
|
128 |
(* *) |
|
129 |
(* ff = {<n, f`succ(n)`n>. n \<in> nat} *) |
|
130 |
(* *) |
|
131 |
(* is the desired function. *) |
|
132 |
(* *) |
|
133 |
(* ********************************************************************** *) |
|
134 |
||
135 |
lemma (in DC0_imp) lemma1_1: "RR \<subseteq> XX*XX" |
|
136 |
by (unfold RR_def, fast) |
|
137 |
||
138 |
lemma (in DC0_imp) lemma1_2: "RR \<noteq> 0" |
|
139 |
apply (unfold RR_def XX_def) |
|
140 |
apply (rule all_ex [THEN ballE]) |
|
141 |
apply (erule_tac [2] notE [OF _ empty_subsetI [THEN PowI]]) |
|
142 |
apply (erule_tac impE [OF _ nat_0I [THEN n_lesspoll_nat]]) |
|
143 |
apply (erule bexE) |
|
144 |
apply (rule_tac a = "<0, {<0, x>}>" in not_emptyI) |
|
145 |
apply (rule CollectI) |
|
146 |
apply (rule SigmaI) |
|
147 |
apply (rule nat_0I [THEN UN_I]) |
|
148 |
apply (simp (no_asm_simp) add: nat_0I [THEN UN_I]) |
|
149 |
apply (rule nat_1I [THEN UN_I]) |
|
150 |
apply (force intro!: singleton_fun [THEN Pi_type] |
|
151 |
simp add: singleton_0 [symmetric]) |
|
152 |
apply (simp add: singleton_0) |
|
153 |
done |
|
154 |
||
155 |
lemma (in DC0_imp) lemma1_3: "range(RR) \<subseteq> domain(RR)" |
|
156 |
apply (unfold RR_def XX_def) |
|
157 |
apply (rule range_subset_domain, blast, clarify) |
|
158 |
apply (frule fun_is_rel [THEN image_subset, THEN PowI, |
|
159 |
THEN all_ex [THEN bspec]]) |
|
160 |
apply (erule impE[OF _ lesspoll_trans1[OF image_Ord_lepoll |
|
161 |
[OF _ nat_into_Ord] n_lesspoll_nat]], |
|
162 |
assumption+) |
|
163 |
apply (erule bexE) |
|
164 |
apply (rule_tac x = "cons (<n,x>, g) " in exI) |
|
165 |
apply (rule CollectI) |
|
166 |
apply (force elim!: cons_fun_type2 |
|
167 |
simp add: cons_image_n cons_val_n cons_image_k cons_val_k) |
|
168 |
apply (simp add: domain_of_fun succ_def restrict_cons_eq) |
|
169 |
done |
|
5482 | 170 |
|
12776 | 171 |
lemma (in DC0_imp) lemma2: |
172 |
"[| \<forall>n \<in> nat. <f`n, f`succ(n)> \<in> RR; f \<in> nat -> XX; n \<in> nat |] |
|
173 |
==> \<exists>k \<in> nat. f`succ(n) \<in> k -> X & n \<in> k |
|
174 |
& <f`succ(n)``n, f`succ(n)`n> \<in> R" |
|
175 |
apply (induct_tac "n") |
|
176 |
apply (drule apply_type [OF _ nat_1I]) |
|
177 |
apply (drule bspec [OF _ nat_0I]) |
|
178 |
apply (simp add: XX_def, safe) |
|
179 |
apply (rule rev_bexI, assumption) |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
180 |
apply (subgoal_tac "0 \<in> y", force) |
12776 | 181 |
apply (force simp add: RR_def |
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
182 |
intro: ltD elim!: nat_0_le [THEN leE]) |
12776 | 183 |
(** LEVEL 7, other subgoal **) |
184 |
apply (drule bspec [OF _ nat_succI], assumption) |
|
185 |
apply (subgoal_tac "f ` succ (succ (x)) \<in> succ (k) ->X") |
|
186 |
apply (drule apply_type [OF _ nat_succI [THEN nat_succI]], assumption) |
|
187 |
apply (simp (no_asm_use) add: XX_def RR_def) |
|
188 |
apply safe |
|
189 |
apply (frule_tac a="succ(k)" in domain_of_fun [symmetric, THEN trans], |
|
190 |
assumption) |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
191 |
apply (frule_tac a=y in domain_of_fun [symmetric, THEN trans], |
12776 | 192 |
assumption) |
193 |
apply (fast elim!: nat_into_Ord [THEN succ_in_succ] |
|
194 |
dest!: bspec [OF _ nat_into_Ord [THEN succ_in_succ]]) |
|
195 |
apply (drule domain_of_fun) |
|
196 |
apply (simp add: XX_def RR_def, clarify) |
|
197 |
apply (blast dest: domain_of_fun [symmetric, THEN trans] ) |
|
198 |
done |
|
199 |
||
200 |
lemma (in DC0_imp) lemma3_1: |
|
201 |
"[| \<forall>n \<in> nat. <f`n, f`succ(n)> \<in> RR; f \<in> nat -> XX; m \<in> nat |] |
|
202 |
==> {f`succ(x)`x. x \<in> m} = {f`succ(m)`x. x \<in> m}" |
|
203 |
apply (subgoal_tac "\<forall>x \<in> m. f`succ (m) `x = f`succ (x) `x") |
|
204 |
apply simp |
|
205 |
apply (induct_tac "m", blast) |
|
206 |
apply (rule ballI) |
|
207 |
apply (erule succE) |
|
208 |
apply (rule restrict_eq_imp_val_eq) |
|
209 |
apply (drule bspec [OF _ nat_succI], assumption) |
|
210 |
apply (simp add: RR_def) |
|
211 |
apply (drule lemma2, assumption+) |
|
212 |
apply (fast dest!: domain_of_fun) |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
213 |
apply (drule_tac x = xa in bspec, assumption) |
12776 | 214 |
apply (erule sym [THEN trans, symmetric]) |
215 |
apply (rule restrict_eq_imp_val_eq [symmetric]) |
|
216 |
apply (drule bspec [OF _ nat_succI], assumption) |
|
217 |
apply (simp add: RR_def) |
|
218 |
apply (drule lemma2, assumption+) |
|
219 |
apply (blast dest!: domain_of_fun |
|
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
220 |
intro: nat_into_Ord OrdmemD [THEN subsetD]) |
12776 | 221 |
done |
5482 | 222 |
|
12776 | 223 |
lemma (in DC0_imp) lemma3: |
224 |
"[| \<forall>n \<in> nat. <f`n, f`succ(n)> \<in> RR; f \<in> nat -> XX; m \<in> nat |] |
|
225 |
==> (\<lambda>x \<in> nat. f`succ(x)`x) `` m = f`succ(m)``m" |
|
226 |
apply (erule natE, simp) |
|
227 |
apply (subst image_lam) |
|
228 |
apply (fast elim!: OrdmemD [OF nat_succI Ord_nat]) |
|
229 |
apply (subst lemma3_1, assumption+) |
|
230 |
apply fast |
|
231 |
apply (fast dest!: lemma2 |
|
232 |
elim!: image_fun [symmetric, OF _ OrdmemD [OF _ nat_into_Ord]]) |
|
233 |
done |
|
234 |
||
235 |
||
236 |
theorem DC0_imp_DC_nat: "DC0 ==> DC(nat)" |
|
237 |
apply (unfold DC_def DC0_def, clarify) |
|
238 |
apply (elim allE) |
|
239 |
apply (erule impE) |
|
240 |
(*these three results comprise Lemma 1*) |
|
27678 | 241 |
apply (blast intro!: DC0_imp.lemma1_1 [OF DC0_imp.intro] DC0_imp.lemma1_2 [OF DC0_imp.intro] DC0_imp.lemma1_3 [OF DC0_imp.intro]) |
12776 | 242 |
apply (erule bexE) |
243 |
apply (rule_tac x = "\<lambda>n \<in> nat. f`succ (n) `n" in rev_bexI) |
|
27678 | 244 |
apply (rule lam_type, blast dest!: DC0_imp.lemma2 [OF DC0_imp.intro] intro: fun_weaken_type) |
12776 | 245 |
apply (rule oallI) |
27678 | 246 |
apply (frule DC0_imp.lemma2 [OF DC0_imp.intro], assumption) |
12776 | 247 |
apply (blast intro: fun_weaken_type) |
248 |
apply (erule ltD) |
|
249 |
(** LEVEL 11: last subgoal **) |
|
27678 | 250 |
apply (subst DC0_imp.lemma3 [OF DC0_imp.intro], assumption+) |
12776 | 251 |
apply (fast elim!: fun_weaken_type) |
13175
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12891
diff
changeset
|
252 |
apply (erule ltD) |
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12891
diff
changeset
|
253 |
apply (force simp add: lt_def) |
12776 | 254 |
done |
255 |
||
256 |
||
257 |
(* ************************************************************************ |
|
258 |
DC(omega) ==> DC |
|
259 |
||
260 |
The scheme of the proof: |
|
261 |
||
262 |
Assume DC(omega). Let R and x satisfy the premise of DC. |
|
263 |
||
264 |
Define XX and RR as follows: |
|
265 |
||
266 |
XX = (\<Union>n \<in> nat. {f \<in> succ(n)->domain(R). \<forall>k \<in> n. <f`k, f`succ(k)> \<in> R}) |
|
267 |
||
268 |
RR = {<z1,z2>:Fin(XX)*XX. |
|
269 |
(domain(z2)=succ(\<Union>f \<in> z1. domain(f)) & |
|
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
270 |
(\<forall>f \<in> z1. restrict(z2, domain(f)) = f)) | |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
271 |
(~ (\<exists>g \<in> XX. domain(g)=succ(\<Union>f \<in> z1. domain(f)) & |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
272 |
(\<forall>f \<in> z1. restrict(g, domain(f)) = f)) & |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
273 |
z2={<0,x>})} |
12776 | 274 |
|
275 |
Then XX and RR satisfy the hypotheses of DC(omega). |
|
276 |
So applying DC: |
|
277 |
||
278 |
\<exists>f \<in> nat->XX. \<forall>n \<in> nat. f``n RR f`n |
|
279 |
||
280 |
Thence |
|
281 |
||
282 |
ff = {<n, f`n`n>. n \<in> nat} |
|
283 |
||
284 |
is the desired function. |
|
285 |
||
286 |
************************************************************************* *) |
|
287 |
||
288 |
lemma singleton_in_funs: |
|
289 |
"x \<in> X ==> {<0,x>} \<in> |
|
290 |
(\<Union>n \<in> nat. {f \<in> succ(n)->X. \<forall>k \<in> n. <f`k, f`succ(k)> \<in> R})" |
|
291 |
apply (rule nat_0I [THEN UN_I]) |
|
292 |
apply (force simp add: singleton_0 [symmetric] |
|
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
293 |
intro!: singleton_fun [THEN Pi_type]) |
12776 | 294 |
done |
5482 | 295 |
|
1196 | 296 |
|
27678 | 297 |
locale imp_DC0 = |
12776 | 298 |
fixes XX and RR and x and R and f and allRR |
299 |
defines XX_def: "XX == (\<Union>n \<in> nat. |
|
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
300 |
{f \<in> succ(n)->domain(R). \<forall>k \<in> n. <f`k, f`succ(k)> \<in> R})" |
12776 | 301 |
and RR_def: |
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
302 |
"RR == {<z1,z2>:Fin(XX)*XX. |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
303 |
(domain(z2)=succ(\<Union>f \<in> z1. domain(f)) |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
304 |
& (\<forall>f \<in> z1. restrict(z2, domain(f)) = f)) |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
305 |
| (~ (\<exists>g \<in> XX. domain(g)=succ(\<Union>f \<in> z1. domain(f)) |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
306 |
& (\<forall>f \<in> z1. restrict(g, domain(f)) = f)) & z2={<0,x>})}" |
12776 | 307 |
and allRR_def: |
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
308 |
"allRR == \<forall>b<nat. |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
309 |
<f``b, f`b> \<in> |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
310 |
{<z1,z2>\<in>Fin(XX)*XX. (domain(z2)=succ(\<Union>f \<in> z1. domain(f)) |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
311 |
& (\<Union>f \<in> z1. domain(f)) = b |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
312 |
& (\<forall>f \<in> z1. restrict(z2,domain(f)) = f))}" |
12776 | 313 |
|
314 |
lemma (in imp_DC0) lemma4: |
|
315 |
"[| range(R) \<subseteq> domain(R); x \<in> domain(R) |] |
|
316 |
==> RR \<subseteq> Pow(XX)*XX & |
|
317 |
(\<forall>Y \<in> Pow(XX). Y \<prec> nat --> (\<exists>x \<in> XX. <Y,x>:RR))" |
|
318 |
apply (rule conjI) |
|
319 |
apply (force dest!: FinD [THEN PowI] simp add: RR_def) |
|
320 |
apply (rule impI [THEN ballI]) |
|
321 |
apply (drule Finite_Fin [OF lesspoll_nat_is_Finite PowD], assumption) |
|
322 |
apply (case_tac |
|
323 |
"\<exists>g \<in> XX. domain (g) = |
|
324 |
succ(\<Union>f \<in> Y. domain(f)) & (\<forall>f\<in>Y. restrict(g, domain(f)) = f)") |
|
325 |
apply (simp add: RR_def, blast) |
|
326 |
apply (safe del: domainE) |
|
327 |
apply (unfold XX_def RR_def) |
|
328 |
apply (rule rev_bexI, erule singleton_in_funs) |
|
329 |
apply (simp add: nat_0I [THEN rev_bexI] cons_fun_type2) |
|
330 |
done |
|
331 |
||
332 |
lemma (in imp_DC0) UN_image_succ_eq: |
|
333 |
"[| f \<in> nat->X; n \<in> nat |] |
|
334 |
==> (\<Union>x \<in> f``succ(n). P(x)) = P(f`n) Un (\<Union>x \<in> f``n. P(x))" |
|
335 |
by (simp add: image_fun OrdmemD) |
|
336 |
||
337 |
lemma (in imp_DC0) UN_image_succ_eq_succ: |
|
338 |
"[| (\<Union>x \<in> f``n. P(x)) = y; P(f`n) = succ(y); |
|
339 |
f \<in> nat -> X; n \<in> nat |] ==> (\<Union>x \<in> f``succ(n). P(x)) = succ(y)" |
|
340 |
by (simp add: UN_image_succ_eq, blast) |
|
341 |
||
342 |
lemma (in imp_DC0) apply_domain_type: |
|
343 |
"[| h \<in> succ(n) -> D; n \<in> nat; domain(h)=succ(y) |] ==> h`y \<in> D" |
|
344 |
by (fast elim: apply_type dest!: trans [OF sym domain_of_fun]) |
|
345 |
||
346 |
lemma (in imp_DC0) image_fun_succ: |
|
347 |
"[| h \<in> nat -> X; n \<in> nat |] ==> h``succ(n) = cons(h`n, h``n)" |
|
348 |
by (simp add: image_fun OrdmemD) |
|
349 |
||
350 |
lemma (in imp_DC0) f_n_type: |
|
351 |
"[| domain(f`n) = succ(k); f \<in> nat -> XX; n \<in> nat |] |
|
352 |
==> f`n \<in> succ(k) -> domain(R)" |
|
353 |
apply (unfold XX_def) |
|
354 |
apply (drule apply_type, assumption) |
|
355 |
apply (fast elim: domain_eq_imp_fun_type) |
|
356 |
done |
|
357 |
||
358 |
lemma (in imp_DC0) f_n_pairs_in_R [rule_format]: |
|
359 |
"[| h \<in> nat -> XX; domain(h`n) = succ(k); n \<in> nat |] |
|
360 |
==> \<forall>i \<in> k. <h`n`i, h`n`succ(i)> \<in> R" |
|
361 |
apply (unfold XX_def) |
|
362 |
apply (drule apply_type, assumption) |
|
363 |
apply (elim UN_E CollectE) |
|
12820 | 364 |
apply (drule domain_of_fun [symmetric, THEN trans], assumption, simp) |
12776 | 365 |
done |
366 |
||
367 |
lemma (in imp_DC0) restrict_cons_eq_restrict: |
|
368 |
"[| restrict(h, domain(u))=u; h \<in> n->X; domain(u) \<subseteq> n |] |
|
369 |
==> restrict(cons(<n, y>, h), domain(u)) = u" |
|
370 |
apply (unfold restrict_def) |
|
12891 | 371 |
apply (simp add: restrict_def Pi_iff) |
12776 | 372 |
apply (erule sym [THEN trans, symmetric]) |
12891 | 373 |
apply (blast elim: mem_irrefl) |
12776 | 374 |
done |
375 |
||
376 |
lemma (in imp_DC0) all_in_image_restrict_eq: |
|
377 |
"[| \<forall>x \<in> f``n. restrict(f`n, domain(x))=x; |
|
378 |
f \<in> nat -> XX; |
|
379 |
n \<in> nat; domain(f`n) = succ(n); |
|
380 |
(\<Union>x \<in> f``n. domain(x)) \<subseteq> n |] |
|
381 |
==> \<forall>x \<in> f``succ(n). restrict(cons(<succ(n),y>, f`n), domain(x)) = x" |
|
382 |
apply (rule ballI) |
|
383 |
apply (simp add: image_fun_succ) |
|
384 |
apply (drule f_n_type, assumption+) |
|
385 |
apply (erule disjE) |
|
386 |
apply (simp add: domain_of_fun restrict_cons_eq) |
|
387 |
apply (blast intro!: restrict_cons_eq_restrict) |
|
388 |
done |
|
389 |
||
390 |
lemma (in imp_DC0) simplify_recursion: |
|
391 |
"[| \<forall>b<nat. <f``b, f`b> \<in> RR; |
|
392 |
f \<in> nat -> XX; range(R) \<subseteq> domain(R); x \<in> domain(R)|] |
|
393 |
==> allRR" |
|
394 |
apply (unfold RR_def allRR_def) |
|
395 |
apply (rule oallI, drule ltD) |
|
396 |
apply (erule nat_induct) |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
397 |
apply (drule_tac x=0 in ospec, blast intro: Limit_has_0) |
12776 | 398 |
apply (force simp add: singleton_fun [THEN domain_of_fun] singleton_in_funs) |
399 |
(*induction step*) (** LEVEL 5 **) |
|
400 |
(*prevent simplification of ~\<exists> to \<forall>~ *) |
|
401 |
apply (simp only: separation split) |
|
12820 | 402 |
apply (drule_tac x="succ(xa)" in ospec, blast intro: ltI) |
12776 | 403 |
apply (elim conjE disjE) |
404 |
apply (force elim!: trans subst_context |
|
405 |
intro!: UN_image_succ_eq_succ) |
|
406 |
apply (erule notE) |
|
407 |
apply (simp add: XX_def UN_image_succ_eq_succ) |
|
408 |
apply (elim conjE bexE) |
|
409 |
apply (drule apply_domain_type, assumption+) |
|
410 |
apply (erule domainE)+ |
|
411 |
apply (frule f_n_type) |
|
412 |
apply (simp add: XX_def, assumption+) |
|
413 |
apply (rule rev_bexI, erule nat_succI) |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
414 |
apply (rename_tac m i j y z) |
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
415 |
apply (rule_tac x = "cons(<succ(m), z>, f`m)" in bexI) |
12776 | 416 |
prefer 2 apply (blast intro: cons_fun_type2) |
417 |
apply (rule conjI) |
|
418 |
prefer 2 apply (fast del: ballI subsetI |
|
32960
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
419 |
elim: trans [OF _ subst_context, THEN domain_cons_eq_succ] |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
420 |
subst_context |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
421 |
all_in_image_restrict_eq [simplified XX_def] |
69916a850301
eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents:
27678
diff
changeset
|
422 |
trans equalityD1) |
12776 | 423 |
(*one remaining subgoal*) |
424 |
apply (rule ballI) |
|
425 |
apply (erule succE) |
|
426 |
(** LEVEL 25 **) |
|
427 |
apply (simp add: cons_val_n cons_val_k) |
|
428 |
(*assumption+ will not perform the required backtracking!*) |
|
429 |
apply (drule f_n_pairs_in_R [simplified XX_def, OF _ domain_of_fun], |
|
430 |
assumption, assumption, assumption) |
|
431 |
apply (simp add: nat_into_Ord [THEN succ_in_succ] succI2 cons_val_k) |
|
432 |
done |
|
433 |
||
5482 | 434 |
|
12776 | 435 |
lemma (in imp_DC0) lemma2: |
436 |
"[| allRR; f \<in> nat->XX; range(R) \<subseteq> domain(R); x \<in> domain(R); n \<in> nat |] |
|
437 |
==> f`n \<in> succ(n) -> domain(R) & (\<forall>i \<in> n. <f`n`i, f`n`succ(i)>:R)" |
|
438 |
apply (unfold allRR_def) |
|
439 |
apply (drule ospec) |
|
440 |
apply (erule ltI [OF _ Ord_nat]) |
|
441 |
apply (erule CollectE, simp) |
|
442 |
apply (rule conjI) |
|
443 |
prefer 2 apply (fast elim!: f_n_pairs_in_R trans subst_context) |
|
444 |
apply (unfold XX_def) |
|
445 |
apply (fast elim!: trans [THEN domain_eq_imp_fun_type] subst_context) |
|
446 |
done |
|
447 |
||
448 |
lemma (in imp_DC0) lemma3: |
|
449 |
"[| allRR; f \<in> nat->XX; n\<in>nat; range(R) \<subseteq> domain(R); x \<in> domain(R) |] |
|
450 |
==> f`n`n = f`succ(n)`n" |
|
451 |
apply (frule lemma2 [THEN conjunct1, THEN domain_of_fun], assumption+) |
|
452 |
apply (unfold allRR_def) |
|
453 |
apply (drule ospec) |
|
12820 | 454 |
apply (drule ltI [OF nat_succI Ord_nat], assumption, simp) |
12776 | 455 |
apply (elim conjE ballE) |
456 |
apply (erule restrict_eq_imp_val_eq [symmetric], force) |
|
457 |
apply (simp add: image_fun OrdmemD) |
|
458 |
done |
|
459 |
||
460 |
||
461 |
theorem DC_nat_imp_DC0: "DC(nat) ==> DC0" |
|
462 |
apply (unfold DC_def DC0_def) |
|
463 |
apply (intro allI impI) |
|
464 |
apply (erule asm_rl conjE ex_in_domain [THEN exE] allE)+ |
|
465 |
apply (erule impE [OF _ imp_DC0.lemma4], assumption+) |
|
466 |
apply (erule bexE) |
|
467 |
apply (drule imp_DC0.simplify_recursion, assumption+) |
|
468 |
apply (rule_tac x = "\<lambda>n \<in> nat. f`n`n" in bexI) |
|
469 |
apply (rule_tac [2] lam_type) |
|
470 |
apply (erule_tac [2] apply_type [OF imp_DC0.lemma2 [THEN conjunct1] succI1]) |
|
471 |
apply (rule ballI) |
|
472 |
apply (frule_tac n="succ(n)" in imp_DC0.lemma2, |
|
473 |
(assumption|erule nat_succI)+) |
|
474 |
apply (drule imp_DC0.lemma3, auto) |
|
475 |
done |
|
476 |
||
477 |
(* ********************************************************************** *) |
|
478 |
(* \<forall>K. Card(K) --> DC(K) ==> WO3 *) |
|
479 |
(* ********************************************************************** *) |
|
480 |
||
481 |
lemma fun_Ord_inj: |
|
482 |
"[| f \<in> a->X; Ord(a); |
|
483 |
!!b c. [| b<c; c \<in> a |] ==> f`b\<noteq>f`c |] |
|
484 |
==> f \<in> inj(a, X)" |
|
485 |
apply (unfold inj_def, simp) |
|
486 |
apply (intro ballI impI) |
|
487 |
apply (rule_tac j=x in Ord_in_Ord [THEN Ord_linear_lt], assumption+) |
|
488 |
apply (blast intro: Ord_in_Ord, auto) |
|
489 |
apply (atomize, blast dest: not_sym) |
|
490 |
done |
|
491 |
||
492 |
lemma value_in_image: "[| f \<in> X->Y; A \<subseteq> X; a \<in> A |] ==> f`a \<in> f``A" |
|
13175
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12891
diff
changeset
|
493 |
by (fast elim!: image_fun [THEN ssubst]) |
12776 | 494 |
|
495 |
theorem DC_WO3: "(\<forall>K. Card(K) --> DC(K)) ==> WO3" |
|
496 |
apply (unfold DC_def WO3_def) |
|
497 |
apply (rule allI) |
|
12820 | 498 |
apply (case_tac "A \<prec> Hartog (A)") |
12776 | 499 |
apply (fast dest!: lesspoll_imp_ex_lt_eqpoll |
500 |
intro!: Ord_Hartog leI [THEN le_imp_subset]) |
|
501 |
apply (erule allE impE)+ |
|
502 |
apply (rule Card_Hartog) |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
503 |
apply (erule_tac x = A in allE) |
12776 | 504 |
apply (erule_tac x = "{<z1,z2> \<in> Pow (A) *A . z1 \<prec> Hartog (A) & z2 \<notin> z1}" |
505 |
in allE) |
|
506 |
apply simp |
|
507 |
apply (erule impE, fast elim: lesspoll_lemma [THEN not_emptyE]) |
|
508 |
apply (erule bexE) |
|
509 |
apply (rule Hartog_lepoll_selfE) |
|
510 |
apply (rule lepoll_def [THEN def_imp_iff, THEN iffD2]) |
|
511 |
apply (rule exI, rule fun_Ord_inj, assumption, rule Ord_Hartog) |
|
512 |
apply (drule value_in_image) |
|
513 |
apply (drule OrdmemD, rule Ord_Hartog, assumption+, erule ltD) |
|
514 |
apply (drule ospec) |
|
515 |
apply (blast intro: ltI Ord_Hartog, force) |
|
516 |
done |
|
517 |
||
518 |
(* ********************************************************************** *) |
|
519 |
(* WO1 ==> \<forall>K. Card(K) --> DC(K) *) |
|
520 |
(* ********************************************************************** *) |
|
521 |
||
522 |
lemma images_eq: |
|
523 |
"[| \<forall>x \<in> A. f`x=g`x; f \<in> Df->Cf; g \<in> Dg->Cg; A \<subseteq> Df; A \<subseteq> Dg |] |
|
524 |
==> f``A = g``A" |
|
525 |
apply (simp (no_asm_simp) add: image_fun) |
|
526 |
done |
|
527 |
||
528 |
lemma lam_images_eq: |
|
529 |
"[| Ord(a); b \<in> a |] ==> (\<lambda>x \<in> a. h(x))``b = (\<lambda>x \<in> b. h(x))``b" |
|
530 |
apply (rule images_eq) |
|
531 |
apply (rule ballI) |
|
532 |
apply (drule OrdmemD [THEN subsetD], assumption+) |
|
533 |
apply simp |
|
534 |
apply (fast elim!: RepFunI OrdmemD intro!: lam_type)+ |
|
535 |
done |
|
536 |
||
537 |
lemma lam_type_RepFun: "(\<lambda>b \<in> a. h(b)) \<in> a -> {h(b). b \<in> a}" |
|
538 |
by (fast intro!: lam_type RepFunI) |
|
539 |
||
540 |
lemma lemmaX: |
|
541 |
"[| \<forall>Y \<in> Pow(X). Y \<prec> K --> (\<exists>x \<in> X. <Y, x> \<in> R); |
|
542 |
b \<in> K; Z \<in> Pow(X); Z \<prec> K |] |
|
543 |
==> {x \<in> X. <Z,x> \<in> R} \<noteq> 0" |
|
544 |
by blast |
|
545 |
||
546 |
||
547 |
lemma WO1_DC_lemma: |
|
548 |
"[| Card(K); well_ord(X,Q); |
|
549 |
\<forall>Y \<in> Pow(X). Y \<prec> K --> (\<exists>x \<in> X. <Y, x> \<in> R); b \<in> K |] |
|
550 |
==> ff(b, X, Q, R) \<in> {x \<in> X. <(\<lambda>c \<in> b. ff(c, X, Q, R))``b, x> \<in> R}" |
|
551 |
apply (rule_tac P = "b \<in> K" in impE, (erule_tac [2] asm_rl)+) |
|
552 |
apply (rule_tac i=b in Card_is_Ord [THEN Ord_in_Ord, THEN trans_induct], |
|
553 |
assumption+) |
|
554 |
apply (rule impI) |
|
555 |
apply (rule ff_def [THEN def_transrec, THEN ssubst]) |
|
556 |
apply (erule the_first_in, fast) |
|
557 |
apply (simp add: image_fun [OF lam_type_RepFun subset_refl]) |
|
558 |
apply (erule lemmaX, assumption) |
|
559 |
apply (blast intro: Card_is_Ord OrdmemD [THEN subsetD]) |
|
560 |
apply (blast intro: lesspoll_trans1 in_Card_imp_lesspoll RepFun_lepoll) |
|
561 |
done |
|
562 |
||
563 |
theorem WO1_DC_Card: "WO1 ==> \<forall>K. Card(K) --> DC(K)" |
|
564 |
apply (unfold DC_def WO1_def) |
|
565 |
apply (rule allI impI)+ |
|
566 |
apply (erule allE exE conjE)+ |
|
567 |
apply (rule_tac x = "\<lambda>b \<in> K. ff (b, X, Ra, R) " in bexI) |
|
568 |
apply (simp add: lam_images_eq [OF Card_is_Ord ltD]) |
|
569 |
apply (fast elim!: ltE WO1_DC_lemma [THEN CollectD2]) |
|
570 |
apply (rule_tac lam_type) |
|
571 |
apply (rule WO1_DC_lemma [THEN CollectD1], assumption+) |
|
572 |
done |
|
573 |
||
1196 | 574 |
end |