author | wenzelm |
Sun, 21 Aug 2022 15:00:14 +0200 | |
changeset 75952 | 864b10457a7d |
parent 75625 | 0dd3ac5fdbaa |
child 76951 | 293caf3dbecd |
permissions | -rw-r--r-- |
55056 | 1 |
(* Title: HOL/BNF_Cardinal_Arithmetic.thy |
54474 | 2 |
Author: Dmitriy Traytel, TU Muenchen |
3 |
Copyright 2012 |
|
4 |
||
55059 | 5 |
Cardinal arithmetic as needed by bounded natural functors. |
54474 | 6 |
*) |
7 |
||
60758 | 8 |
section \<open>Cardinal Arithmetic as Needed by Bounded Natural Functors\<close> |
54474 | 9 |
|
55056 | 10 |
theory BNF_Cardinal_Arithmetic |
11 |
imports BNF_Cardinal_Order_Relation |
|
54474 | 12 |
begin |
13 |
||
14 |
lemma dir_image: "\<lbrakk>\<And>x y. (f x = f y) = (x = y); Card_order r\<rbrakk> \<Longrightarrow> r =o dir_image r f" |
|
15 |
by (rule dir_image_ordIso) (auto simp add: inj_on_def card_order_on_def) |
|
16 |
||
17 |
lemma card_order_dir_image: |
|
18 |
assumes bij: "bij f" and co: "card_order r" |
|
19 |
shows "card_order (dir_image r f)" |
|
20 |
proof - |
|
21 |
from assms have "Field (dir_image r f) = UNIV" |
|
22 |
using card_order_on_Card_order[of UNIV r] unfolding bij_def dir_image_Field by auto |
|
23 |
moreover from bij have "\<And>x y. (f x = f y) = (x = y)" unfolding bij_def inj_on_def by auto |
|
24 |
with co have "Card_order (dir_image r f)" |
|
25 |
using card_order_on_Card_order[of UNIV r] Card_order_ordIso2[OF _ dir_image] by blast |
|
26 |
ultimately show ?thesis by auto |
|
27 |
qed |
|
28 |
||
29 |
lemma ordIso_refl: "Card_order r \<Longrightarrow> r =o r" |
|
30 |
by (rule card_order_on_ordIso) |
|
31 |
||
32 |
lemma ordLeq_refl: "Card_order r \<Longrightarrow> r \<le>o r" |
|
33 |
by (rule ordIso_imp_ordLeq, rule card_order_on_ordIso) |
|
34 |
||
35 |
lemma card_of_ordIso_subst: "A = B \<Longrightarrow> |A| =o |B|" |
|
36 |
by (simp only: ordIso_refl card_of_Card_order) |
|
37 |
||
38 |
lemma Field_card_order: "card_order r \<Longrightarrow> Field r = UNIV" |
|
39 |
using card_order_on_Card_order[of UNIV r] by simp |
|
40 |
||
41 |
||
60758 | 42 |
subsection \<open>Zero\<close> |
54474 | 43 |
|
44 |
definition czero where |
|
45 |
"czero = card_of {}" |
|
46 |
||
47 |
lemma czero_ordIso: |
|
48 |
"czero =o czero" |
|
49 |
using card_of_empty_ordIso by (simp add: czero_def) |
|
50 |
||
51 |
lemma card_of_ordIso_czero_iff_empty: |
|
52 |
"|A| =o (czero :: 'b rel) \<longleftrightarrow> A = ({} :: 'a set)" |
|
53 |
unfolding czero_def by (rule iffI[OF card_of_empty2]) (auto simp: card_of_refl card_of_empty_ordIso) |
|
54 |
||
55 |
(* A "not czero" Cardinal predicate *) |
|
56 |
abbreviation Cnotzero where |
|
57 |
"Cnotzero (r :: 'a rel) \<equiv> \<not>(r =o (czero :: 'a rel)) \<and> Card_order r" |
|
58 |
||
59 |
(*helper*) |
|
60 |
lemma Cnotzero_imp_not_empty: "Cnotzero r \<Longrightarrow> Field r \<noteq> {}" |
|
55811 | 61 |
unfolding Card_order_iff_ordIso_card_of czero_def by force |
54474 | 62 |
|
63 |
lemma czeroI: |
|
64 |
"\<lbrakk>Card_order r; Field r = {}\<rbrakk> \<Longrightarrow> r =o czero" |
|
65 |
using Cnotzero_imp_not_empty ordIso_transitive[OF _ czero_ordIso] by blast |
|
66 |
||
67 |
lemma czeroE: |
|
68 |
"r =o czero \<Longrightarrow> Field r = {}" |
|
69 |
unfolding czero_def |
|
70 |
by (drule card_of_cong) (simp only: Field_card_of card_of_empty2) |
|
71 |
||
72 |
lemma Cnotzero_mono: |
|
73 |
"\<lbrakk>Cnotzero r; Card_order q; r \<le>o q\<rbrakk> \<Longrightarrow> Cnotzero q" |
|
74 |
apply (rule ccontr) |
|
75 |
apply auto |
|
76 |
apply (drule czeroE) |
|
77 |
apply (erule notE) |
|
78 |
apply (erule czeroI) |
|
79 |
apply (drule card_of_mono2) |
|
80 |
apply (simp only: card_of_empty3) |
|
81 |
done |
|
82 |
||
60758 | 83 |
subsection \<open>(In)finite cardinals\<close> |
54474 | 84 |
|
85 |
definition cinfinite where |
|
54578
9387251b6a46
eliminated dependence of BNF on Infinite_Set by moving 3 theorems from the latter to Main
traytel
parents:
54482
diff
changeset
|
86 |
"cinfinite r = (\<not> finite (Field r))" |
54474 | 87 |
|
88 |
abbreviation Cinfinite where |
|
89 |
"Cinfinite r \<equiv> cinfinite r \<and> Card_order r" |
|
90 |
||
91 |
definition cfinite where |
|
92 |
"cfinite r = finite (Field r)" |
|
93 |
||
94 |
abbreviation Cfinite where |
|
95 |
"Cfinite r \<equiv> cfinite r \<and> Card_order r" |
|
96 |
||
97 |
lemma Cfinite_ordLess_Cinfinite: "\<lbrakk>Cfinite r; Cinfinite s\<rbrakk> \<Longrightarrow> r <o s" |
|
98 |
unfolding cfinite_def cinfinite_def |
|
55811 | 99 |
by (blast intro: finite_ordLess_infinite card_order_on_well_order_on) |
54474 | 100 |
|
54581
1502a1f707d9
eliminated dependence of Cardinals_FP on Set_Intervals, more precise imports
traytel
parents:
54578
diff
changeset
|
101 |
lemmas natLeq_card_order = natLeq_Card_order[unfolded Field_natLeq] |
1502a1f707d9
eliminated dependence of Cardinals_FP on Set_Intervals, more precise imports
traytel
parents:
54578
diff
changeset
|
102 |
|
1502a1f707d9
eliminated dependence of Cardinals_FP on Set_Intervals, more precise imports
traytel
parents:
54578
diff
changeset
|
103 |
lemma natLeq_cinfinite: "cinfinite natLeq" |
55811 | 104 |
unfolding cinfinite_def Field_natLeq by (rule infinite_UNIV_nat) |
54581
1502a1f707d9
eliminated dependence of Cardinals_FP on Set_Intervals, more precise imports
traytel
parents:
54578
diff
changeset
|
105 |
|
75624 | 106 |
lemma natLeq_Cinfinite: "Cinfinite natLeq" |
107 |
using natLeq_cinfinite natLeq_Card_order by simp |
|
108 |
||
54474 | 109 |
lemma natLeq_ordLeq_cinfinite: |
110 |
assumes inf: "Cinfinite r" |
|
111 |
shows "natLeq \<le>o r" |
|
112 |
proof - |
|
55811 | 113 |
from inf have "natLeq \<le>o |Field r|" unfolding cinfinite_def |
114 |
using infinite_iff_natLeq_ordLeq by blast |
|
54474 | 115 |
also from inf have "|Field r| =o r" by (simp add: card_of_unique ordIso_symmetric) |
116 |
finally show ?thesis . |
|
117 |
qed |
|
118 |
||
119 |
lemma cinfinite_not_czero: "cinfinite r \<Longrightarrow> \<not> (r =o (czero :: 'a rel))" |
|
55811 | 120 |
unfolding cinfinite_def by (cases "Field r = {}") (auto dest: czeroE) |
54474 | 121 |
|
122 |
lemma Cinfinite_Cnotzero: "Cinfinite r \<Longrightarrow> Cnotzero r" |
|
55811 | 123 |
by (rule conjI[OF cinfinite_not_czero]) simp_all |
54474 | 124 |
|
125 |
lemma Cinfinite_cong: "\<lbrakk>r1 =o r2; Cinfinite r1\<rbrakk> \<Longrightarrow> Cinfinite r2" |
|
55811 | 126 |
using Card_order_ordIso2[of r1 r2] unfolding cinfinite_def ordIso_iff_ordLeq |
127 |
by (auto dest: card_of_ordLeq_infinite[OF card_of_mono2]) |
|
54474 | 128 |
|
129 |
lemma cinfinite_mono: "\<lbrakk>r1 \<le>o r2; cinfinite r1\<rbrakk> \<Longrightarrow> cinfinite r2" |
|
55811 | 130 |
unfolding cinfinite_def by (auto dest: card_of_ordLeq_infinite[OF card_of_mono2]) |
54474 | 131 |
|
75624 | 132 |
lemma regularCard_ordIso: |
133 |
assumes "k =o k'" and "Cinfinite k" and "regularCard k" |
|
134 |
shows "regularCard k'" |
|
135 |
proof- |
|
136 |
have "stable k" using assms cinfinite_def regularCard_stable by blast |
|
137 |
hence "stable k'" using assms stable_ordIso1 ordIso_symmetric by blast |
|
138 |
thus ?thesis using assms cinfinite_def stable_regularCard |
|
139 |
using Cinfinite_cong by blast |
|
140 |
qed |
|
141 |
||
142 |
corollary card_of_UNION_ordLess_infinite_Field_regularCard: |
|
143 |
assumes ST: "regularCard r" and INF: "Cinfinite r" and |
|
144 |
LEQ_I: "|I| <o r" and LEQ: "\<forall>i \<in> I. |A i| <o r" |
|
145 |
shows "|\<Union>i \<in> I. A i| <o r" |
|
146 |
using card_of_UNION_ordLess_infinite_Field regularCard_stable assms cinfinite_def by blast |
|
54474 | 147 |
|
60758 | 148 |
subsection \<open>Binary sum\<close> |
54474 | 149 |
|
150 |
definition csum (infixr "+c" 65) where |
|
151 |
"r1 +c r2 \<equiv> |Field r1 <+> Field r2|" |
|
152 |
||
153 |
lemma Field_csum: "Field (r +c s) = Inl ` Field r \<union> Inr ` Field s" |
|
154 |
unfolding csum_def Field_card_of by auto |
|
155 |
||
156 |
lemma Card_order_csum: |
|
157 |
"Card_order (r1 +c r2)" |
|
158 |
unfolding csum_def by (simp add: card_of_Card_order) |
|
159 |
||
160 |
lemma csum_Cnotzero1: |
|
161 |
"Cnotzero r1 \<Longrightarrow> Cnotzero (r1 +c r2)" |
|
55811 | 162 |
unfolding csum_def using Cnotzero_imp_not_empty[of r1] Plus_eq_empty_conv[of "Field r1" "Field r2"] |
163 |
card_of_ordIso_czero_iff_empty[of "Field r1 <+> Field r2"] by (auto intro: card_of_Card_order) |
|
54474 | 164 |
|
165 |
lemma card_order_csum: |
|
166 |
assumes "card_order r1" "card_order r2" |
|
167 |
shows "card_order (r1 +c r2)" |
|
168 |
proof - |
|
169 |
have "Field r1 = UNIV" "Field r2 = UNIV" using assms card_order_on_Card_order by auto |
|
170 |
thus ?thesis unfolding csum_def by (auto simp: card_of_card_order_on) |
|
171 |
qed |
|
172 |
||
173 |
lemma cinfinite_csum: |
|
174 |
"cinfinite r1 \<or> cinfinite r2 \<Longrightarrow> cinfinite (r1 +c r2)" |
|
175 |
unfolding cinfinite_def csum_def by (auto simp: Field_card_of) |
|
176 |
||
177 |
lemma Cinfinite_csum1: |
|
178 |
"Cinfinite r1 \<Longrightarrow> Cinfinite (r1 +c r2)" |
|
55811 | 179 |
unfolding cinfinite_def csum_def by (rule conjI[OF _ card_of_Card_order]) (auto simp: Field_card_of) |
54474 | 180 |
|
54480
57e781b711b5
no need for 3-way split with GFP for a handful of theorems
blanchet
parents:
54474
diff
changeset
|
181 |
lemma Cinfinite_csum: |
57e781b711b5
no need for 3-way split with GFP for a handful of theorems
blanchet
parents:
54474
diff
changeset
|
182 |
"Cinfinite r1 \<or> Cinfinite r2 \<Longrightarrow> Cinfinite (r1 +c r2)" |
55811 | 183 |
unfolding cinfinite_def csum_def by (rule conjI[OF _ card_of_Card_order]) (auto simp: Field_card_of) |
54480
57e781b711b5
no need for 3-way split with GFP for a handful of theorems
blanchet
parents:
54474
diff
changeset
|
184 |
|
55851
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
185 |
lemma Cinfinite_csum_weak: |
54480
57e781b711b5
no need for 3-way split with GFP for a handful of theorems
blanchet
parents:
54474
diff
changeset
|
186 |
"\<lbrakk>Cinfinite r1; Cinfinite r2\<rbrakk> \<Longrightarrow> Cinfinite (r1 +c r2)" |
55811 | 187 |
by (erule Cinfinite_csum1) |
54480
57e781b711b5
no need for 3-way split with GFP for a handful of theorems
blanchet
parents:
54474
diff
changeset
|
188 |
|
54474 | 189 |
lemma csum_cong: "\<lbrakk>p1 =o r1; p2 =o r2\<rbrakk> \<Longrightarrow> p1 +c p2 =o r1 +c r2" |
190 |
by (simp only: csum_def ordIso_Plus_cong) |
|
191 |
||
192 |
lemma csum_cong1: "p1 =o r1 \<Longrightarrow> p1 +c q =o r1 +c q" |
|
193 |
by (simp only: csum_def ordIso_Plus_cong1) |
|
194 |
||
195 |
lemma csum_cong2: "p2 =o r2 \<Longrightarrow> q +c p2 =o q +c r2" |
|
196 |
by (simp only: csum_def ordIso_Plus_cong2) |
|
197 |
||
198 |
lemma csum_mono: "\<lbrakk>p1 \<le>o r1; p2 \<le>o r2\<rbrakk> \<Longrightarrow> p1 +c p2 \<le>o r1 +c r2" |
|
199 |
by (simp only: csum_def ordLeq_Plus_mono) |
|
200 |
||
201 |
lemma csum_mono1: "p1 \<le>o r1 \<Longrightarrow> p1 +c q \<le>o r1 +c q" |
|
202 |
by (simp only: csum_def ordLeq_Plus_mono1) |
|
203 |
||
204 |
lemma csum_mono2: "p2 \<le>o r2 \<Longrightarrow> q +c p2 \<le>o q +c r2" |
|
205 |
by (simp only: csum_def ordLeq_Plus_mono2) |
|
206 |
||
207 |
lemma ordLeq_csum1: "Card_order p1 \<Longrightarrow> p1 \<le>o p1 +c p2" |
|
208 |
by (simp only: csum_def Card_order_Plus1) |
|
209 |
||
210 |
lemma ordLeq_csum2: "Card_order p2 \<Longrightarrow> p2 \<le>o p1 +c p2" |
|
211 |
by (simp only: csum_def Card_order_Plus2) |
|
212 |
||
213 |
lemma csum_com: "p1 +c p2 =o p2 +c p1" |
|
214 |
by (simp only: csum_def card_of_Plus_commute) |
|
215 |
||
216 |
lemma csum_assoc: "(p1 +c p2) +c p3 =o p1 +c p2 +c p3" |
|
217 |
by (simp only: csum_def Field_card_of card_of_Plus_assoc) |
|
218 |
||
219 |
lemma Cfinite_csum: "\<lbrakk>Cfinite r; Cfinite s\<rbrakk> \<Longrightarrow> Cfinite (r +c s)" |
|
220 |
unfolding cfinite_def csum_def Field_card_of using card_of_card_order_on by simp |
|
221 |
||
222 |
lemma csum_csum: "(r1 +c r2) +c (r3 +c r4) =o (r1 +c r3) +c (r2 +c r4)" |
|
223 |
proof - |
|
224 |
have "(r1 +c r2) +c (r3 +c r4) =o r1 +c r2 +c (r3 +c r4)" |
|
55811 | 225 |
by (rule csum_assoc) |
54474 | 226 |
also have "r1 +c r2 +c (r3 +c r4) =o r1 +c (r2 +c r3) +c r4" |
55811 | 227 |
by (intro csum_assoc csum_cong2 ordIso_symmetric) |
54474 | 228 |
also have "r1 +c (r2 +c r3) +c r4 =o r1 +c (r3 +c r2) +c r4" |
55811 | 229 |
by (intro csum_com csum_cong1 csum_cong2) |
54474 | 230 |
also have "r1 +c (r3 +c r2) +c r4 =o r1 +c r3 +c r2 +c r4" |
55811 | 231 |
by (intro csum_assoc csum_cong2 ordIso_symmetric) |
54474 | 232 |
also have "r1 +c r3 +c r2 +c r4 =o (r1 +c r3) +c (r2 +c r4)" |
55811 | 233 |
by (intro csum_assoc ordIso_symmetric) |
54474 | 234 |
finally show ?thesis . |
235 |
qed |
|
236 |
||
237 |
lemma Plus_csum: "|A <+> B| =o |A| +c |B|" |
|
238 |
by (simp only: csum_def Field_card_of card_of_refl) |
|
239 |
||
240 |
lemma Un_csum: "|A \<union> B| \<le>o |A| +c |B|" |
|
241 |
using ordLeq_ordIso_trans[OF card_of_Un_Plus_ordLeq Plus_csum] by blast |
|
242 |
||
60758 | 243 |
subsection \<open>One\<close> |
54474 | 244 |
|
245 |
definition cone where |
|
246 |
"cone = card_of {()}" |
|
247 |
||
248 |
lemma Card_order_cone: "Card_order cone" |
|
249 |
unfolding cone_def by (rule card_of_Card_order) |
|
250 |
||
251 |
lemma Cfinite_cone: "Cfinite cone" |
|
252 |
unfolding cfinite_def by (simp add: Card_order_cone) |
|
253 |
||
254 |
lemma cone_not_czero: "\<not> (cone =o czero)" |
|
55811 | 255 |
unfolding czero_def cone_def ordIso_iff_ordLeq using card_of_empty3 empty_not_insert by blast |
54474 | 256 |
|
257 |
lemma cone_ordLeq_Cnotzero: "Cnotzero r \<Longrightarrow> cone \<le>o r" |
|
55811 | 258 |
unfolding cone_def by (rule Card_order_singl_ordLeq) (auto intro: czeroI) |
54474 | 259 |
|
260 |
||
60758 | 261 |
subsection \<open>Two\<close> |
54474 | 262 |
|
263 |
definition ctwo where |
|
264 |
"ctwo = |UNIV :: bool set|" |
|
265 |
||
266 |
lemma Card_order_ctwo: "Card_order ctwo" |
|
267 |
unfolding ctwo_def by (rule card_of_Card_order) |
|
268 |
||
269 |
lemma ctwo_not_czero: "\<not> (ctwo =o czero)" |
|
270 |
using card_of_empty3[of "UNIV :: bool set"] ordIso_iff_ordLeq |
|
55811 | 271 |
unfolding czero_def ctwo_def using UNIV_not_empty by auto |
54474 | 272 |
|
273 |
lemma ctwo_Cnotzero: "Cnotzero ctwo" |
|
274 |
by (simp add: ctwo_not_czero Card_order_ctwo) |
|
275 |
||
276 |
||
60758 | 277 |
subsection \<open>Family sum\<close> |
54474 | 278 |
|
279 |
definition Csum where |
|
280 |
"Csum r rs \<equiv> |SIGMA i : Field r. Field (rs i)|" |
|
281 |
||
282 |
(* Similar setup to the one for SIGMA from theory Big_Operators: *) |
|
283 |
syntax "_Csum" :: |
|
284 |
"pttrn => ('a * 'a) set => 'b * 'b set => (('a * 'b) * ('a * 'b)) set" |
|
285 |
("(3CSUM _:_. _)" [0, 51, 10] 10) |
|
286 |
||
287 |
translations |
|
288 |
"CSUM i:r. rs" == "CONST Csum r (%i. rs)" |
|
289 |
||
290 |
lemma SIGMA_CSUM: "|SIGMA i : I. As i| = (CSUM i : |I|. |As i| )" |
|
291 |
by (auto simp: Csum_def Field_card_of) |
|
292 |
||
293 |
(* NB: Always, under the cardinal operator, |
|
294 |
operations on sets are reduced automatically to operations on cardinals. |
|
295 |
This should make cardinal reasoning more direct and natural. *) |
|
296 |
||
297 |
||
60758 | 298 |
subsection \<open>Product\<close> |
54474 | 299 |
|
300 |
definition cprod (infixr "*c" 80) where |
|
61943 | 301 |
"r1 *c r2 = |Field r1 \<times> Field r2|" |
54474 | 302 |
|
303 |
lemma card_order_cprod: |
|
304 |
assumes "card_order r1" "card_order r2" |
|
305 |
shows "card_order (r1 *c r2)" |
|
306 |
proof - |
|
307 |
have "Field r1 = UNIV" "Field r2 = UNIV" using assms card_order_on_Card_order by auto |
|
308 |
thus ?thesis by (auto simp: cprod_def card_of_card_order_on) |
|
309 |
qed |
|
310 |
||
311 |
lemma Card_order_cprod: "Card_order (r1 *c r2)" |
|
312 |
by (simp only: cprod_def Field_card_of card_of_card_order_on) |
|
313 |
||
314 |
lemma cprod_mono1: "p1 \<le>o r1 \<Longrightarrow> p1 *c q \<le>o r1 *c q" |
|
315 |
by (simp only: cprod_def ordLeq_Times_mono1) |
|
316 |
||
317 |
lemma cprod_mono2: "p2 \<le>o r2 \<Longrightarrow> q *c p2 \<le>o q *c r2" |
|
318 |
by (simp only: cprod_def ordLeq_Times_mono2) |
|
319 |
||
55851
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
320 |
lemma cprod_mono: "\<lbrakk>p1 \<le>o r1; p2 \<le>o r2\<rbrakk> \<Longrightarrow> p1 *c p2 \<le>o r1 *c r2" |
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
321 |
by (rule ordLeq_transitive[OF cprod_mono1 cprod_mono2]) |
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
322 |
|
54474 | 323 |
lemma ordLeq_cprod2: "\<lbrakk>Cnotzero p1; Card_order p2\<rbrakk> \<Longrightarrow> p2 \<le>o p1 *c p2" |
55811 | 324 |
unfolding cprod_def by (rule Card_order_Times2) (auto intro: czeroI) |
54474 | 325 |
|
326 |
lemma cinfinite_cprod: "\<lbrakk>cinfinite r1; cinfinite r2\<rbrakk> \<Longrightarrow> cinfinite (r1 *c r2)" |
|
327 |
by (simp add: cinfinite_def cprod_def Field_card_of infinite_cartesian_product) |
|
328 |
||
329 |
lemma cinfinite_cprod2: "\<lbrakk>Cnotzero r1; Cinfinite r2\<rbrakk> \<Longrightarrow> cinfinite (r1 *c r2)" |
|
55811 | 330 |
by (rule cinfinite_mono) (auto intro: ordLeq_cprod2) |
54474 | 331 |
|
332 |
lemma Cinfinite_cprod2: "\<lbrakk>Cnotzero r1; Cinfinite r2\<rbrakk> \<Longrightarrow> Cinfinite (r1 *c r2)" |
|
333 |
by (blast intro: cinfinite_cprod2 Card_order_cprod) |
|
334 |
||
55851
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
335 |
lemma cprod_cong: "\<lbrakk>p1 =o r1; p2 =o r2\<rbrakk> \<Longrightarrow> p1 *c p2 =o r1 *c r2" |
55866 | 336 |
unfolding ordIso_iff_ordLeq by (blast intro: cprod_mono) |
55851
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
337 |
|
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
338 |
lemma cprod_cong1: "\<lbrakk>p1 =o r1\<rbrakk> \<Longrightarrow> p1 *c p2 =o r1 *c p2" |
55866 | 339 |
unfolding ordIso_iff_ordLeq by (blast intro: cprod_mono1) |
55851
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
340 |
|
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
341 |
lemma cprod_cong2: "p2 =o r2 \<Longrightarrow> q *c p2 =o q *c r2" |
55866 | 342 |
unfolding ordIso_iff_ordLeq by (blast intro: cprod_mono2) |
55851
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
343 |
|
54474 | 344 |
lemma cprod_com: "p1 *c p2 =o p2 *c p1" |
345 |
by (simp only: cprod_def card_of_Times_commute) |
|
346 |
||
347 |
lemma card_of_Csum_Times: |
|
348 |
"\<forall>i \<in> I. |A i| \<le>o |B| \<Longrightarrow> (CSUM i : |I|. |A i| ) \<le>o |I| *c |B|" |
|
56191 | 349 |
by (simp only: Csum_def cprod_def Field_card_of card_of_Sigma_mono1) |
54474 | 350 |
|
351 |
lemma card_of_Csum_Times': |
|
352 |
assumes "Card_order r" "\<forall>i \<in> I. |A i| \<le>o r" |
|
353 |
shows "(CSUM i : |I|. |A i| ) \<le>o |I| *c r" |
|
354 |
proof - |
|
355 |
from assms(1) have *: "r =o |Field r|" by (simp add: card_of_unique) |
|
356 |
with assms(2) have "\<forall>i \<in> I. |A i| \<le>o |Field r|" by (blast intro: ordLeq_ordIso_trans) |
|
357 |
hence "(CSUM i : |I|. |A i| ) \<le>o |I| *c |Field r|" by (simp only: card_of_Csum_Times) |
|
358 |
also from * have "|I| *c |Field r| \<le>o |I| *c r" |
|
359 |
by (simp only: Field_card_of card_of_refl cprod_def ordIso_imp_ordLeq) |
|
360 |
finally show ?thesis . |
|
361 |
qed |
|
362 |
||
363 |
lemma cprod_csum_distrib1: "r1 *c r2 +c r1 *c r3 =o r1 *c (r2 +c r3)" |
|
364 |
unfolding csum_def cprod_def by (simp add: Field_card_of card_of_Times_Plus_distrib ordIso_symmetric) |
|
365 |
||
366 |
lemma csum_absorb2': "\<lbrakk>Card_order r2; r1 \<le>o r2; cinfinite r1 \<or> cinfinite r2\<rbrakk> \<Longrightarrow> r1 +c r2 =o r2" |
|
55811 | 367 |
unfolding csum_def by (rule conjunct2[OF Card_order_Plus_infinite]) |
368 |
(auto simp: cinfinite_def dest: cinfinite_mono) |
|
54474 | 369 |
|
370 |
lemma csum_absorb1': |
|
371 |
assumes card: "Card_order r2" |
|
372 |
and r12: "r1 \<le>o r2" and cr12: "cinfinite r1 \<or> cinfinite r2" |
|
373 |
shows "r2 +c r1 =o r2" |
|
374 |
by (rule ordIso_transitive, rule csum_com, rule csum_absorb2', (simp only: assms)+) |
|
375 |
||
376 |
lemma csum_absorb1: "\<lbrakk>Cinfinite r2; r1 \<le>o r2\<rbrakk> \<Longrightarrow> r2 +c r1 =o r2" |
|
377 |
by (rule csum_absorb1') auto |
|
378 |
||
75624 | 379 |
lemma csum_absorb2: "\<lbrakk>Cinfinite r2 ; r1 \<le>o r2\<rbrakk> \<Longrightarrow> r1 +c r2 =o r2" |
380 |
using ordIso_transitive csum_com csum_absorb1 by blast |
|
381 |
||
382 |
lemma regularCard_csum: |
|
383 |
assumes "Cinfinite r" "Cinfinite s" "regularCard r" "regularCard s" |
|
384 |
shows "regularCard (r +c s)" |
|
385 |
proof (cases "r \<le>o s") |
|
386 |
case True |
|
387 |
then show ?thesis using regularCard_ordIso[of s] csum_absorb2'[THEN ordIso_symmetric] assms by auto |
|
388 |
next |
|
389 |
case False |
|
390 |
have "Well_order s" "Well_order r" using assms card_order_on_well_order_on by auto |
|
391 |
then have "s \<le>o r" using not_ordLeq_iff_ordLess False ordLess_imp_ordLeq by auto |
|
392 |
then show ?thesis using regularCard_ordIso[of r] csum_absorb1'[THEN ordIso_symmetric] assms by auto |
|
393 |
qed |
|
394 |
||
395 |
lemma csum_mono_strict: |
|
396 |
assumes Card_order: "Card_order r" "Card_order q" |
|
397 |
and Cinfinite: "Cinfinite r'" "Cinfinite q'" |
|
398 |
and less: "r <o r'" "q <o q'" |
|
399 |
shows "r +c q <o r' +c q'" |
|
400 |
proof - |
|
401 |
have Well_order: "Well_order r" "Well_order q" "Well_order r'" "Well_order q'" |
|
402 |
using card_order_on_well_order_on Card_order Cinfinite by auto |
|
403 |
show ?thesis |
|
404 |
proof (cases "Cinfinite r") |
|
405 |
case outer: True |
|
406 |
then show ?thesis |
|
407 |
proof (cases "Cinfinite q") |
|
408 |
case inner: True |
|
409 |
then show ?thesis |
|
410 |
proof (cases "r \<le>o q") |
|
411 |
case True |
|
412 |
then have "r +c q =o q" using csum_absorb2 inner by blast |
|
413 |
then show ?thesis |
|
414 |
using ordIso_ordLess_trans ordLess_ordLeq_trans less Cinfinite ordLeq_csum2 by blast |
|
415 |
next |
|
416 |
case False |
|
417 |
then have "q \<le>o r" using not_ordLeq_iff_ordLess Well_order ordLess_imp_ordLeq by blast |
|
418 |
then have "r +c q =o r" using csum_absorb1 outer by blast |
|
419 |
then show ?thesis |
|
420 |
using ordIso_ordLess_trans ordLess_ordLeq_trans less Cinfinite ordLeq_csum1 by blast |
|
421 |
qed |
|
422 |
next |
|
423 |
case False |
|
424 |
then have "Cfinite q" using Card_order cinfinite_def cfinite_def by blast |
|
425 |
then have "q \<le>o r" using finite_ordLess_infinite cfinite_def cinfinite_def outer |
|
426 |
Well_order ordLess_imp_ordLeq by blast |
|
427 |
then have "r +c q =o r" by (rule csum_absorb1[OF outer]) |
|
428 |
then show ?thesis using ordIso_ordLess_trans ordLess_ordLeq_trans less ordLeq_csum1 Cinfinite by blast |
|
429 |
qed |
|
430 |
next |
|
431 |
case False |
|
432 |
then have outer: "Cfinite r" using Card_order cinfinite_def cfinite_def by blast |
|
433 |
then show ?thesis |
|
434 |
proof (cases "Cinfinite q") |
|
435 |
case True |
|
436 |
then have "r \<le>o q" using finite_ordLess_infinite cinfinite_def cfinite_def outer Well_order |
|
437 |
ordLess_imp_ordLeq by blast |
|
438 |
then have "r +c q =o q" by (rule csum_absorb2[OF True]) |
|
439 |
then show ?thesis using ordIso_ordLess_trans ordLess_ordLeq_trans less ordLeq_csum2 Cinfinite by blast |
|
440 |
next |
|
441 |
case False |
|
442 |
then have "Cfinite q" using Card_order cinfinite_def cfinite_def by blast |
|
443 |
then have "Cfinite (r +c q)" using Cfinite_csum outer by blast |
|
444 |
moreover have "Cinfinite (r' +c q')" using Cinfinite_csum1 Cinfinite by blast |
|
445 |
ultimately show ?thesis using Cfinite_ordLess_Cinfinite by blast |
|
446 |
qed |
|
447 |
qed |
|
448 |
qed |
|
54474 | 449 |
|
60758 | 450 |
subsection \<open>Exponentiation\<close> |
54474 | 451 |
|
452 |
definition cexp (infixr "^c" 90) where |
|
453 |
"r1 ^c r2 \<equiv> |Func (Field r2) (Field r1)|" |
|
454 |
||
455 |
lemma Card_order_cexp: "Card_order (r1 ^c r2)" |
|
456 |
unfolding cexp_def by (rule card_of_Card_order) |
|
457 |
||
458 |
lemma cexp_mono': |
|
459 |
assumes 1: "p1 \<le>o r1" and 2: "p2 \<le>o r2" |
|
460 |
and n: "Field p2 = {} \<Longrightarrow> Field r2 = {}" |
|
461 |
shows "p1 ^c p2 \<le>o r1 ^c r2" |
|
462 |
proof(cases "Field p1 = {}") |
|
463 |
case True |
|
55811 | 464 |
hence "Field p2 \<noteq> {} \<Longrightarrow> Func (Field p2) {} = {}" unfolding Func_is_emp by simp |
465 |
with True have "|Field |Func (Field p2) (Field p1)|| \<le>o cone" |
|
54474 | 466 |
unfolding cone_def Field_card_of |
55811 | 467 |
by (cases "Field p2 = {}", auto intro: surj_imp_ordLeq simp: Func_empty) |
54474 | 468 |
hence "|Func (Field p2) (Field p1)| \<le>o cone" by (simp add: Field_card_of cexp_def) |
469 |
hence "p1 ^c p2 \<le>o cone" unfolding cexp_def . |
|
470 |
thus ?thesis |
|
471 |
proof (cases "Field p2 = {}") |
|
472 |
case True |
|
473 |
with n have "Field r2 = {}" . |
|
55604 | 474 |
hence "cone \<le>o r1 ^c r2" unfolding cone_def cexp_def Func_def |
475 |
by (auto intro: card_of_ordLeqI[where f="\<lambda>_ _. undefined"]) |
|
60758 | 476 |
thus ?thesis using \<open>p1 ^c p2 \<le>o cone\<close> ordLeq_transitive by auto |
54474 | 477 |
next |
478 |
case False with True have "|Field (p1 ^c p2)| =o czero" |
|
479 |
unfolding card_of_ordIso_czero_iff_empty cexp_def Field_card_of Func_def by auto |
|
480 |
thus ?thesis unfolding cexp_def card_of_ordIso_czero_iff_empty Field_card_of |
|
481 |
by (simp add: card_of_empty) |
|
482 |
qed |
|
483 |
next |
|
484 |
case False |
|
485 |
have 1: "|Field p1| \<le>o |Field r1|" and 2: "|Field p2| \<le>o |Field r2|" |
|
486 |
using 1 2 by (auto simp: card_of_mono2) |
|
487 |
obtain f1 where f1: "f1 ` Field r1 = Field p1" |
|
488 |
using 1 unfolding card_of_ordLeq2[OF False, symmetric] by auto |
|
489 |
obtain f2 where f2: "inj_on f2 (Field p2)" "f2 ` Field p2 \<subseteq> Field r2" |
|
490 |
using 2 unfolding card_of_ordLeq[symmetric] by blast |
|
491 |
have 0: "Func_map (Field p2) f1 f2 ` (Field (r1 ^c r2)) = Field (p1 ^c p2)" |
|
492 |
unfolding cexp_def Field_card_of using Func_map_surj[OF f1 f2 n, symmetric] . |
|
493 |
have 00: "Field (p1 ^c p2) \<noteq> {}" unfolding cexp_def Field_card_of Func_is_emp |
|
494 |
using False by simp |
|
495 |
show ?thesis |
|
496 |
using 0 card_of_ordLeq2[OF 00] unfolding cexp_def Field_card_of by blast |
|
497 |
qed |
|
498 |
||
499 |
lemma cexp_mono: |
|
500 |
assumes 1: "p1 \<le>o r1" and 2: "p2 \<le>o r2" |
|
501 |
and n: "p2 =o czero \<Longrightarrow> r2 =o czero" and card: "Card_order p2" |
|
502 |
shows "p1 ^c p2 \<le>o r1 ^c r2" |
|
55811 | 503 |
by (rule cexp_mono'[OF 1 2 czeroE[OF n[OF czeroI[OF card]]]]) |
54474 | 504 |
|
505 |
lemma cexp_mono1: |
|
506 |
assumes 1: "p1 \<le>o r1" and q: "Card_order q" |
|
507 |
shows "p1 ^c q \<le>o r1 ^c q" |
|
508 |
using ordLeq_refl[OF q] by (rule cexp_mono[OF 1]) (auto simp: q) |
|
509 |
||
510 |
lemma cexp_mono2': |
|
511 |
assumes 2: "p2 \<le>o r2" and q: "Card_order q" |
|
512 |
and n: "Field p2 = {} \<Longrightarrow> Field r2 = {}" |
|
513 |
shows "q ^c p2 \<le>o q ^c r2" |
|
514 |
using ordLeq_refl[OF q] by (rule cexp_mono'[OF _ 2 n]) auto |
|
515 |
||
516 |
lemma cexp_mono2: |
|
517 |
assumes 2: "p2 \<le>o r2" and q: "Card_order q" |
|
518 |
and n: "p2 =o czero \<Longrightarrow> r2 =o czero" and card: "Card_order p2" |
|
519 |
shows "q ^c p2 \<le>o q ^c r2" |
|
520 |
using ordLeq_refl[OF q] by (rule cexp_mono[OF _ 2 n card]) auto |
|
521 |
||
522 |
lemma cexp_mono2_Cnotzero: |
|
523 |
assumes "p2 \<le>o r2" "Card_order q" "Cnotzero p2" |
|
524 |
shows "q ^c p2 \<le>o q ^c r2" |
|
55811 | 525 |
using assms(3) czeroI by (blast intro: cexp_mono2'[OF assms(1,2)]) |
54474 | 526 |
|
527 |
lemma cexp_cong: |
|
528 |
assumes 1: "p1 =o r1" and 2: "p2 =o r2" |
|
529 |
and Cr: "Card_order r2" |
|
530 |
and Cp: "Card_order p2" |
|
531 |
shows "p1 ^c p2 =o r1 ^c r2" |
|
532 |
proof - |
|
533 |
obtain f where "bij_betw f (Field p2) (Field r2)" |
|
534 |
using 2 card_of_ordIso[of "Field p2" "Field r2"] card_of_cong by auto |
|
535 |
hence 0: "Field p2 = {} \<longleftrightarrow> Field r2 = {}" unfolding bij_betw_def by auto |
|
536 |
have r: "p2 =o czero \<Longrightarrow> r2 =o czero" |
|
537 |
and p: "r2 =o czero \<Longrightarrow> p2 =o czero" |
|
538 |
using 0 Cr Cp czeroE czeroI by auto |
|
539 |
show ?thesis using 0 1 2 unfolding ordIso_iff_ordLeq |
|
55811 | 540 |
using r p cexp_mono[OF _ _ _ Cp] cexp_mono[OF _ _ _ Cr] by blast |
54474 | 541 |
qed |
542 |
||
543 |
lemma cexp_cong1: |
|
544 |
assumes 1: "p1 =o r1" and q: "Card_order q" |
|
545 |
shows "p1 ^c q =o r1 ^c q" |
|
546 |
by (rule cexp_cong[OF 1 _ q q]) (rule ordIso_refl[OF q]) |
|
547 |
||
548 |
lemma cexp_cong2: |
|
549 |
assumes 2: "p2 =o r2" and q: "Card_order q" and p: "Card_order p2" |
|
550 |
shows "q ^c p2 =o q ^c r2" |
|
551 |
by (rule cexp_cong[OF _ 2]) (auto simp only: ordIso_refl Card_order_ordIso2[OF p 2] q p) |
|
552 |
||
553 |
lemma cexp_cone: |
|
554 |
assumes "Card_order r" |
|
555 |
shows "r ^c cone =o r" |
|
556 |
proof - |
|
557 |
have "r ^c cone =o |Field r|" |
|
558 |
unfolding cexp_def cone_def Field_card_of Func_empty |
|
559 |
card_of_ordIso[symmetric] bij_betw_def Func_def inj_on_def image_def |
|
560 |
by (rule exI[of _ "\<lambda>f. f ()"]) auto |
|
561 |
also have "|Field r| =o r" by (rule card_of_Field_ordIso[OF assms]) |
|
562 |
finally show ?thesis . |
|
563 |
qed |
|
564 |
||
565 |
lemma cexp_cprod: |
|
566 |
assumes r1: "Card_order r1" |
|
567 |
shows "(r1 ^c r2) ^c r3 =o r1 ^c (r2 *c r3)" (is "?L =o ?R") |
|
568 |
proof - |
|
569 |
have "?L =o r1 ^c (r3 *c r2)" |
|
570 |
unfolding cprod_def cexp_def Field_card_of |
|
571 |
using card_of_Func_Times by(rule ordIso_symmetric) |
|
572 |
also have "r1 ^c (r3 *c r2) =o ?R" |
|
573 |
apply(rule cexp_cong2) using cprod_com r1 by (auto simp: Card_order_cprod) |
|
574 |
finally show ?thesis . |
|
575 |
qed |
|
576 |
||
577 |
lemma cprod_infinite1': "\<lbrakk>Cinfinite r; Cnotzero p; p \<le>o r\<rbrakk> \<Longrightarrow> r *c p =o r" |
|
578 |
unfolding cinfinite_def cprod_def |
|
579 |
by (rule Card_order_Times_infinite[THEN conjunct1]) (blast intro: czeroI)+ |
|
580 |
||
55851
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
581 |
lemma cprod_infinite: "Cinfinite r \<Longrightarrow> r *c r =o r" |
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
582 |
using cprod_infinite1' Cinfinite_Cnotzero ordLeq_refl by blast |
3d40cf74726c
optimize cardinal bounds involving natLeq (omega)
blanchet
parents:
55811
diff
changeset
|
583 |
|
54474 | 584 |
lemma cexp_cprod_ordLeq: |
585 |
assumes r1: "Card_order r1" and r2: "Cinfinite r2" |
|
586 |
and r3: "Cnotzero r3" "r3 \<le>o r2" |
|
587 |
shows "(r1 ^c r2) ^c r3 =o r1 ^c r2" (is "?L =o ?R") |
|
588 |
proof- |
|
589 |
have "?L =o r1 ^c (r2 *c r3)" using cexp_cprod[OF r1] . |
|
590 |
also have "r1 ^c (r2 *c r3) =o ?R" |
|
591 |
apply(rule cexp_cong2) |
|
592 |
apply(rule cprod_infinite1'[OF r2 r3]) using r1 r2 by (fastforce simp: Card_order_cprod)+ |
|
593 |
finally show ?thesis . |
|
594 |
qed |
|
595 |
||
596 |
lemma Cnotzero_UNIV: "Cnotzero |UNIV|" |
|
597 |
by (auto simp: card_of_Card_order card_of_ordIso_czero_iff_empty) |
|
598 |
||
599 |
lemma ordLess_ctwo_cexp: |
|
600 |
assumes "Card_order r" |
|
601 |
shows "r <o ctwo ^c r" |
|
602 |
proof - |
|
603 |
have "r <o |Pow (Field r)|" using assms by (rule Card_order_Pow) |
|
604 |
also have "|Pow (Field r)| =o ctwo ^c r" |
|
605 |
unfolding ctwo_def cexp_def Field_card_of by (rule card_of_Pow_Func) |
|
606 |
finally show ?thesis . |
|
607 |
qed |
|
608 |
||
609 |
lemma ordLeq_cexp1: |
|
610 |
assumes "Cnotzero r" "Card_order q" |
|
611 |
shows "q \<le>o q ^c r" |
|
612 |
proof (cases "q =o (czero :: 'a rel)") |
|
613 |
case True thus ?thesis by (simp only: card_of_empty cexp_def czero_def ordIso_ordLeq_trans) |
|
614 |
next |
|
615 |
case False |
|
616 |
thus ?thesis |
|
617 |
apply - |
|
618 |
apply (rule ordIso_ordLeq_trans) |
|
619 |
apply (rule ordIso_symmetric) |
|
620 |
apply (rule cexp_cone) |
|
621 |
apply (rule assms(2)) |
|
622 |
apply (rule cexp_mono2) |
|
623 |
apply (rule cone_ordLeq_Cnotzero) |
|
624 |
apply (rule assms(1)) |
|
625 |
apply (rule assms(2)) |
|
626 |
apply (rule notE) |
|
627 |
apply (rule cone_not_czero) |
|
628 |
apply assumption |
|
629 |
apply (rule Card_order_cone) |
|
630 |
done |
|
631 |
qed |
|
632 |
||
633 |
lemma ordLeq_cexp2: |
|
634 |
assumes "ctwo \<le>o q" "Card_order r" |
|
635 |
shows "r \<le>o q ^c r" |
|
636 |
proof (cases "r =o (czero :: 'a rel)") |
|
637 |
case True thus ?thesis by (simp only: card_of_empty cexp_def czero_def ordIso_ordLeq_trans) |
|
638 |
next |
|
639 |
case False thus ?thesis |
|
640 |
apply - |
|
641 |
apply (rule ordLess_imp_ordLeq) |
|
642 |
apply (rule ordLess_ordLeq_trans) |
|
643 |
apply (rule ordLess_ctwo_cexp) |
|
644 |
apply (rule assms(2)) |
|
645 |
apply (rule cexp_mono1) |
|
646 |
apply (rule assms(1)) |
|
647 |
apply (rule assms(2)) |
|
648 |
done |
|
649 |
qed |
|
650 |
||
651 |
lemma cinfinite_cexp: "\<lbrakk>ctwo \<le>o q; Cinfinite r\<rbrakk> \<Longrightarrow> cinfinite (q ^c r)" |
|
55811 | 652 |
by (rule cinfinite_mono[OF ordLeq_cexp2]) simp_all |
54474 | 653 |
|
654 |
lemma Cinfinite_cexp: |
|
655 |
"\<lbrakk>ctwo \<le>o q; Cinfinite r\<rbrakk> \<Longrightarrow> Cinfinite (q ^c r)" |
|
656 |
by (simp add: cinfinite_cexp Card_order_cexp) |
|
657 |
||
75624 | 658 |
lemma card_order_cexp: |
659 |
assumes "card_order r1" "card_order r2" |
|
660 |
shows "card_order (r1 ^c r2)" |
|
661 |
proof - |
|
662 |
have "Field r1 = UNIV" "Field r2 = UNIV" using assms card_order_on_Card_order by auto |
|
663 |
thus ?thesis unfolding cexp_def Func_def using card_of_card_order_on by simp |
|
664 |
qed |
|
665 |
||
54474 | 666 |
lemma ctwo_ordLess_natLeq: "ctwo <o natLeq" |
54581
1502a1f707d9
eliminated dependence of Cardinals_FP on Set_Intervals, more precise imports
traytel
parents:
54578
diff
changeset
|
667 |
unfolding ctwo_def using finite_UNIV natLeq_cinfinite natLeq_Card_order |
1502a1f707d9
eliminated dependence of Cardinals_FP on Set_Intervals, more precise imports
traytel
parents:
54578
diff
changeset
|
668 |
by (intro Cfinite_ordLess_Cinfinite) (auto simp: cfinite_def card_of_Card_order) |
54474 | 669 |
|
670 |
lemma ctwo_ordLess_Cinfinite: "Cinfinite r \<Longrightarrow> ctwo <o r" |
|
55811 | 671 |
by (rule ordLess_ordLeq_trans[OF ctwo_ordLess_natLeq natLeq_ordLeq_cinfinite]) |
54474 | 672 |
|
673 |
lemma ctwo_ordLeq_Cinfinite: |
|
674 |
assumes "Cinfinite r" |
|
675 |
shows "ctwo \<le>o r" |
|
676 |
by (rule ordLess_imp_ordLeq[OF ctwo_ordLess_Cinfinite[OF assms]]) |
|
677 |
||
678 |
lemma Un_Cinfinite_bound: "\<lbrakk>|A| \<le>o r; |B| \<le>o r; Cinfinite r\<rbrakk> \<Longrightarrow> |A \<union> B| \<le>o r" |
|
679 |
by (auto simp add: cinfinite_def card_of_Un_ordLeq_infinite_Field) |
|
680 |
||
75624 | 681 |
lemma Un_Cinfinite_bound_strict: "\<lbrakk>|A| <o r; |B| <o r; Cinfinite r\<rbrakk> \<Longrightarrow> |A \<union> B| <o r" |
682 |
by (auto simp add: cinfinite_def card_of_Un_ordLess_infinite_Field) |
|
683 |
||
54474 | 684 |
lemma UNION_Cinfinite_bound: "\<lbrakk>|I| \<le>o r; \<forall>i \<in> I. |A i| \<le>o r; Cinfinite r\<rbrakk> \<Longrightarrow> |\<Union>i \<in> I. A i| \<le>o r" |
685 |
by (auto simp add: card_of_UNION_ordLeq_infinite_Field cinfinite_def) |
|
686 |
||
687 |
lemma csum_cinfinite_bound: |
|
688 |
assumes "p \<le>o r" "q \<le>o r" "Card_order p" "Card_order q" "Cinfinite r" |
|
689 |
shows "p +c q \<le>o r" |
|
690 |
proof - |
|
691 |
from assms(1-4) have "|Field p| \<le>o r" "|Field q| \<le>o r" |
|
692 |
unfolding card_order_on_def using card_of_least ordLeq_transitive by blast+ |
|
693 |
with assms show ?thesis unfolding cinfinite_def csum_def |
|
694 |
by (blast intro: card_of_Plus_ordLeq_infinite_Field) |
|
695 |
qed |
|
696 |
||
697 |
lemma cprod_cinfinite_bound: |
|
698 |
assumes "p \<le>o r" "q \<le>o r" "Card_order p" "Card_order q" "Cinfinite r" |
|
699 |
shows "p *c q \<le>o r" |
|
700 |
proof - |
|
701 |
from assms(1-4) have "|Field p| \<le>o r" "|Field q| \<le>o r" |
|
702 |
unfolding card_order_on_def using card_of_least ordLeq_transitive by blast+ |
|
703 |
with assms show ?thesis unfolding cinfinite_def cprod_def |
|
704 |
by (blast intro: card_of_Times_ordLeq_infinite_Field) |
|
705 |
qed |
|
706 |
||
75624 | 707 |
lemma cprod_infinite2': "\<lbrakk>Cnotzero r1; Cinfinite r2; r1 \<le>o r2\<rbrakk> \<Longrightarrow> r1 *c r2 =o r2" |
708 |
unfolding ordIso_iff_ordLeq |
|
709 |
by (intro conjI cprod_cinfinite_bound ordLeq_cprod2 ordLeq_refl) |
|
710 |
(auto dest!: ordIso_imp_ordLeq not_ordLeq_ordLess simp: czero_def Card_order_empty) |
|
711 |
||
712 |
lemma regularCard_cprod: |
|
713 |
assumes "Cinfinite r" "Cinfinite s" "regularCard r" "regularCard s" |
|
714 |
shows "regularCard (r *c s)" |
|
715 |
proof (cases "r \<le>o s") |
|
716 |
case True |
|
717 |
show ?thesis |
|
718 |
apply (rule regularCard_ordIso[of s]) |
|
719 |
apply (rule ordIso_symmetric[OF cprod_infinite2']) |
|
720 |
using assms True Cinfinite_Cnotzero by auto |
|
721 |
next |
|
722 |
case False |
|
723 |
have "Well_order r" "Well_order s" using assms card_order_on_well_order_on by auto |
|
724 |
then have 1: "s \<le>o r" using not_ordLeq_iff_ordLess ordLess_imp_ordLeq False by blast |
|
725 |
show ?thesis |
|
726 |
apply (rule regularCard_ordIso[of r]) |
|
727 |
apply (rule ordIso_symmetric[OF cprod_infinite1']) |
|
728 |
using assms 1 Cinfinite_Cnotzero by auto |
|
729 |
qed |
|
730 |
||
54474 | 731 |
lemma cprod_csum_cexp: |
732 |
"r1 *c r2 \<le>o (r1 +c r2) ^c ctwo" |
|
733 |
unfolding cprod_def csum_def cexp_def ctwo_def Field_card_of |
|
734 |
proof - |
|
735 |
let ?f = "\<lambda>(a, b). %x. if x then Inl a else Inr b" |
|
736 |
have "inj_on ?f (Field r1 \<times> Field r2)" (is "inj_on _ ?LHS") |
|
737 |
by (auto simp: inj_on_def fun_eq_iff split: bool.split) |
|
738 |
moreover |
|
739 |
have "?f ` ?LHS \<subseteq> Func (UNIV :: bool set) (Field r1 <+> Field r2)" (is "_ \<subseteq> ?RHS") |
|
740 |
by (auto simp: Func_def) |
|
741 |
ultimately show "|?LHS| \<le>o |?RHS|" using card_of_ordLeq by blast |
|
742 |
qed |
|
743 |
||
744 |
lemma Cfinite_cprod_Cinfinite: "\<lbrakk>Cfinite r; Cinfinite s\<rbrakk> \<Longrightarrow> r *c s \<le>o s" |
|
745 |
by (intro cprod_cinfinite_bound) |
|
746 |
(auto intro: ordLeq_refl ordLess_imp_ordLeq[OF Cfinite_ordLess_Cinfinite]) |
|
747 |
||
748 |
lemma cprod_cexp: "(r *c s) ^c t =o r ^c t *c s ^c t" |
|
749 |
unfolding cprod_def cexp_def Field_card_of by (rule Func_Times_Range) |
|
750 |
||
751 |
lemma cprod_cexp_csum_cexp_Cinfinite: |
|
752 |
assumes t: "Cinfinite t" |
|
753 |
shows "(r *c s) ^c t \<le>o (r +c s) ^c t" |
|
754 |
proof - |
|
755 |
have "(r *c s) ^c t \<le>o ((r +c s) ^c ctwo) ^c t" |
|
756 |
by (rule cexp_mono1[OF cprod_csum_cexp conjunct2[OF t]]) |
|
757 |
also have "((r +c s) ^c ctwo) ^c t =o (r +c s) ^c (ctwo *c t)" |
|
758 |
by (rule cexp_cprod[OF Card_order_csum]) |
|
759 |
also have "(r +c s) ^c (ctwo *c t) =o (r +c s) ^c (t *c ctwo)" |
|
760 |
by (rule cexp_cong2[OF cprod_com Card_order_csum Card_order_cprod]) |
|
761 |
also have "(r +c s) ^c (t *c ctwo) =o ((r +c s) ^c t) ^c ctwo" |
|
762 |
by (rule ordIso_symmetric[OF cexp_cprod[OF Card_order_csum]]) |
|
763 |
also have "((r +c s) ^c t) ^c ctwo =o (r +c s) ^c t" |
|
764 |
by (rule cexp_cprod_ordLeq[OF Card_order_csum t ctwo_Cnotzero ctwo_ordLeq_Cinfinite[OF t]]) |
|
765 |
finally show ?thesis . |
|
766 |
qed |
|
767 |
||
768 |
lemma Cfinite_cexp_Cinfinite: |
|
769 |
assumes s: "Cfinite s" and t: "Cinfinite t" |
|
770 |
shows "s ^c t \<le>o ctwo ^c t" |
|
771 |
proof (cases "s \<le>o ctwo") |
|
772 |
case True thus ?thesis using t by (blast intro: cexp_mono1) |
|
773 |
next |
|
774 |
case False |
|
55811 | 775 |
hence "ctwo \<le>o s" using ordLeq_total[of s ctwo] Card_order_ctwo s |
776 |
by (auto intro: card_order_on_well_order_on) |
|
777 |
hence "Cnotzero s" using Cnotzero_mono[OF ctwo_Cnotzero] s by blast |
|
778 |
hence st: "Cnotzero (s *c t)" by (intro Cinfinite_Cnotzero[OF Cinfinite_cprod2]) (auto simp: t) |
|
54474 | 779 |
have "s ^c t \<le>o (ctwo ^c s) ^c t" |
780 |
using assms by (blast intro: cexp_mono1 ordLess_imp_ordLeq[OF ordLess_ctwo_cexp]) |
|
781 |
also have "(ctwo ^c s) ^c t =o ctwo ^c (s *c t)" |
|
782 |
by (blast intro: Card_order_ctwo cexp_cprod) |
|
783 |
also have "ctwo ^c (s *c t) \<le>o ctwo ^c t" |
|
784 |
using assms st by (intro cexp_mono2_Cnotzero Cfinite_cprod_Cinfinite Card_order_ctwo) |
|
785 |
finally show ?thesis . |
|
786 |
qed |
|
787 |
||
788 |
lemma csum_Cfinite_cexp_Cinfinite: |
|
789 |
assumes r: "Card_order r" and s: "Cfinite s" and t: "Cinfinite t" |
|
790 |
shows "(r +c s) ^c t \<le>o (r +c ctwo) ^c t" |
|
791 |
proof (cases "Cinfinite r") |
|
792 |
case True |
|
793 |
hence "r +c s =o r" by (intro csum_absorb1 ordLess_imp_ordLeq[OF Cfinite_ordLess_Cinfinite] s) |
|
794 |
hence "(r +c s) ^c t =o r ^c t" using t by (blast intro: cexp_cong1) |
|
795 |
also have "r ^c t \<le>o (r +c ctwo) ^c t" using t by (blast intro: cexp_mono1 ordLeq_csum1 r) |
|
796 |
finally show ?thesis . |
|
797 |
next |
|
798 |
case False |
|
799 |
with r have "Cfinite r" unfolding cinfinite_def cfinite_def by auto |
|
800 |
hence "Cfinite (r +c s)" by (intro Cfinite_csum s) |
|
801 |
hence "(r +c s) ^c t \<le>o ctwo ^c t" by (intro Cfinite_cexp_Cinfinite t) |
|
802 |
also have "ctwo ^c t \<le>o (r +c ctwo) ^c t" using t |
|
803 |
by (blast intro: cexp_mono1 ordLeq_csum2 Card_order_ctwo) |
|
804 |
finally show ?thesis . |
|
805 |
qed |
|
806 |
||
807 |
(* cardSuc *) |
|
808 |
||
809 |
lemma Cinfinite_cardSuc: "Cinfinite r \<Longrightarrow> Cinfinite (cardSuc r)" |
|
810 |
by (simp add: cinfinite_def cardSuc_Card_order cardSuc_finite) |
|
811 |
||
812 |
lemma cardSuc_UNION_Cinfinite: |
|
69276 | 813 |
assumes "Cinfinite r" "relChain (cardSuc r) As" "B \<le> (\<Union>i \<in> Field (cardSuc r). As i)" "|B| <=o r" |
67613 | 814 |
shows "\<exists>i \<in> Field (cardSuc r). B \<le> As i" |
54474 | 815 |
using cardSuc_UNION assms unfolding cinfinite_def by blast |
816 |
||
75624 | 817 |
lemma Cinfinite_card_suc: "\<lbrakk> Cinfinite r ; card_order r \<rbrakk> \<Longrightarrow> Cinfinite (card_suc r)" |
818 |
using Cinfinite_cong[OF cardSuc_ordIso_card_suc Cinfinite_cardSuc] . |
|
819 |
||
75625
0dd3ac5fdbaa
tuned BNF bounds for function space and bounded sets; NEWS and CONTRIBUTORS
traytel
parents:
75624
diff
changeset
|
820 |
lemma card_suc_least: "\<lbrakk>card_order r; Card_order s; r <o s\<rbrakk> \<Longrightarrow> card_suc r \<le>o s" |
0dd3ac5fdbaa
tuned BNF bounds for function space and bounded sets; NEWS and CONTRIBUTORS
traytel
parents:
75624
diff
changeset
|
821 |
by (rule ordIso_ordLeq_trans[OF ordIso_symmetric[OF cardSuc_ordIso_card_suc]]) |
0dd3ac5fdbaa
tuned BNF bounds for function space and bounded sets; NEWS and CONTRIBUTORS
traytel
parents:
75624
diff
changeset
|
822 |
(auto intro!: cardSuc_least simp: card_order_on_Card_order) |
0dd3ac5fdbaa
tuned BNF bounds for function space and bounded sets; NEWS and CONTRIBUTORS
traytel
parents:
75624
diff
changeset
|
823 |
|
75624 | 824 |
lemma regularCard_cardSuc: "Cinfinite k \<Longrightarrow> regularCard (cardSuc k)" |
825 |
by (rule infinite_cardSuc_regularCard) (auto simp: cinfinite_def) |
|
826 |
||
75625
0dd3ac5fdbaa
tuned BNF bounds for function space and bounded sets; NEWS and CONTRIBUTORS
traytel
parents:
75624
diff
changeset
|
827 |
lemma regularCard_card_suc: "card_order r \<Longrightarrow> Cinfinite r \<Longrightarrow> regularCard (card_suc r)" |
75624 | 828 |
using cardSuc_ordIso_card_suc Cinfinite_cardSuc regularCard_cardSuc regularCard_ordIso |
829 |
by blast |
|
830 |
||
54474 | 831 |
end |