author | webertj |
Fri, 01 Jun 2007 23:21:40 +0200 | |
changeset 23193 | 1f2d94b6a8ef |
parent 16417 | 9bc16273c2d4 |
child 24783 | 5a3e336a2e37 |
permissions | -rw-r--r-- |
1478 | 1 |
(* Title: ZF/AC/WO6_WO1.thy |
1019 | 2 |
ID: $Id$ |
1478 | 3 |
Author: Krzysztof Grabczewski |
1019 | 4 |
|
12776 | 5 |
Proofs needed to state that formulations WO1,...,WO6 are all equivalent. |
6 |
The only hard one is WO6 ==> WO1. |
|
1019 | 7 |
|
12776 | 8 |
Every proof (except WO6 ==> WO1 and WO1 ==> WO2) are described as "clear" |
9 |
by Rubin & Rubin (page 2). |
|
10 |
They refer reader to a book by Gödel to see the proof WO1 ==> WO2. |
|
11 |
Fortunately order types made this proof also very easy. |
|
1019 | 12 |
*) |
13 |
||
16417 | 14 |
theory WO6_WO1 imports Cardinal_aux begin |
1019 | 15 |
|
12776 | 16 |
constdefs |
1019 | 17 |
(* Auxiliary definitions used in proof *) |
12776 | 18 |
NN :: "i => i" |
19 |
"NN(y) == {m \<in> nat. \<exists>a. \<exists>f. Ord(a) & domain(f)=a & |
|
20 |
(\<Union>b<a. f`b) = y & (\<forall>b<a. f`b \<lesssim> m)}" |
|
21 |
||
22 |
uu :: "[i, i, i, i] => i" |
|
23 |
"uu(f, beta, gamma, delta) == (f`beta * f`gamma) Int f`delta" |
|
24 |
||
25 |
(** Definitions for case 1 **) |
|
26 |
vv1 :: "[i, i, i] => i" |
|
27 |
"vv1(f,m,b) == |
|
28 |
let g = LEAST g. (\<exists>d. Ord(d) & (domain(uu(f,b,g,d)) \<noteq> 0 & |
|
29 |
domain(uu(f,b,g,d)) \<lesssim> m)); |
|
30 |
d = LEAST d. domain(uu(f,b,g,d)) \<noteq> 0 & |
|
31 |
domain(uu(f,b,g,d)) \<lesssim> m |
|
32 |
in if f`b \<noteq> 0 then domain(uu(f,b,g,d)) else 0" |
|
33 |
||
34 |
ww1 :: "[i, i, i] => i" |
|
35 |
"ww1(f,m,b) == f`b - vv1(f,m,b)" |
|
36 |
||
37 |
gg1 :: "[i, i, i] => i" |
|
38 |
"gg1(f,a,m) == \<lambda>b \<in> a++a. if b<a then vv1(f,m,b) else ww1(f,m,b--a)" |
|
39 |
||
40 |
(** Definitions for case 2 **) |
|
41 |
vv2 :: "[i, i, i, i] => i" |
|
42 |
"vv2(f,b,g,s) == |
|
43 |
if f`g \<noteq> 0 then {uu(f, b, g, LEAST d. uu(f,b,g,d) \<noteq> 0)`s} else 0" |
|
44 |
||
45 |
ww2 :: "[i, i, i, i] => i" |
|
46 |
"ww2(f,b,g,s) == f`g - vv2(f,b,g,s)" |
|
47 |
||
48 |
gg2 :: "[i, i, i, i] => i" |
|
49 |
"gg2(f,a,b,s) == |
|
50 |
\<lambda>g \<in> a++a. if g<a then vv2(f,b,g,s) else ww2(f,b,g--a,s)" |
|
51 |
||
52 |
||
53 |
lemma WO2_WO3: "WO2 ==> WO3" |
|
54 |
by (unfold WO2_def WO3_def, fast) |
|
55 |
||
56 |
(* ********************************************************************** *) |
|
57 |
||
58 |
lemma WO3_WO1: "WO3 ==> WO1" |
|
59 |
apply (unfold eqpoll_def WO1_def WO3_def) |
|
60 |
apply (intro allI) |
|
61 |
apply (drule_tac x=A in spec) |
|
62 |
apply (blast intro: bij_is_inj well_ord_rvimage |
|
63 |
well_ord_Memrel [THEN well_ord_subset]) |
|
64 |
done |
|
65 |
||
66 |
(* ********************************************************************** *) |
|
67 |
||
68 |
lemma WO1_WO2: "WO1 ==> WO2" |
|
69 |
apply (unfold eqpoll_def WO1_def WO2_def) |
|
70 |
apply (blast intro!: Ord_ordertype ordermap_bij) |
|
71 |
done |
|
72 |
||
73 |
(* ********************************************************************** *) |
|
74 |
||
75 |
lemma lam_sets: "f \<in> A->B ==> (\<lambda>x \<in> A. {f`x}): A -> {{b}. b \<in> B}" |
|
76 |
by (fast intro!: lam_type apply_type) |
|
77 |
||
78 |
lemma surj_imp_eq_: "f \<in> surj(A,B) ==> (\<Union>a \<in> A. {f`a}) = B" |
|
79 |
apply (unfold surj_def) |
|
80 |
apply (fast elim!: apply_type) |
|
81 |
done |
|
82 |
||
83 |
lemma surj_imp_eq: "[| f \<in> surj(A,B); Ord(A) |] ==> (\<Union>a<A. {f`a}) = B" |
|
84 |
by (fast dest!: surj_imp_eq_ intro!: ltI elim!: ltE) |
|
85 |
||
86 |
lemma WO1_WO4: "WO1 ==> WO4(1)" |
|
87 |
apply (unfold WO1_def WO4_def) |
|
88 |
apply (rule allI) |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
89 |
apply (erule_tac x = A in allE) |
12776 | 90 |
apply (erule exE) |
91 |
apply (intro exI conjI) |
|
92 |
apply (erule Ord_ordertype) |
|
93 |
apply (erule ordermap_bij [THEN bij_converse_bij, THEN bij_is_fun, THEN lam_sets, THEN domain_of_fun]) |
|
94 |
apply (simp_all add: singleton_eqpoll_1 eqpoll_imp_lepoll Ord_ordertype |
|
13175
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
95 |
ordermap_bij [THEN bij_converse_bij, THEN bij_is_surj, THEN surj_imp_eq] |
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
96 |
ltD) |
12776 | 97 |
done |
98 |
||
99 |
(* ********************************************************************** *) |
|
100 |
||
101 |
lemma WO4_mono: "[| m\<le>n; WO4(m) |] ==> WO4(n)" |
|
102 |
apply (unfold WO4_def) |
|
103 |
apply (blast dest!: spec intro: lepoll_trans [OF _ le_imp_lepoll]) |
|
104 |
done |
|
105 |
||
106 |
(* ********************************************************************** *) |
|
107 |
||
108 |
lemma WO4_WO5: "[| m \<in> nat; 1\<le>m; WO4(m) |] ==> WO5" |
|
109 |
by (unfold WO4_def WO5_def, blast) |
|
110 |
||
111 |
(* ********************************************************************** *) |
|
112 |
||
113 |
lemma WO5_WO6: "WO5 ==> WO6" |
|
114 |
by (unfold WO4_def WO5_def WO6_def, blast) |
|
115 |
||
116 |
||
117 |
(* ********************************************************************** |
|
118 |
The proof of "WO6 ==> WO1". Simplified by L C Paulson. |
|
119 |
||
120 |
From the book "Equivalents of the Axiom of Choice" by Rubin & Rubin, |
|
121 |
pages 2-5 |
|
122 |
************************************************************************* *) |
|
123 |
||
124 |
lemma lt_oadd_odiff_disj: |
|
125 |
"[| k < i++j; Ord(i); Ord(j) |] |
|
126 |
==> k < i | (~ k<i & k = i ++ (k--i) & (k--i)<j)" |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
127 |
apply (rule_tac i = k and j = i in Ord_linear2) |
12776 | 128 |
prefer 4 |
129 |
apply (drule odiff_lt_mono2, assumption) |
|
130 |
apply (simp add: oadd_odiff_inverse odiff_oadd_inverse) |
|
131 |
apply (auto elim!: lt_Ord) |
|
132 |
done |
|
133 |
||
134 |
||
135 |
(* ********************************************************************** *) |
|
136 |
(* The most complicated part of the proof - lemma ii - p. 2-4 *) |
|
137 |
(* ********************************************************************** *) |
|
138 |
||
139 |
(* ********************************************************************** *) |
|
140 |
(* some properties of relation uu(beta, gamma, delta) - p. 2 *) |
|
141 |
(* ********************************************************************** *) |
|
1019 | 142 |
|
12776 | 143 |
lemma domain_uu_subset: "domain(uu(f,b,g,d)) \<subseteq> f`b" |
144 |
by (unfold uu_def, blast) |
|
145 |
||
146 |
lemma quant_domain_uu_lepoll_m: |
|
147 |
"\<forall>b<a. f`b \<lesssim> m ==> \<forall>b<a. \<forall>g<a. \<forall>d<a. domain(uu(f,b,g,d)) \<lesssim> m" |
|
148 |
by (blast intro: domain_uu_subset [THEN subset_imp_lepoll] lepoll_trans) |
|
149 |
||
150 |
lemma uu_subset1: "uu(f,b,g,d) \<subseteq> f`b * f`g" |
|
151 |
by (unfold uu_def, blast) |
|
152 |
||
153 |
lemma uu_subset2: "uu(f,b,g,d) \<subseteq> f`d" |
|
154 |
by (unfold uu_def, blast) |
|
155 |
||
156 |
lemma uu_lepoll_m: "[| \<forall>b<a. f`b \<lesssim> m; d<a |] ==> uu(f,b,g,d) \<lesssim> m" |
|
157 |
by (blast intro: uu_subset2 [THEN subset_imp_lepoll] lepoll_trans) |
|
158 |
||
159 |
(* ********************************************************************** *) |
|
160 |
(* Two cases for lemma ii *) |
|
161 |
(* ********************************************************************** *) |
|
162 |
lemma cases: |
|
163 |
"\<forall>b<a. \<forall>g<a. \<forall>d<a. u(f,b,g,d) \<lesssim> m |
|
164 |
==> (\<forall>b<a. f`b \<noteq> 0 --> |
|
165 |
(\<exists>g<a. \<exists>d<a. u(f,b,g,d) \<noteq> 0 & u(f,b,g,d) \<prec> m)) |
|
166 |
| (\<exists>b<a. f`b \<noteq> 0 & (\<forall>g<a. \<forall>d<a. u(f,b,g,d) \<noteq> 0 --> |
|
167 |
u(f,b,g,d) \<approx> m))" |
|
168 |
apply (unfold lesspoll_def) |
|
169 |
apply (blast del: equalityI) |
|
170 |
done |
|
171 |
||
172 |
(* ********************************************************************** *) |
|
173 |
(* Lemmas used in both cases *) |
|
174 |
(* ********************************************************************** *) |
|
175 |
lemma UN_oadd: "Ord(a) ==> (\<Union>b<a++a. C(b)) = (\<Union>b<a. C(b) Un C(a++b))" |
|
176 |
by (blast intro: ltI lt_oadd1 oadd_lt_mono2 dest!: lt_oadd_disj) |
|
177 |
||
178 |
||
179 |
(* ********************************************************************** *) |
|
180 |
(* Case 1: lemmas *) |
|
181 |
(* ********************************************************************** *) |
|
182 |
||
183 |
lemma vv1_subset: "vv1(f,m,b) \<subseteq> f`b" |
|
184 |
by (simp add: vv1_def Let_def domain_uu_subset) |
|
185 |
||
186 |
(* ********************************************************************** *) |
|
187 |
(* Case 1: Union of images is the whole "y" *) |
|
188 |
(* ********************************************************************** *) |
|
189 |
lemma UN_gg1_eq: |
|
190 |
"[| Ord(a); m \<in> nat |] ==> (\<Union>b<a++a. gg1(f,a,m)`b) = (\<Union>b<a. f`b)" |
|
191 |
by (simp add: gg1_def UN_oadd lt_oadd1 oadd_le_self [THEN le_imp_not_lt] |
|
192 |
lt_Ord odiff_oadd_inverse ltD vv1_subset [THEN Diff_partition] |
|
193 |
ww1_def) |
|
194 |
||
195 |
lemma domain_gg1: "domain(gg1(f,a,m)) = a++a" |
|
196 |
by (simp add: lam_funtype [THEN domain_of_fun] gg1_def) |
|
992 | 197 |
|
12776 | 198 |
(* ********************************************************************** *) |
199 |
(* every value of defined function is less than or equipollent to m *) |
|
200 |
(* ********************************************************************** *) |
|
201 |
lemma nested_LeastI: |
|
202 |
"[| P(a, b); Ord(a); Ord(b); |
|
203 |
Least_a = (LEAST a. \<exists>x. Ord(x) & P(a, x)) |] |
|
204 |
==> P(Least_a, LEAST b. P(Least_a, b))" |
|
205 |
apply (erule ssubst) |
|
206 |
apply (rule_tac Q = "%z. P (z, LEAST b. P (z, b))" in LeastI2) |
|
207 |
apply (fast elim!: LeastI)+ |
|
208 |
done |
|
209 |
||
210 |
lemmas nested_Least_instance = |
|
211 |
nested_LeastI [of "%g d. domain(uu(f,b,g,d)) \<noteq> 0 & |
|
212 |
domain(uu(f,b,g,d)) \<lesssim> m", |
|
213 |
standard] (*generalizes the Variables!*) |
|
1019 | 214 |
|
12776 | 215 |
lemma gg1_lepoll_m: |
216 |
"[| Ord(a); m \<in> nat; |
|
217 |
\<forall>b<a. f`b \<noteq>0 --> |
|
218 |
(\<exists>g<a. \<exists>d<a. domain(uu(f,b,g,d)) \<noteq> 0 & |
|
219 |
domain(uu(f,b,g,d)) \<lesssim> m); |
|
220 |
\<forall>b<a. f`b \<lesssim> succ(m); b<a++a |] |
|
221 |
==> gg1(f,a,m)`b \<lesssim> m" |
|
13175
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
222 |
apply (simp add: gg1_def empty_lepollI) |
12776 | 223 |
apply (safe dest!: lt_oadd_odiff_disj) |
224 |
(*Case b<a \<in> show vv1(f,m,b) \<lesssim> m *) |
|
13175
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
225 |
apply (simp add: vv1_def Let_def empty_lepollI) |
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
226 |
apply (fast intro: nested_Least_instance [THEN conjunct2] |
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
227 |
elim!: lt_Ord) |
12776 | 228 |
(*Case a\<le>b \<in> show ww1(f,m,b--a) \<lesssim> m *) |
13175
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
229 |
apply (simp add: ww1_def empty_lepollI) |
12776 | 230 |
apply (case_tac "f` (b--a) = 0", simp add: empty_lepollI) |
231 |
apply (rule Diff_lepoll, blast) |
|
232 |
apply (rule vv1_subset) |
|
233 |
apply (drule ospec [THEN mp], assumption+) |
|
234 |
apply (elim oexE conjE) |
|
235 |
apply (simp add: vv1_def Let_def lt_Ord nested_Least_instance [THEN conjunct1]) |
|
236 |
done |
|
237 |
||
238 |
(* ********************************************************************** *) |
|
239 |
(* Case 2: lemmas *) |
|
240 |
(* ********************************************************************** *) |
|
1042 | 241 |
|
12776 | 242 |
(* ********************************************************************** *) |
243 |
(* Case 2: vv2_subset *) |
|
244 |
(* ********************************************************************** *) |
|
245 |
||
246 |
lemma ex_d_uu_not_empty: |
|
247 |
"[| b<a; g<a; f`b\<noteq>0; f`g\<noteq>0; |
|
248 |
y*y \<subseteq> y; (\<Union>b<a. f`b)=y |] |
|
249 |
==> \<exists>d<a. uu(f,b,g,d) \<noteq> 0" |
|
250 |
by (unfold uu_def, blast) |
|
251 |
||
252 |
lemma uu_not_empty: |
|
253 |
"[| b<a; g<a; f`b\<noteq>0; f`g\<noteq>0; y*y \<subseteq> y; (\<Union>b<a. f`b)=y |] |
|
254 |
==> uu(f,b,g,LEAST d. (uu(f,b,g,d) \<noteq> 0)) \<noteq> 0" |
|
255 |
apply (drule ex_d_uu_not_empty, assumption+) |
|
256 |
apply (fast elim!: LeastI lt_Ord) |
|
257 |
done |
|
258 |
||
259 |
lemma not_empty_rel_imp_domain: "[| r \<subseteq> A*B; r\<noteq>0 |] ==> domain(r)\<noteq>0" |
|
260 |
by blast |
|
261 |
||
262 |
lemma Least_uu_not_empty_lt_a: |
|
263 |
"[| b<a; g<a; f`b\<noteq>0; f`g\<noteq>0; y*y \<subseteq> y; (\<Union>b<a. f`b)=y |] |
|
264 |
==> (LEAST d. uu(f,b,g,d) \<noteq> 0) < a" |
|
265 |
apply (erule ex_d_uu_not_empty [THEN oexE], assumption+) |
|
266 |
apply (blast intro: Least_le [THEN lt_trans1] lt_Ord) |
|
267 |
done |
|
268 |
||
269 |
lemma subset_Diff_sing: "[| B \<subseteq> A; a\<notin>B |] ==> B \<subseteq> A-{a}" |
|
270 |
by blast |
|
1042 | 271 |
|
12776 | 272 |
(*Could this be proved more directly?*) |
273 |
lemma supset_lepoll_imp_eq: |
|
274 |
"[| A \<lesssim> m; m \<lesssim> B; B \<subseteq> A; m \<in> nat |] ==> A=B" |
|
275 |
apply (erule natE) |
|
276 |
apply (fast dest!: lepoll_0_is_0 intro!: equalityI) |
|
277 |
apply (safe intro!: equalityI) |
|
278 |
apply (rule ccontr) |
|
279 |
apply (rule succ_lepoll_natE) |
|
280 |
apply (erule lepoll_trans) |
|
281 |
apply (rule lepoll_trans) |
|
282 |
apply (erule subset_Diff_sing [THEN subset_imp_lepoll], assumption) |
|
283 |
apply (rule Diff_sing_lepoll, assumption+) |
|
284 |
done |
|
285 |
||
286 |
lemma uu_Least_is_fun: |
|
287 |
"[| \<forall>g<a. \<forall>d<a. domain(uu(f, b, g, d))\<noteq>0 --> |
|
288 |
domain(uu(f, b, g, d)) \<approx> succ(m); |
|
289 |
\<forall>b<a. f`b \<lesssim> succ(m); y*y \<subseteq> y; |
|
290 |
(\<Union>b<a. f`b)=y; b<a; g<a; d<a; |
|
291 |
f`b\<noteq>0; f`g\<noteq>0; m \<in> nat; s \<in> f`b |] |
|
292 |
==> uu(f, b, g, LEAST d. uu(f,b,g,d)\<noteq>0) \<in> f`b -> f`g" |
|
293 |
apply (drule_tac x2=g in ospec [THEN ospec, THEN mp]) |
|
294 |
apply (rule_tac [3] not_empty_rel_imp_domain [OF uu_subset1 uu_not_empty]) |
|
295 |
apply (rule_tac [2] Least_uu_not_empty_lt_a, assumption+) |
|
296 |
apply (rule rel_is_fun) |
|
297 |
apply (erule eqpoll_sym [THEN eqpoll_imp_lepoll]) |
|
298 |
apply (erule uu_lepoll_m) |
|
299 |
apply (rule Least_uu_not_empty_lt_a, assumption+) |
|
300 |
apply (rule uu_subset1) |
|
301 |
apply (rule supset_lepoll_imp_eq [OF _ eqpoll_sym [THEN eqpoll_imp_lepoll]]) |
|
302 |
apply (fast intro!: domain_uu_subset)+ |
|
303 |
done |
|
304 |
||
305 |
lemma vv2_subset: |
|
306 |
"[| \<forall>g<a. \<forall>d<a. domain(uu(f, b, g, d))\<noteq>0 --> |
|
307 |
domain(uu(f, b, g, d)) \<approx> succ(m); |
|
308 |
\<forall>b<a. f`b \<lesssim> succ(m); y*y \<subseteq> y; |
|
309 |
(\<Union>b<a. f`b)=y; b<a; g<a; m \<in> nat; s \<in> f`b |] |
|
310 |
==> vv2(f,b,g,s) \<subseteq> f`g" |
|
311 |
apply (simp add: vv2_def) |
|
312 |
apply (blast intro: uu_Least_is_fun [THEN apply_type]) |
|
313 |
done |
|
314 |
||
315 |
(* ********************************************************************** *) |
|
316 |
(* Case 2: Union of images is the whole "y" *) |
|
317 |
(* ********************************************************************** *) |
|
318 |
lemma UN_gg2_eq: |
|
319 |
"[| \<forall>g<a. \<forall>d<a. domain(uu(f,b,g,d)) \<noteq> 0 --> |
|
320 |
domain(uu(f,b,g,d)) \<approx> succ(m); |
|
321 |
\<forall>b<a. f`b \<lesssim> succ(m); y*y \<subseteq> y; |
|
322 |
(\<Union>b<a. f`b)=y; Ord(a); m \<in> nat; s \<in> f`b; b<a |] |
|
323 |
==> (\<Union>g<a++a. gg2(f,a,b,s) ` g) = y" |
|
324 |
apply (unfold gg2_def) |
|
13175
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
325 |
apply (drule sym) |
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
326 |
apply (simp add: ltD UN_oadd oadd_le_self [THEN le_imp_not_lt] |
12776 | 327 |
lt_Ord odiff_oadd_inverse ww2_def |
328 |
vv2_subset [THEN Diff_partition]) |
|
329 |
done |
|
330 |
||
331 |
lemma domain_gg2: "domain(gg2(f,a,b,s)) = a++a" |
|
332 |
by (simp add: lam_funtype [THEN domain_of_fun] gg2_def) |
|
333 |
||
1042 | 334 |
|
12776 | 335 |
(* ********************************************************************** *) |
336 |
(* every value of defined function is less than or equipollent to m *) |
|
337 |
(* ********************************************************************** *) |
|
338 |
||
339 |
lemma vv2_lepoll: "[| m \<in> nat; m\<noteq>0 |] ==> vv2(f,b,g,s) \<lesssim> m" |
|
340 |
apply (unfold vv2_def) |
|
341 |
apply (simp add: empty_lepollI) |
|
342 |
apply (fast dest!: le_imp_subset [THEN subset_imp_lepoll, THEN lepoll_0_is_0] |
|
343 |
intro!: singleton_eqpoll_1 [THEN eqpoll_imp_lepoll, THEN lepoll_trans] |
|
344 |
not_lt_imp_le [THEN le_imp_subset, THEN subset_imp_lepoll] |
|
345 |
nat_into_Ord nat_1I) |
|
346 |
done |
|
347 |
||
348 |
lemma ww2_lepoll: |
|
349 |
"[| \<forall>b<a. f`b \<lesssim> succ(m); g<a; m \<in> nat; vv2(f,b,g,d) \<subseteq> f`g |] |
|
350 |
==> ww2(f,b,g,d) \<lesssim> m" |
|
351 |
apply (unfold ww2_def) |
|
352 |
apply (case_tac "f`g = 0") |
|
353 |
apply (simp add: empty_lepollI) |
|
354 |
apply (drule ospec, assumption) |
|
355 |
apply (rule Diff_lepoll, assumption+) |
|
356 |
apply (simp add: vv2_def not_emptyI) |
|
357 |
done |
|
358 |
||
359 |
lemma gg2_lepoll_m: |
|
360 |
"[| \<forall>g<a. \<forall>d<a. domain(uu(f,b,g,d)) \<noteq> 0 --> |
|
361 |
domain(uu(f,b,g,d)) \<approx> succ(m); |
|
362 |
\<forall>b<a. f`b \<lesssim> succ(m); y*y \<subseteq> y; |
|
363 |
(\<Union>b<a. f`b)=y; b<a; s \<in> f`b; m \<in> nat; m\<noteq> 0; g<a++a |] |
|
364 |
==> gg2(f,a,b,s) ` g \<lesssim> m" |
|
13175
81082cfa5618
new definition of "apply" and new simprule "beta_if"
paulson
parents:
12820
diff
changeset
|
365 |
apply (simp add: gg2_def empty_lepollI) |
12776 | 366 |
apply (safe elim!: lt_Ord2 dest!: lt_oadd_odiff_disj) |
367 |
apply (simp add: vv2_lepoll) |
|
368 |
apply (simp add: ww2_lepoll vv2_subset) |
|
369 |
done |
|
370 |
||
371 |
(* ********************************************************************** *) |
|
372 |
(* lemma ii *) |
|
373 |
(* ********************************************************************** *) |
|
374 |
lemma lemma_ii: "[| succ(m) \<in> NN(y); y*y \<subseteq> y; m \<in> nat; m\<noteq>0 |] ==> m \<in> NN(y)" |
|
375 |
apply (unfold NN_def) |
|
376 |
apply (elim CollectE exE conjE) |
|
377 |
apply (rule quant_domain_uu_lepoll_m [THEN cases, THEN disjE], assumption) |
|
378 |
(* case 1 *) |
|
379 |
apply (simp add: lesspoll_succ_iff) |
|
380 |
apply (rule_tac x = "a++a" in exI) |
|
381 |
apply (fast intro!: Ord_oadd domain_gg1 UN_gg1_eq gg1_lepoll_m) |
|
382 |
(* case 2 *) |
|
383 |
apply (elim oexE conjE) |
|
384 |
apply (rule_tac A = "f`?B" in not_emptyE, assumption) |
|
385 |
apply (rule CollectI) |
|
386 |
apply (erule succ_natD) |
|
387 |
apply (rule_tac x = "a++a" in exI) |
|
388 |
apply (rule_tac x = "gg2 (f,a,b,x) " in exI) |
|
389 |
(*Calling fast_tac might get rid of the res_inst_tac calls, but it |
|
390 |
is just too slow.*) |
|
391 |
apply (simp add: Ord_oadd domain_gg2 UN_gg2_eq gg2_lepoll_m) |
|
392 |
done |
|
393 |
||
394 |
||
395 |
(* ********************************************************************** *) |
|
396 |
(* lemma iv - p. 4: *) |
|
397 |
(* For every set x there is a set y such that x Un (y * y) \<subseteq> y *) |
|
398 |
(* ********************************************************************** *) |
|
399 |
||
400 |
||
401 |
(* The leading \<forall>-quantifier looks odd but makes the proofs shorter |
|
402 |
(used only in the following two lemmas) *) |
|
1042 | 403 |
|
12776 | 404 |
lemma z_n_subset_z_succ_n: |
405 |
"\<forall>n \<in> nat. rec(n, x, %k r. r Un r*r) \<subseteq> rec(succ(n), x, %k r. r Un r*r)" |
|
406 |
by (fast intro: rec_succ [THEN ssubst]) |
|
407 |
||
408 |
lemma le_subsets: |
|
409 |
"[| \<forall>n \<in> nat. f(n)<=f(succ(n)); n\<le>m; n \<in> nat; m \<in> nat |] |
|
410 |
==> f(n)<=f(m)" |
|
411 |
apply (erule_tac P = "n\<le>m" in rev_mp) |
|
412 |
apply (rule_tac P = "%z. n\<le>z --> f (n) \<subseteq> f (z) " in nat_induct) |
|
413 |
apply (auto simp add: le_iff) |
|
414 |
done |
|
415 |
||
416 |
lemma le_imp_rec_subset: |
|
417 |
"[| n\<le>m; m \<in> nat |] |
|
418 |
==> rec(n, x, %k r. r Un r*r) \<subseteq> rec(m, x, %k r. r Un r*r)" |
|
419 |
apply (rule z_n_subset_z_succ_n [THEN le_subsets]) |
|
420 |
apply (blast intro: lt_nat_in_nat)+ |
|
421 |
done |
|
422 |
||
423 |
lemma lemma_iv: "\<exists>y. x Un y*y \<subseteq> y" |
|
424 |
apply (rule_tac x = "\<Union>n \<in> nat. rec (n, x, %k r. r Un r*r) " in exI) |
|
425 |
apply safe |
|
426 |
apply (rule nat_0I [THEN UN_I], simp) |
|
427 |
apply (rule_tac a = "succ (n Un na) " in UN_I) |
|
428 |
apply (erule Un_nat_type [THEN nat_succI], assumption) |
|
429 |
apply (auto intro: le_imp_rec_subset [THEN subsetD] |
|
430 |
intro!: Un_upper1_le Un_upper2_le Un_nat_type |
|
431 |
elim!: nat_into_Ord) |
|
432 |
done |
|
1019 | 433 |
|
12776 | 434 |
(* ********************************************************************** *) |
435 |
(* Rubin & Rubin wrote, *) |
|
436 |
(* "It follows from (ii) and mathematical induction that if y*y \<subseteq> y then *) |
|
437 |
(* y can be well-ordered" *) |
|
438 |
||
439 |
(* In fact we have to prove *) |
|
440 |
(* * WO6 ==> NN(y) \<noteq> 0 *) |
|
441 |
(* * reverse induction which lets us infer that 1 \<in> NN(y) *) |
|
442 |
(* * 1 \<in> NN(y) ==> y can be well-ordered *) |
|
443 |
(* ********************************************************************** *) |
|
444 |
||
445 |
(* ********************************************************************** *) |
|
446 |
(* WO6 ==> NN(y) \<noteq> 0 *) |
|
447 |
(* ********************************************************************** *) |
|
448 |
||
449 |
lemma WO6_imp_NN_not_empty: "WO6 ==> NN(y) \<noteq> 0" |
|
12820 | 450 |
by (unfold WO6_def NN_def, clarify, blast) |
12776 | 451 |
|
452 |
(* ********************************************************************** *) |
|
453 |
(* 1 \<in> NN(y) ==> y can be well-ordered *) |
|
454 |
(* ********************************************************************** *) |
|
455 |
||
456 |
lemma lemma1: |
|
457 |
"[| (\<Union>b<a. f`b)=y; x \<in> y; \<forall>b<a. f`b \<lesssim> 1; Ord(a) |] ==> \<exists>c<a. f`c = {x}" |
|
458 |
by (fast elim!: lepoll_1_is_sing) |
|
459 |
||
460 |
lemma lemma2: |
|
461 |
"[| (\<Union>b<a. f`b)=y; x \<in> y; \<forall>b<a. f`b \<lesssim> 1; Ord(a) |] |
|
462 |
==> f` (LEAST i. f`i = {x}) = {x}" |
|
463 |
apply (drule lemma1, assumption+) |
|
464 |
apply (fast elim!: lt_Ord intro: LeastI) |
|
465 |
done |
|
1019 | 466 |
|
12776 | 467 |
lemma NN_imp_ex_inj: "1 \<in> NN(y) ==> \<exists>a f. Ord(a) & f \<in> inj(y, a)" |
468 |
apply (unfold NN_def) |
|
469 |
apply (elim CollectE exE conjE) |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
470 |
apply (rule_tac x = a in exI) |
12776 | 471 |
apply (rule_tac x = "\<lambda>x \<in> y. LEAST i. f`i = {x}" in exI) |
472 |
apply (rule conjI, assumption) |
|
473 |
apply (rule_tac d = "%i. THE x. x \<in> f`i" in lam_injective) |
|
474 |
apply (drule lemma1, assumption+) |
|
475 |
apply (fast elim!: Least_le [THEN lt_trans1, THEN ltD] lt_Ord) |
|
476 |
apply (rule lemma2 [THEN ssubst], assumption+, blast) |
|
477 |
done |
|
478 |
||
479 |
lemma y_well_ord: "[| y*y \<subseteq> y; 1 \<in> NN(y) |] ==> \<exists>r. well_ord(y, r)" |
|
480 |
apply (drule NN_imp_ex_inj) |
|
481 |
apply (fast elim!: well_ord_rvimage [OF _ well_ord_Memrel]) |
|
482 |
done |
|
483 |
||
484 |
(* ********************************************************************** *) |
|
485 |
(* reverse induction which lets us infer that 1 \<in> NN(y) *) |
|
486 |
(* ********************************************************************** *) |
|
487 |
||
488 |
lemma rev_induct_lemma [rule_format]: |
|
489 |
"[| n \<in> nat; !!m. [| m \<in> nat; m\<noteq>0; P(succ(m)) |] ==> P(m) |] |
|
490 |
==> n\<noteq>0 --> P(n) --> P(1)" |
|
491 |
by (erule nat_induct, blast+) |
|
492 |
||
493 |
lemma rev_induct: |
|
494 |
"[| n \<in> nat; P(n); n\<noteq>0; |
|
495 |
!!m. [| m \<in> nat; m\<noteq>0; P(succ(m)) |] ==> P(m) |] |
|
496 |
==> P(1)" |
|
497 |
by (rule rev_induct_lemma, blast+) |
|
1019 | 498 |
|
12776 | 499 |
lemma NN_into_nat: "n \<in> NN(y) ==> n \<in> nat" |
500 |
by (simp add: NN_def) |
|
501 |
||
502 |
lemma lemma3: "[| n \<in> NN(y); y*y \<subseteq> y; n\<noteq>0 |] ==> 1 \<in> NN(y)" |
|
503 |
apply (rule rev_induct [OF NN_into_nat], assumption+) |
|
504 |
apply (rule lemma_ii, assumption+) |
|
505 |
done |
|
506 |
||
507 |
(* ********************************************************************** *) |
|
508 |
(* Main theorem "WO6 ==> WO1" *) |
|
509 |
(* ********************************************************************** *) |
|
510 |
||
511 |
(* another helpful lemma *) |
|
512 |
lemma NN_y_0: "0 \<in> NN(y) ==> y=0" |
|
513 |
apply (unfold NN_def) |
|
514 |
apply (fast intro!: equalityI dest!: lepoll_0_is_0 elim: subst) |
|
515 |
done |
|
516 |
||
517 |
lemma WO6_imp_WO1: "WO6 ==> WO1" |
|
518 |
apply (unfold WO1_def) |
|
519 |
apply (rule allI) |
|
520 |
apply (case_tac "A=0") |
|
521 |
apply (fast intro!: well_ord_Memrel nat_0I [THEN nat_into_Ord]) |
|
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13175
diff
changeset
|
522 |
apply (rule_tac x1 = A in lemma_iv [THEN revcut_rl]) |
12776 | 523 |
apply (erule exE) |
524 |
apply (drule WO6_imp_NN_not_empty) |
|
525 |
apply (erule Un_subset_iff [THEN iffD1, THEN conjE]) |
|
526 |
apply (erule_tac A = "NN (y) " in not_emptyE) |
|
527 |
apply (frule y_well_ord) |
|
528 |
apply (fast intro!: lemma3 dest!: NN_y_0 elim!: not_emptyE) |
|
529 |
apply (fast elim: well_ord_subset) |
|
530 |
done |
|
531 |
||
1019 | 532 |
end |