src/ZF/Order.ML
author lcp
Tue, 21 Jun 1994 17:20:34 +0200
changeset 435 ca5356bd315a
child 437 435875e4b21d
permissions -rw-r--r--
Addition of cardinals and order types, various tidying
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
435
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
     1
(*  Title: 	ZF/Order.ML
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
     2
    ID:         $Id$
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
     3
    Author: 	Lawrence C Paulson, Cambridge University Computer Laboratory
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
     4
    Copyright   1994  University of Cambridge
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
     5
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
     6
For Order.thy.  Orders in Zermelo-Fraenkel Set Theory 
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
     7
*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
     8
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
     9
(*TO PURE/TACTIC.ML*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    10
fun subgoals_tac sprops = EVERY' (map subgoal_tac sprops);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    11
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    12
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    13
open Order;
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    14
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    15
val bij_apply_cs = ZF_cs addSEs [bij_converse_bij]
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    16
                         addIs  [bij_is_fun, apply_type];
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    17
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    18
val bij_inverse_ss = 
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    19
    ZF_ss addsimps [bij_is_fun RS apply_type,
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    20
		    bij_converse_bij RS bij_is_fun RS apply_type,
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    21
		    left_inverse_bij, right_inverse_bij];
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    22
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    23
(** Basic properties of the definitions **)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    24
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    25
(*needed????*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    26
goalw Order.thy [part_ord_def, irrefl_def, trans_on_def, asym_def]
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    27
    "!!r. part_ord(A,r) ==> asym(r Int A*A)";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    28
by (fast_tac ZF_cs 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    29
val part_ord_Imp_asym = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    30
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    31
(** Order-isomorphisms **)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    32
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    33
goalw Order.thy [ord_iso_def] 
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    34
    "!!f. f: ord_iso(A,r,B,s) ==> f: bij(A,B)";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    35
by (etac CollectD1 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    36
val ord_iso_is_bij = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    37
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    38
goalw Order.thy [ord_iso_def] 
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    39
    "!!f. [| f: ord_iso(A,r,B,s);  <x,y>: r;  x:A;  y:A |] ==> \
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    40
\         <f`x, f`y> : s";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    41
by (fast_tac ZF_cs 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    42
val ord_iso_apply = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    43
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    44
goalw Order.thy [ord_iso_def] 
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    45
    "!!f. [| f: ord_iso(A,r,B,s);  <x,y>: s;  x:B;  y:B |] ==> \
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    46
\         <converse(f) ` x, converse(f) ` y> : r";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    47
be CollectE 1;
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    48
be (bspec RS bspec RS iffD2) 1;
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    49
by (REPEAT (eresolve_tac [asm_rl, 
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    50
			  bij_converse_bij RS bij_is_fun RS apply_type] 1));
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    51
by (asm_simp_tac (ZF_ss addsimps [right_inverse_bij]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    52
val ord_iso_converse = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    53
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    54
val major::premx::premy::prems = goalw Order.thy [linear_def]
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    55
    "[| linear(A,r);  x:A;  y:A;  \
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    56
\       <x,y>:r ==> P;  x=y ==> P;  <y,x>:r ==> P |] ==> P";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    57
by (cut_facts_tac [major,premx,premy] 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    58
by (REPEAT_FIRST (eresolve_tac [ballE,disjE]));
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    59
by (EVERY1 (map etac prems));
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    60
by (ALLGOALS contr_tac);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    61
val linearE = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    62
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    63
(*Does the case analysis, deleting linear(A,r) and proving trivial subgoals*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    64
val linear_case_tac =
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    65
    SELECT_GOAL (EVERY [etac linearE 1, assume_tac 1, assume_tac 1,
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    66
			REPEAT_SOME assume_tac]);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    67
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    68
(*Inductive argument for proving Kunen's Lemma 6.1*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    69
goalw Order.thy [well_ord_def, tot_ord_def, part_ord_def, pred_def]
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    70
  "!!r. [| well_ord(A,r);  x: A;  f: ord_iso(A, r, pred(A,x,r), r);  y: A |] \
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    71
\       ==> f`y = y";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    72
by (safe_tac ZF_cs);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    73
by (wf_on_ind_tac "y" [] 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    74
by (forward_tac [ord_iso_is_bij] 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    75
by (subgoal_tac "f`y1 : {y: A . <y, x> : r}" 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    76
by (fast_tac (ZF_cs addSEs [bij_is_fun RS apply_type]) 2);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    77
(*Now we know f`y1 : A  and  <f`y1, x> : r  *)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    78
by (etac CollectE 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    79
by (linear_case_tac 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    80
(*Case  <f`y1, y1> : r *)   (*use induction hyp*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    81
by (dtac bspec 1 THEN mp_tac 2 THEN assume_tac 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    82
by (dres_inst_tac [("t", "op `(converse(f))")] subst_context 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    83
by (asm_full_simp_tac (ZF_ss addsimps [left_inverse_bij]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    84
(*The case  <y1, f`y1> : r  *)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    85
by (subgoal_tac "<y1,x> : r" 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    86
by (fast_tac (ZF_cs addSEs [trans_onD]) 2);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    87
by (dtac ord_iso_converse 1 THEN assume_tac 1 THEN fast_tac ZF_cs 2);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    88
by (fast_tac ZF_cs 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    89
by (asm_full_simp_tac (ZF_ss addsimps [left_inverse_bij]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    90
(*now use induction hyp*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    91
by (dtac bspec 1 THEN mp_tac 2 THEN fast_tac bij_apply_cs 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    92
by (dres_inst_tac [("t", "op `(f)")] subst_context 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    93
by (asm_full_simp_tac (ZF_ss addsimps [right_inverse_bij]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    94
val not_well_ord_iso_pred_lemma = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    95
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    96
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    97
(*Kunen's Lemma 6.1: there's no order-isomorphism to an initial segment
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    98
                     of a well-ordering*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
    99
goal Order.thy
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   100
    "!!r. [| well_ord(A,r);  x:A |] ==> \
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   101
\         ALL f. f ~: ord_iso(A, r, pred(A,x,r), r)";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   102
by (safe_tac ZF_cs);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   103
by (metacut_tac not_well_ord_iso_pred_lemma 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   104
by (REPEAT_SOME assume_tac);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   105
(*Now we know f`x = x*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   106
by (EVERY1 [dtac (ord_iso_is_bij RS bij_is_fun RS apply_type),
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   107
	     assume_tac]);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   108
(*Now we know f`x : pred(A,x,r) *)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   109
by (asm_full_simp_tac (ZF_ss addsimps [well_ord_def, pred_def]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   110
by (fast_tac (ZF_cs addSEs [wf_on_not_refl RS notE]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   111
val not_well_ord_iso_pred = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   112
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   113
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   114
(*Inductive argument for proving Kunen's Lemma 6.2*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   115
goalw Order.thy [well_ord_def, tot_ord_def, part_ord_def]
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   116
    "!!r. [| well_ord(A,r);  well_ord(B,s);  \
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   117
\            f: ord_iso(A,r, B,s);  g: ord_iso(A,r, B,s);  y: A |] \
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   118
\         ==> f`y = g`y";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   119
by (safe_tac ZF_cs);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   120
by (wf_on_ind_tac "y" [] 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   121
by (subgoals_tac ["f: bij(A,B)", "g: bij(A,B)", "f`y1 : B", "g`y1 : B"] 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   122
by (REPEAT (fast_tac (bij_apply_cs addSEs [ord_iso_is_bij]) 2));
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   123
by (linear_case_tac 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   124
(*The case  <f`y1, g`y1> : s  *)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   125
by (forw_inst_tac [("f","g")] ord_iso_converse 1 THEN REPEAT (assume_tac 1));
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   126
by (asm_full_simp_tac (ZF_ss addsimps [left_inverse_bij]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   127
by (dtac bspec 1 THEN mp_tac 2 THEN fast_tac bij_apply_cs 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   128
by (dres_inst_tac [("t", "op `(converse(f))")] subst_context 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   129
by (dres_inst_tac [("t", "op `(g)")] subst_context 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   130
by (asm_full_simp_tac bij_inverse_ss 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   131
(*The case  <g`y1, f`y1> : s  *)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   132
by (forw_inst_tac [("f","f")] ord_iso_converse 1 THEN REPEAT (assume_tac 1));
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   133
by (asm_full_simp_tac (ZF_ss addsimps [left_inverse_bij]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   134
by (dtac bspec 1 THEN mp_tac 2 THEN fast_tac bij_apply_cs 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   135
by (dres_inst_tac [("t", "op `(converse(g))")] subst_context 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   136
by (dres_inst_tac [("t", "op `(f)")] subst_context 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   137
by (asm_full_simp_tac bij_inverse_ss 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   138
val well_ord_iso_unique_lemma = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   139
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   140
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   141
(*Kunen's Lemma 6.2: Order-isomorphisms between well-orderings are unique*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   142
goal Order.thy
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   143
    "!!r. [| well_ord(A,r);  well_ord(B,s);  \
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   144
\            f: ord_iso(A,r, B,s);  g: ord_iso(A,r, B,s) |] ==> f = g";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   145
br fun_extension 1;
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   146
be (ord_iso_is_bij RS bij_is_fun) 1;
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   147
be (ord_iso_is_bij RS bij_is_fun) 1;
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   148
br well_ord_iso_unique_lemma 1;
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   149
by (REPEAT_SOME assume_tac);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   150
val well_ord_iso_unique = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   151
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   152
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   153
goalw Order.thy [irrefl_def, part_ord_def, tot_ord_def, 
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   154
		 trans_on_def, well_ord_def]
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   155
    "!!r. [| wf[A](r); linear(A,r) |] ==> well_ord(A,r)";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   156
by (asm_simp_tac (ZF_ss addsimps [wf_on_not_refl]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   157
by (safe_tac ZF_cs);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   158
by (linear_case_tac 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   159
(*case x=xb*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   160
by (fast_tac (ZF_cs addSEs [wf_on_anti_sym]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   161
(*case x<xb*)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   162
by (fast_tac (ZF_cs addSEs [wf_on_chain3]) 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   163
val well_ordI = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   164
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   165
goalw Order.thy [well_ord_def]
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   166
    "!!r. well_ord(A,r) ==> wf[A](r)";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   167
by (safe_tac ZF_cs);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   168
val well_ord_is_wf = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   169
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   170
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   171
(*** Derived rules for pred(A,x,r) ***)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   172
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   173
val [major,minor] = goalw Order.thy [pred_def]
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   174
    "[| y: pred(A,x,r);  [| y:A; <y,x>:r |] ==> P |] ==> P";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   175
br (major RS CollectE) 1;
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   176
by (REPEAT (ares_tac [minor] 1));
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   177
val predE = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   178
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   179
goalw Order.thy [pred_def] "pred(A,x,r) <= r -`` {x}";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   180
by (fast_tac ZF_cs 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   181
val pred_subset_under = result();
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   182
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   183
goalw Order.thy [pred_def] "pred(A,x,r) <= A";
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   184
by (fast_tac ZF_cs 1);
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents:
diff changeset
   185
val pred_subset = result();