src/ZF/AC/AC_Equiv.thy
author nipkow
Mon, 06 Jun 2005 21:21:19 +0200
changeset 16307 cb0f9e96d456
parent 14171 0cab06e3bbd0
child 16417 9bc16273c2d4
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1478
2b8c2a7547ab expanded tabs
clasohm
parents: 1401
diff changeset
     1
(*  Title:      ZF/AC/AC_Equiv.thy
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
     2
    ID:         $Id$
1478
2b8c2a7547ab expanded tabs
clasohm
parents: 1401
diff changeset
     3
    Author:     Krzysztof Grabczewski
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
     4
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
     5
Axioms AC1 -- AC19 come from "Equivalents of the Axiom of Choice, II"
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
     6
by H. Rubin and J.E. Rubin, 1985.
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
     7
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
     8
Axiom AC0 comes from "Axiomatic Set Theory" by P. Suppes, 1972.
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
     9
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    10
Some Isabelle proofs of equivalences of these axioms are formalizations of
1123
5dfdc1464966 Krzysztof Grabczewski's (nearly) complete AC proofs
lcp
parents: 1071
diff changeset
    11
proofs presented by the Rubins.  The others are based on the Rubins' proofs,
5dfdc1464966 Krzysztof Grabczewski's (nearly) complete AC proofs
lcp
parents: 1071
diff changeset
    12
but slightly changed.
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    13
*)
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    14
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    15
theory AC_Equiv = Main: (*obviously not Main_ZFC*)
8123
a71686059be0 a bit of tidying
paulson
parents: 2469
diff changeset
    16
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    17
constdefs
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    18
  
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    19
(* Well Ordering Theorems *)
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    20
  WO1 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    21
    "WO1 == \<forall>A. \<exists>R. well_ord(A,R)"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    22
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    23
  WO2 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    24
    "WO2 == \<forall>A. \<exists>a. Ord(a) & A\<approx>a"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    25
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    26
  WO3 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    27
    "WO3 == \<forall>A. \<exists>a. Ord(a) & (\<exists>b. b \<subseteq> a & A\<approx>b)"
1123
5dfdc1464966 Krzysztof Grabczewski's (nearly) complete AC proofs
lcp
parents: 1071
diff changeset
    28
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    29
  WO4 :: "i => o"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    30
    "WO4(m) == \<forall>A. \<exists>a f. Ord(a) & domain(f)=a &   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    31
		         (\<Union>b<a. f`b) = A & (\<forall>b<a. f`b \<lesssim> m)"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    32
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    33
  WO5 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    34
    "WO5 == \<exists>m \<in> nat. 1\<le>m & WO4(m)"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    35
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    36
  WO6 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    37
    "WO6 == \<forall>A. \<exists>m \<in> nat. 1\<le>m & (\<exists>a f. Ord(a) & domain(f)=a
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    38
		               & (\<Union>b<a. f`b) = A & (\<forall>b<a. f`b \<lesssim> m))"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    39
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    40
  WO7 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    41
    "WO7 == \<forall>A. Finite(A) <-> (\<forall>R. well_ord(A,R) --> well_ord(A,converse(R)))"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    42
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    43
  WO8 :: o
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
    44
    "WO8 == \<forall>A. (\<exists>f. f \<in> (\<Pi> X \<in> A. X)) --> (\<exists>R. well_ord(A,R))"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    45
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    46
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    47
(* Auxiliary concepts needed below *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    48
  pairwise_disjoint :: "i => o"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    49
    "pairwise_disjoint(A) == \<forall>A1 \<in> A. \<forall>A2 \<in> A. A1 Int A2 \<noteq> 0 --> A1=A2"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    50
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    51
  sets_of_size_between :: "[i, i, i] => o"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    52
    "sets_of_size_between(A,m,n) == \<forall>B \<in> A. m \<lesssim> B & B \<lesssim> n"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    53
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    54
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    55
(* Axioms of Choice *)  
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    56
  AC0 :: o
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
    57
    "AC0 == \<forall>A. \<exists>f. f \<in> (\<Pi> X \<in> Pow(A)-{0}. X)"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    58
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    59
  AC1 :: o
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
    60
    "AC1 == \<forall>A. 0\<notin>A --> (\<exists>f. f \<in> (\<Pi> X \<in> A. X))"
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    61
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    62
  AC2 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    63
    "AC2 == \<forall>A. 0\<notin>A & pairwise_disjoint(A)   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    64
		   --> (\<exists>C. \<forall>B \<in> A. \<exists>y. B Int C = {y})"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    65
  AC3 :: o
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
    66
    "AC3 == \<forall>A B. \<forall>f \<in> A->B. \<exists>g. g \<in> (\<Pi> x \<in> {a \<in> A. f`a\<noteq>0}. f`x)"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    67
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    68
  AC4 :: o
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
    69
    "AC4 == \<forall>R A B. (R \<subseteq> A*B --> (\<exists>f. f \<in> (\<Pi> x \<in> domain(R). R``{x})))"
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    70
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    71
  AC5 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    72
    "AC5 == \<forall>A B. \<forall>f \<in> A->B. \<exists>g \<in> range(f)->A. \<forall>x \<in> domain(g). f`(g`x) = x"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    73
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    74
  AC6 :: o
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
    75
    "AC6 == \<forall>A. 0\<notin>A --> (\<Pi> B \<in> A. B)\<noteq>0"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    76
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    77
  AC7 :: o
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
    78
    "AC7 == \<forall>A. 0\<notin>A & (\<forall>B1 \<in> A. \<forall>B2 \<in> A. B1\<approx>B2) --> (\<Pi> B \<in> A. B) \<noteq> 0"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    79
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    80
  AC8 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    81
    "AC8 == \<forall>A. (\<forall>B \<in> A. \<exists>B1 B2. B=<B1,B2> & B1\<approx>B2)   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    82
		   --> (\<exists>f. \<forall>B \<in> A. f`B \<in> bij(fst(B),snd(B)))"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    83
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    84
  AC9 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    85
    "AC9 == \<forall>A. (\<forall>B1 \<in> A. \<forall>B2 \<in> A. B1\<approx>B2) -->   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    86
		   (\<exists>f. \<forall>B1 \<in> A. \<forall>B2 \<in> A. f`<B1,B2> \<in> bij(B1,B2))"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    87
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    88
  AC10 :: "i => o"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    89
    "AC10(n) ==  \<forall>A. (\<forall>B \<in> A. ~Finite(B)) -->   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    90
		   (\<exists>f. \<forall>B \<in> A. (pairwise_disjoint(f`B) &   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    91
		   sets_of_size_between(f`B, 2, succ(n)) & Union(f`B)=B))"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
    92
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    93
  AC11 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    94
    "AC11 == \<exists>n \<in> nat. 1\<le>n & AC10(n)"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    95
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    96
  AC12 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    97
    "AC12 == \<forall>A. (\<forall>B \<in> A. ~Finite(B)) -->
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    98
  	         (\<exists>n \<in> nat. 1\<le>n & (\<exists>f. \<forall>B \<in> A. (pairwise_disjoint(f`B) &   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
    99
	              sets_of_size_between(f`B, 2, succ(n)) & Union(f`B)=B)))"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   100
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   101
  AC13 :: "i => o"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   102
    "AC13(m) == \<forall>A. 0\<notin>A --> (\<exists>f. \<forall>B \<in> A. f`B\<noteq>0 & f`B \<subseteq> B & f`B \<lesssim> m)"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   103
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   104
  AC14 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   105
    "AC14 == \<exists>m \<in> nat. 1\<le>m & AC13(m)"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   106
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   107
  AC15 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   108
    "AC15 == \<forall>A. 0\<notin>A --> 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   109
                 (\<exists>m \<in> nat. 1\<le>m & (\<exists>f. \<forall>B \<in> A. f`B\<noteq>0 & f`B \<subseteq> B & f`B \<lesssim> m))"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   110
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   111
  AC16 :: "[i, i] => o"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   112
    "AC16(n, k)  == 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   113
       \<forall>A. ~Finite(A) -->   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   114
	   (\<exists>T. T \<subseteq> {X \<in> Pow(A). X\<approx>succ(n)} &   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   115
	   (\<forall>X \<in> {X \<in> Pow(A). X\<approx>succ(k)}. \<exists>! Y. Y \<in> T & X \<subseteq> Y))"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   116
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   117
  AC17 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   118
    "AC17 == \<forall>A. \<forall>g \<in> (Pow(A)-{0} -> A) -> Pow(A)-{0}.   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   119
		   \<exists>f \<in> Pow(A)-{0} -> A. f`(g`f) \<in> g`f"
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   120
13416
5851987ab2e8 AC18: meta-level predicate via locale;
wenzelm
parents: 12820
diff changeset
   121
locale AC18 =
5851987ab2e8 AC18: meta-level predicate via locale;
wenzelm
parents: 12820
diff changeset
   122
  assumes AC18: "A\<noteq>0 & (\<forall>a \<in> A. B(a) \<noteq> 0) -->
5851987ab2e8 AC18: meta-level predicate via locale;
wenzelm
parents: 12820
diff changeset
   123
    ((\<Inter>a \<in> A. \<Union>b \<in> B(a). X(a,b)) =   
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
   124
      (\<Union>f \<in> \<Pi> a \<in> A. B(a). \<Inter>a \<in> A. X(a, f`a)))"
13416
5851987ab2e8 AC18: meta-level predicate via locale;
wenzelm
parents: 12820
diff changeset
   125
  --"AC18 cannot be expressed within the object-logic"
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   126
13416
5851987ab2e8 AC18: meta-level predicate via locale;
wenzelm
parents: 12820
diff changeset
   127
constdefs
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   128
  AC19 :: o
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   129
    "AC19 == \<forall>A. A\<noteq>0 & 0\<notin>A --> ((\<Inter>a \<in> A. \<Union>b \<in> a. b) =   
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
   130
		   (\<Union>f \<in> (\<Pi> B \<in> A. B). \<Inter>a \<in> A. f`a))"
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   131
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   132
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   133
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   134
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   135
(*                    Theorems concerning ordinals                        *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   136
(* ********************************************************************** *)
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   137
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   138
(* lemma for ordertype_Int *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   139
lemma rvimage_id: "rvimage(A,id(A),r) = r Int A*A"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   140
apply (unfold rvimage_def)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   141
apply (rule equalityI, safe)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   142
apply (drule_tac P = "%a. <id (A) `xb,a>:r" in id_conv [THEN subst],
12820
02e2ff3e4d37 lexical tidying
paulson
parents: 12814
diff changeset
   143
       assumption)
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   144
apply (drule_tac P = "%a. <a,ya>:r" in id_conv [THEN subst], (assumption+))
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   145
apply (fast intro: id_conv [THEN ssubst])
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   146
done
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   147
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   148
(* used only in Hartog.ML *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   149
lemma ordertype_Int:
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   150
     "well_ord(A,r) ==> ordertype(A, r Int A*A) = ordertype(A,r)"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   151
apply (rule_tac P = "%a. ordertype (A,a) =ordertype (A,r) " in rvimage_id [THEN subst])
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   152
apply (erule id_bij [THEN bij_ordertype_vimage])
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   153
done
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   154
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   155
lemma lam_sing_bij: "(\<lambda>x \<in> A. {x}) \<in> bij(A, {{x}. x \<in> A})"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   156
apply (rule_tac d = "%z. THE x. z={x}" in lam_bijective)
12814
paulson
parents: 12776
diff changeset
   157
apply (auto simp add: the_equality)
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   158
done
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   159
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   160
lemma inj_strengthen_type: 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   161
     "[| f \<in> inj(A, B);  !!a. a \<in> A ==> f`a \<in> C |] ==> f \<in> inj(A,C)"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   162
by (unfold inj_def, blast intro: Pi_type) 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   163
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   164
lemma nat_not_Finite: "~ Finite(nat)"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   165
by (unfold Finite_def, blast dest: eqpoll_imp_lepoll ltI lt_not_lepoll)
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   166
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   167
lemmas le_imp_lepoll = le_imp_subset [THEN subset_imp_lepoll]
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   168
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   169
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   170
(* Another elimination rule for \<exists>!                                       *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   171
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   172
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   173
lemma ex1_two_eq: "[| \<exists>! x. P(x); P(x); P(y) |] ==> x=y"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   174
by blast
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   175
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   176
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   177
(* image of a surjection                                                  *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   178
(* ********************************************************************** *)
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   179
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   180
lemma surj_image_eq: "f \<in> surj(A, B) ==> f``A = B"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   181
apply (unfold surj_def)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   182
apply (erule CollectE)
12820
02e2ff3e4d37 lexical tidying
paulson
parents: 12814
diff changeset
   183
apply (rule image_fun [THEN ssubst], assumption, rule subset_refl)
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   184
apply (blast dest: apply_type) 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   185
done
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   186
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   187
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   188
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   189
(* Lemmas used in the proofs like WO? ==> AC?                             *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   190
(* ********************************************************************** *)
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   191
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   192
lemma first_in_B:
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   193
     "[| well_ord(Union(A),r); 0\<notin>A; B \<in> A |] ==> (THE b. first(b,B,r)) \<in> B"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   194
by (blast dest!: well_ord_imp_ex1_first
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   195
                    [THEN theI, THEN first_def [THEN def_imp_iff, THEN iffD1]])
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   196
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
   197
lemma ex_choice_fun: "[| well_ord(Union(A), R); 0\<notin>A |] ==> \<exists>f. f:(\<Pi> X \<in> A. X)"
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   198
by (fast elim!: first_in_B intro!: lam_type)
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   199
14171
0cab06e3bbd0 Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents: 13416
diff changeset
   200
lemma ex_choice_fun_Pow: "well_ord(A, R) ==> \<exists>f. f:(\<Pi> X \<in> Pow(A)-{0}. X)"
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   201
by (fast elim!: well_ord_subset [THEN ex_choice_fun])
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   202
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   203
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   204
(* ********************************************************************** *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   205
(* Lemmas needed to state when a finite relation is a function.           *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   206
(*     The criteria are cardinalities of the relation and its domain.     *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   207
(*     Used in WO6WO1.ML                                                  *)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   208
(* ********************************************************************** *)
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   209
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   210
(*Using AC we could trivially prove, for all u, domain(u) \<lesssim> u*)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   211
lemma lepoll_m_imp_domain_lepoll_m: 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   212
     "[| m \<in> nat; u \<lesssim> m |] ==> domain(u) \<lesssim> m"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   213
apply (unfold lepoll_def)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   214
apply (erule exE)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   215
apply (rule_tac x = "\<lambda>x \<in> domain(u). LEAST i. \<exists>y. <x,y> \<in> u & f`<x,y> = i" 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   216
       in exI)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   217
apply (rule_tac d = "%y. fst (converse(f) ` y) " in lam_injective)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   218
apply (fast intro: LeastI2 nat_into_Ord [THEN Ord_in_Ord] 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   219
                           inj_is_fun [THEN apply_type])
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   220
apply (erule domainE)
12820
02e2ff3e4d37 lexical tidying
paulson
parents: 12814
diff changeset
   221
apply (frule inj_is_fun [THEN apply_type], assumption)
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   222
apply (rule LeastI2)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   223
apply (auto elim!: nat_into_Ord [THEN Ord_in_Ord])
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   224
done
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   225
12776
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   226
lemma rel_domain_ex1: 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   227
    "[| succ(m) \<lesssim> domain(r); r \<lesssim> succ(m); m \<in> nat |] ==> function(r)"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   228
apply (unfold function_def, safe)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   229
apply (rule ccontr) 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   230
apply (fast elim!: lepoll_trans [THEN succ_lepoll_natE] 
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   231
                   lepoll_m_imp_domain_lepoll_m [OF _ Diff_sing_lepoll]
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   232
            elim: domain_Diff_eq [OF _ not_sym, THEN subst])
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   233
done
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   234
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   235
lemma rel_is_fun:
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   236
     "[| succ(m) \<lesssim> domain(r);  r \<lesssim> succ(m);  m \<in> nat;   
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   237
         r \<subseteq> A*B; A=domain(r) |] ==> r \<in> A->B"
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   238
by (simp add: Pi_iff rel_domain_ex1)
249600a63ba9 Isar version of AC
paulson
parents: 12536
diff changeset
   239
991
547931cbbf08 New example of AC Equivalences by Krzysztof Grabczewski
lcp
parents:
diff changeset
   240
end