src/ZF/AC.ML
author paulson
Mon, 27 Mar 2000 17:04:03 +0200
changeset 8590 89675b444abe
parent 5809 bacf85370ce0
child 9907 473a6604da94
permissions -rw-r--r--
added an order-sorted version of quickSort
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1074
diff changeset
     1
(*  Title:      ZF/AC.ML
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
     2
    ID:         $Id$
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1074
diff changeset
     3
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
     4
    Copyright   1994  University of Cambridge
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
     5
5809
bacf85370ce0 removed obsolete comment and "open" declaration
paulson
parents: 5321
diff changeset
     6
The Axiom of Choice
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
     7
*)
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
     8
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
     9
(*The same as AC, but no premise a:A*)
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    10
val [nonempty] = goal AC.thy
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    11
     "[| !!x. x:A ==> (EX y. y:B(x)) |] ==> EX z. z : Pi(A,B)";
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    12
by (excluded_middle_tac "A=0" 1);
4091
771b1f6422a8 isatool fixclasimp;
wenzelm
parents: 3840
diff changeset
    13
by (asm_simp_tac (simpset() addsimps [Pi_empty1]) 2 THEN Blast_tac 2);
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    14
(*The non-trivial case*)
4091
771b1f6422a8 isatool fixclasimp;
wenzelm
parents: 3840
diff changeset
    15
by (blast_tac (claset() addIs [AC, nonempty]) 1);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 741
diff changeset
    16
qed "AC_Pi";
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    17
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    18
(*Using dtac, this has the advantage of DELETING the universal quantifier*)
5137
60205b0de9b9 Huge tidy-up: removal of leading \!\!
paulson
parents: 5067
diff changeset
    19
Goal "ALL x:A. EX y. y:B(x) ==> EX y. y : Pi(A,B)";
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1074
diff changeset
    20
by (rtac AC_Pi 1);
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1074
diff changeset
    21
by (etac bspec 1);
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    22
by (assume_tac 1);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 741
diff changeset
    23
qed "AC_ball_Pi";
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    24
5067
62b6288e6005 isatool fixgoal;
wenzelm
parents: 4091
diff changeset
    25
Goal "EX f. f: (PROD X: Pow(C)-{0}. X)";
3840
e0baea4d485a fixed dots;
wenzelm
parents: 3016
diff changeset
    26
by (res_inst_tac [("B1", "%x. x")] (AC_Pi RS exE) 1);
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    27
by (etac exI 2);
3016
15763781afb0 Conversion to use blast_tac
paulson
parents: 2493
diff changeset
    28
by (Blast_tac 1);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 741
diff changeset
    29
qed "AC_Pi_Pow";
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    30
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    31
val [nonempty] = goal AC.thy
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1074
diff changeset
    32
     "[| !!x. x:A ==> (EX y. y:x)       \
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    33
\     |] ==> EX f: A->Union(A). ALL x:A. f`x : x";
3840
e0baea4d485a fixed dots;
wenzelm
parents: 3016
diff changeset
    34
by (res_inst_tac [("B1", "%x. x")] (AC_Pi RS exE) 1);
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    35
by (etac nonempty 1);
4091
771b1f6422a8 isatool fixclasimp;
wenzelm
parents: 3840
diff changeset
    36
by (blast_tac (claset() addDs [apply_type] addIs [Pi_type]) 1);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 741
diff changeset
    37
qed "AC_func";
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    38
741
5b0dedadb5c2 tidied proofs, using fast_tac etc. as much as possible
lcp
parents: 484
diff changeset
    39
goal ZF.thy "!!x A. [| 0 ~: A;  x: A |] ==> EX y. y:x";
5b0dedadb5c2 tidied proofs, using fast_tac etc. as much as possible
lcp
parents: 484
diff changeset
    40
by (subgoal_tac "x ~= 0" 1);
3016
15763781afb0 Conversion to use blast_tac
paulson
parents: 2493
diff changeset
    41
by (ALLGOALS Blast_tac);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 741
diff changeset
    42
qed "non_empty_family";
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    43
5137
60205b0de9b9 Huge tidy-up: removal of leading \!\!
paulson
parents: 5067
diff changeset
    44
Goal "0 ~: A ==> EX f: A->Union(A). ALL x:A. f`x : x";
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    45
by (rtac AC_func 1);
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    46
by (REPEAT (ares_tac [non_empty_family] 1));
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 741
diff changeset
    47
qed "AC_func0";
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    48
5067
62b6288e6005 isatool fixgoal;
wenzelm
parents: 4091
diff changeset
    49
Goal "EX f: (Pow(C)-{0}) -> C. ALL x:(Pow(C)-{0}). f`x : x";
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    50
by (resolve_tac [AC_func0 RS bexE] 1);
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    51
by (rtac bexI 2);
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    52
by (assume_tac 2);
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1074
diff changeset
    53
by (etac fun_weaken_type 2);
3016
15763781afb0 Conversion to use blast_tac
paulson
parents: 2493
diff changeset
    54
by (ALLGOALS Blast_tac);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 741
diff changeset
    55
qed "AC_func_Pow";
484
70b789956bd3 Axiom of choice, cardinality results, etc.
lcp
parents:
diff changeset
    56
5137
60205b0de9b9 Huge tidy-up: removal of leading \!\!
paulson
parents: 5067
diff changeset
    57
Goal "0 ~: A ==> EX f. f: (PROD x:A. x)";
1074
d60f203eeddf Modified proofs for new claset primitives. The problem is that they enforce
lcp
parents: 760
diff changeset
    58
by (rtac AC_Pi 1);
d60f203eeddf Modified proofs for new claset primitives. The problem is that they enforce
lcp
parents: 760
diff changeset
    59
by (REPEAT (ares_tac [non_empty_family] 1));
d60f203eeddf Modified proofs for new claset primitives. The problem is that they enforce
lcp
parents: 760
diff changeset
    60
qed "AC_Pi0";
d60f203eeddf Modified proofs for new claset primitives. The problem is that they enforce
lcp
parents: 760
diff changeset
    61
5321
f8848433d240 got rid of some goal thy commands
paulson
parents: 5137
diff changeset
    62
(*Used in Zorn.ML*)
f8848433d240 got rid of some goal thy commands
paulson
parents: 5137
diff changeset
    63
Goal "[| ch : (PROD X:Pow(S) - {0}. X);  X<=S;  X~=S |] ==> ch ` (S-X) : S-X";
f8848433d240 got rid of some goal thy commands
paulson
parents: 5137
diff changeset
    64
by (etac apply_type 1);
f8848433d240 got rid of some goal thy commands
paulson
parents: 5137
diff changeset
    65
by (blast_tac (claset() addSEs [equalityE]) 1);
f8848433d240 got rid of some goal thy commands
paulson
parents: 5137
diff changeset
    66
qed "choice_Diff";
f8848433d240 got rid of some goal thy commands
paulson
parents: 5137
diff changeset
    67