src/ZF/AC/WO1_AC.thy
author wenzelm
Sat, 03 Sep 2022 15:39:26 +0200
changeset 76044 c90799513ed0
parent 46822 95f1e700b712
child 76213 e44d86131648
permissions -rw-r--r--
tuned signature;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
12776
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
     1
(*  Title:      ZF/AC/WO1_AC.thy
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
     2
    Author:     Krzysztof Grabczewski
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
     3
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
     4
The proofs of WO1 ==> AC1 and WO1 ==> AC10(n) for n >= 1
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
     5
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
     6
The latter proof is referred to as clear by the Rubins.
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
     7
However it seems to be quite complicated.
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
     8
The formal proof presented below is a mechanisation of the proof 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
     9
by Lawrence C. Paulson which is the following:
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    10
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    11
Assume WO1.  Let s be a set of infinite sets.
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    12
 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    13
Suppose x \<in> s.  Then x is equipollent to |x| (by WO1), an infinite cardinal
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 32960
diff changeset
    14
call it K.  Since K = K \<oplus> K = |K+K| (by InfCard_cdouble_eq) there is an 
12776
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    15
isomorphism h \<in> bij(K+K, x).  (Here + means disjoint sum.)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    16
 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    17
So there is a partition of x into 2-element sets, namely
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    18
 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    19
        {{h(Inl(i)), h(Inr(i))} . i \<in> K}
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    20
 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    21
So for all x \<in> s the desired partition exists.  By AC1 (which follows from WO1) 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    22
there exists a function f that chooses a partition for each x \<in> s.  Therefore we 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    23
have AC10(2).
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    24
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    25
*)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    26
27678
85ea2be46c71 dropped locale (open)
haftmann
parents: 16417
diff changeset
    27
theory WO1_AC
85ea2be46c71 dropped locale (open)
haftmann
parents: 16417
diff changeset
    28
imports AC_Equiv
85ea2be46c71 dropped locale (open)
haftmann
parents: 16417
diff changeset
    29
begin
12776
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    30
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    31
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    32
(* WO1 ==> AC1                                                            *)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    33
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    34
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    35
theorem WO1_AC1: "WO1 ==> AC1"
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    36
by (unfold AC1_def WO1_def, fast elim!: ex_choice_fun)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    37
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    38
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    39
(* WO1 ==> AC10(n) (n >= 1)                                               *)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    40
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    41
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    42
lemma lemma1: "[| WO1; \<forall>B \<in> A. \<exists>C \<in> D(B). P(C,B) |] ==> \<exists>f. \<forall>B \<in> A. P(f`B,B)"
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    43
apply (unfold WO1_def)
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 32960
diff changeset
    44
apply (erule_tac x = "\<Union>({{C \<in> D (B) . P (C,B) }. B \<in> A}) " in allE)
12776
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    45
apply (erule exE, drule ex_choice_fun, fast)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    46
apply (erule exE)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    47
apply (rule_tac x = "\<lambda>x \<in> A. f`{C \<in> D (x) . P (C,x) }" in exI)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    48
apply (simp, blast dest!: apply_type [OF _ RepFunI])
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    49
done
1196
d43c1f7a53fe Numerous small improvements by KG and LCP
lcp
parents:
diff changeset
    50
12776
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    51
lemma lemma2_1: "[| ~Finite(B); WO1 |] ==> |B| + |B| \<approx>  B"
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    52
apply (unfold WO1_def)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    53
apply (rule eqpoll_trans)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    54
prefer 2 apply (fast elim!: well_ord_cardinal_eqpoll)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    55
apply (rule eqpoll_sym [THEN eqpoll_trans])
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    56
apply (fast elim!: well_ord_cardinal_eqpoll)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    57
apply (drule spec [of _ B]) 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    58
apply (clarify dest!: eqpoll_imp_Finite_iff [OF well_ord_cardinal_eqpoll]) 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    59
apply (simp add: cadd_def [symmetric] 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    60
            eqpoll_refl InfCard_cdouble_eq Card_cardinal Inf_Card_is_InfCard) 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    61
done
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    62
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    63
lemma lemma2_2:
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    64
     "f \<in> bij(D+D, B) ==> {{f`Inl(i), f`Inr(i)}. i \<in> D} \<in> Pow(Pow(B))"
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    65
by (fast elim!: bij_is_fun [THEN apply_type])
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    66
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    67
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    68
lemma lemma2_3: 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    69
        "f \<in> bij(D+D, B) ==> pairwise_disjoint({{f`Inl(i), f`Inr(i)}. i \<in> D})"
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    70
apply (unfold pairwise_disjoint_def)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    71
apply (blast dest: bij_is_inj [THEN inj_apply_equality])
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    72
done
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    73
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    74
lemma lemma2_4:
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    75
     "[| f \<in> bij(D+D, B); 1\<le>n |] 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    76
      ==> sets_of_size_between({{f`Inl(i), f`Inr(i)}. i \<in> D}, 2, succ(n))"
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    77
apply (simp (no_asm_simp) add: sets_of_size_between_def succ_def)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    78
apply (blast intro!: cons_lepoll_cong 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    79
            intro: singleton_eqpoll_1 [THEN eqpoll_imp_lepoll]  
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    80
                   le_imp_subset [THEN subset_imp_lepoll]  lepoll_trans 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    81
            dest: bij_is_inj [THEN inj_apply_equality] elim!: mem_irrefl)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    82
done
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    83
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    84
lemma lemma2_5: 
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 32960
diff changeset
    85
     "f \<in> bij(D+D, B) ==> \<Union>({{f`Inl(i), f`Inr(i)}. i \<in> D})=B"
12776
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    86
apply (unfold bij_def surj_def)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    87
apply (fast elim!: inj_is_fun [THEN apply_type])
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    88
done
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    89
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    90
lemma lemma2:
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    91
     "[| WO1; ~Finite(B); 1\<le>n  |]   
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    92
      ==> \<exists>C \<in> Pow(Pow(B)). pairwise_disjoint(C) &   
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    93
                sets_of_size_between(C, 2, succ(n)) &   
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 32960
diff changeset
    94
                \<Union>(C)=B"
12776
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    95
apply (drule lemma2_1 [THEN eqpoll_def [THEN def_imp_iff, THEN iffD1]], 
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    96
       assumption)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    97
apply (blast intro!: lemma2_2 lemma2_3 lemma2_4 lemma2_5)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    98
done
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
    99
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
   100
theorem WO1_AC10: "[| WO1; 1\<le>n |] ==> AC10(n)"
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
   101
apply (unfold AC10_def)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
   102
apply (fast intro!: lemma1 elim!: lemma2)
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
   103
done
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
   104
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
   105
end
249600a63ba9 Isar version of AC
paulson
parents: 1196
diff changeset
   106