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