src/ZF/zf.ML
author lcp
Fri, 17 Sep 1993 16:16:38 +0200
changeset 6 8ce8c4d13d4d
parent 0 a5a9c433f639
child 37 cebe01deba80
permissions -rw-r--r--
Installation of new simplifier for ZF. Deleted all congruence rules not involving local assumptions. NB the congruence rules for Sigma and Pi (dependent type constructions) cause difficulties and are not used by default.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     1
(*  Title: 	ZF/zf.ML
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     2
    ID:         $Id$
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     3
    Author: 	Lawrence C Paulson and Martin D Coen, CU Computer Laboratory
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     4
    Copyright   1992  University of Cambridge
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     5
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     6
Basic introduction and elimination rules for Zermelo-Fraenkel Set Theory 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     7
*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     8
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     9
open ZF;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    10
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    11
signature ZF_LEMMAS = 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
  sig
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    13
  val ballE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    14
  val ballI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    15
  val ball_cong : thm
6
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
    16
  val ball_simp : thm
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    17
  val ball_tac : int -> tactic
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    18
  val bexCI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    19
  val bexE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    20
  val bexI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    21
  val bex_cong : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    22
  val bspec : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    23
  val CollectD1 : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    24
  val CollectD2 : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    25
  val CollectE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    26
  val CollectI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    27
  val Collect_cong : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    28
  val emptyE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    29
  val empty_subsetI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    30
  val equalityCE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    31
  val equalityD1 : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    32
  val equalityD2 : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    33
  val equalityE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    34
  val equalityI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    35
  val equality_iffI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    36
  val equals0D : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    37
  val equals0I : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    38
  val ex1_functional : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    39
  val InterD : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    40
  val InterE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    41
  val InterI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    42
  val INT_E : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    43
  val INT_I : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    44
  val lemmas_cs : claset
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    45
  val PowD : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    46
  val PowI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    47
  val RepFunE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    48
  val RepFunI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    49
  val RepFun_eqI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    50
  val RepFun_cong : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    51
  val ReplaceE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    52
  val ReplaceI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    53
  val Replace_iff : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    54
  val Replace_cong : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    55
  val rev_ballE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    56
  val rev_bspec : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    57
  val rev_subsetD : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    58
  val separation : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    59
  val setup_induction : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    60
  val set_mp_tac : int -> tactic
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    61
  val subsetCE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    62
  val subsetD : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    63
  val subsetI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    64
  val subset_refl : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    65
  val subset_trans : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    66
  val UnionE : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    67
  val UnionI : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    68
  val UN_E : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    69
  val UN_I : thm
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    70
  end;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    71
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    72
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    73
structure ZF_Lemmas : ZF_LEMMAS = 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    74
struct
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    75
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    76
(*** Bounded universal quantifier ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    77
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    78
val ballI = prove_goalw ZF.thy [Ball_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    79
    "[| !!x. x:A ==> P(x) |] ==> ALL x:A. P(x)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    80
 (fn prems=> [ (REPEAT (ares_tac (prems @ [allI,impI]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    81
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    82
val bspec = prove_goalw ZF.thy [Ball_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    83
    "[| ALL x:A. P(x);  x: A |] ==> P(x)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    84
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    85
  [ (rtac (major RS spec RS mp) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    86
    (resolve_tac prems 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    87
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    88
val ballE = prove_goalw ZF.thy [Ball_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    89
    "[| ALL x:A. P(x);  P(x) ==> Q;  ~ x:A ==> Q |] ==> Q"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    90
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    91
  [ (rtac (major RS allE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    92
    (REPEAT (eresolve_tac (prems@[asm_rl,impCE]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    93
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    94
(*Used in the datatype package*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    95
val rev_bspec = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    96
    "!!x A P. [| x: A;  ALL x:A. P(x) |] ==> P(x)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    97
 (fn _ =>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    98
  [ REPEAT (ares_tac [bspec] 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    99
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   100
(*Instantiates x first: better for automatic theorem proving?*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   101
val rev_ballE = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   102
    "[| ALL x:A. P(x);  ~ x:A ==> Q;  P(x) ==> Q |] ==> Q"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   103
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   104
  [ (rtac (major RS ballE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   105
    (REPEAT (eresolve_tac prems 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   106
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   107
(*Takes assumptions ALL x:A.P(x) and a:A; creates assumption P(a)*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   108
val ball_tac = dtac bspec THEN' assume_tac;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   109
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   110
(*Trival rewrite rule;   (ALL x:A.P)<->P holds only if A is nonempty!*)
6
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   111
val ball_simp = prove_goal ZF.thy "(ALL x:A. True) <-> True"
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   112
 (fn _=> [ (REPEAT (ares_tac [TrueI,ballI,iffI] 1)) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   113
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   114
(*Congruence rule for rewriting*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   115
val ball_cong = prove_goalw ZF.thy [Ball_def]
6
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   116
    "[| A=A';  !!x. x:A' ==> P(x) <-> P'(x) |] ==> Ball(A,P) <-> Ball(A',P')"
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   117
 (fn prems=> [ (simp_tac (FOL_ss addsimps prems) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   118
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   119
(*** Bounded existential quantifier ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   120
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   121
val bexI = prove_goalw ZF.thy [Bex_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   122
    "[| P(x);  x: A |] ==> EX x:A. P(x)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   123
 (fn prems=> [ (REPEAT (ares_tac (prems @ [exI,conjI]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   124
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   125
(*Not of the general form for such rules; ~EX has become ALL~ *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   126
val bexCI = prove_goal ZF.thy 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   127
   "[| ALL x:A. ~P(x) ==> P(a);  a: A |] ==> EX x:A.P(x)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   128
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   129
  [ (rtac classical 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   130
    (REPEAT (ares_tac (prems@[bexI,ballI,notI,notE]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   131
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   132
val bexE = prove_goalw ZF.thy [Bex_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   133
    "[| EX x:A. P(x);  !!x. [| x:A; P(x) |] ==> Q \
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   134
\    |] ==> Q"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   135
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   136
  [ (rtac (major RS exE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   137
    (REPEAT (eresolve_tac (prems @ [asm_rl,conjE]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   138
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   139
(*We do not even have (EX x:A. True) <-> True unless A is nonempty!!*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   140
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   141
val bex_cong = prove_goalw ZF.thy [Bex_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   142
    "[| A=A';  !!x. x:A' ==> P(x) <-> P'(x) \
6
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   143
\    |] ==> Bex(A,P) <-> Bex(A',P')"
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   144
 (fn prems=> [ (simp_tac (FOL_ss addsimps prems addcongs [conj_cong]) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   145
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   146
(*** Rules for subsets ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   147
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   148
val subsetI = prove_goalw ZF.thy [subset_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   149
    "(!!x.x:A ==> x:B) ==> A <= B"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   150
 (fn prems=> [ (REPEAT (ares_tac (prems @ [ballI]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   151
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   152
(*Rule in Modus Ponens style [was called subsetE] *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   153
val subsetD = prove_goalw ZF.thy [subset_def] "[| A <= B;  c:A |] ==> c:B"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   154
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   155
  [ (rtac (major RS bspec) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   156
    (resolve_tac prems 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   157
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   158
(*Classical elimination rule*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   159
val subsetCE = prove_goalw ZF.thy [subset_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   160
    "[| A <= B;  ~(c:A) ==> P;  c:B ==> P |] ==> P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   161
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   162
  [ (rtac (major RS ballE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   163
    (REPEAT (eresolve_tac prems 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   164
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   165
(*Takes assumptions A<=B; c:A and creates the assumption c:B *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   166
val set_mp_tac = dtac subsetD THEN' assume_tac;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   167
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   168
(*Sometimes useful with premises in this order*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   169
val rev_subsetD = prove_goal ZF.thy "!!A B c. [| c:A; A<=B |] ==> c:B"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   170
 (fn _=> [REPEAT (ares_tac [subsetD] 1)]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   171
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   172
val subset_refl = prove_goal ZF.thy "A <= A"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   173
 (fn _=> [ (rtac subsetI 1), atac 1 ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   174
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   175
val subset_trans = prove_goal ZF.thy "[| A<=B;  B<=C |] ==> A<=C"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   176
 (fn prems=> [ (REPEAT (ares_tac ([subsetI]@(prems RL [subsetD])) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   177
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   178
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   179
(*** Rules for equality ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   180
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   181
(*Anti-symmetry of the subset relation*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   182
val equalityI = prove_goal ZF.thy "[| A <= B;  B <= A |] ==> A = B"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   183
 (fn prems=> [ (REPEAT (resolve_tac (prems@[conjI, extension RS iffD2]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   184
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   185
val equality_iffI = prove_goal ZF.thy "(!!x. x:A <-> x:B) ==> A = B"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   186
 (fn [prem] =>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   187
  [ (rtac equalityI 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   188
    (REPEAT (ares_tac [subsetI, prem RS iffD1, prem RS iffD2] 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   189
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   190
val equalityD1 = prove_goal ZF.thy "A = B ==> A<=B"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   191
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   192
  [ (rtac (extension RS iffD1 RS conjunct1) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   193
    (resolve_tac prems 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   194
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   195
val equalityD2 = prove_goal ZF.thy "A = B ==> B<=A"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   196
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   197
  [ (rtac (extension RS iffD1 RS conjunct2) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   198
    (resolve_tac prems 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   199
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   200
val equalityE = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   201
    "[| A = B;  [| A<=B; B<=A |] ==> P |]  ==>  P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   202
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   203
  [ (DEPTH_SOLVE (resolve_tac (prems@[equalityD1,equalityD2]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   204
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   205
val equalityCE = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   206
    "[| A = B;  [| c:A; c:B |] ==> P;  [| ~ c:A; ~ c:B |] ==> P |]  ==>  P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   207
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   208
  [ (rtac (major RS equalityE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   209
    (REPEAT (contr_tac 1 ORELSE eresolve_tac ([asm_rl,subsetCE]@prems) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   210
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   211
(*Lemma for creating induction formulae -- for "pattern matching" on p
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   212
  To make the induction hypotheses usable, apply "spec" or "bspec" to
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   213
  put universal quantifiers over the free variables in p. 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   214
  Would it be better to do subgoal_tac "ALL z. p = f(z) --> R(z)" ??*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   215
val setup_induction = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   216
    "[| p: A;  !!z. z: A ==> p=z --> R |] ==> R"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   217
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   218
  [ (rtac mp 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   219
    (REPEAT (resolve_tac (refl::prems) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   220
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   221
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   222
(*** Rules for Replace -- the derived form of replacement ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   223
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   224
val ex1_functional = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   225
    "[| EX! z. P(a,z);  P(a,b);  P(a,c) |] ==> b = c"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   226
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   227
  [ (cut_facts_tac prems 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   228
    (best_tac FOL_dup_cs 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   229
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   230
val Replace_iff = prove_goalw ZF.thy [Replace_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   231
    "b : {y. x:A, P(x,y)}  <->  (EX x:A. P(x,b) & (ALL y. P(x,y) --> y=b))"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   232
 (fn _=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   233
  [ (rtac (replacement RS iff_trans) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   234
    (REPEAT (ares_tac [refl,bex_cong,iffI,ballI,allI,conjI,impI,ex1I] 1
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   235
        ORELSE eresolve_tac [conjE, spec RS mp, ex1_functional] 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   236
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   237
(*Introduction; there must be a unique y such that P(x,y), namely y=b. *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   238
val ReplaceI = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   239
    "[| x: A;  P(x,b);  !!y. P(x,y) ==> y=b |] ==> \
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   240
\    b : {y. x:A, P(x,y)}"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   241
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   242
  [ (rtac (Replace_iff RS iffD2) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   243
    (REPEAT (ares_tac (prems@[bexI,conjI,allI,impI]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   244
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   245
(*Elimination; may asssume there is a unique y such that P(x,y), namely y=b. *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   246
val ReplaceE = prove_goal ZF.thy 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   247
    "[| b : {y. x:A, P(x,y)};  \
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   248
\       !!x. [| x: A;  P(x,b);  ALL y. P(x,y)-->y=b |] ==> R \
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   249
\    |] ==> R"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   250
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   251
  [ (rtac (Replace_iff RS iffD1 RS bexE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   252
    (etac conjE 2),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   253
    (REPEAT (ares_tac prems 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   254
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   255
val Replace_cong = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   256
    "[| A=B;  !!x y. x:B ==> P(x,y) <-> Q(x,y) |] ==> \
6
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   257
\    Replace(A,P) = Replace(B,Q)"
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   258
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   259
   let val substprems = prems RL [subst, ssubst]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   260
       and iffprems = prems RL [iffD1,iffD2]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   261
   in [ (rtac equalityI 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   262
	(REPEAT (eresolve_tac (substprems@[asm_rl, ReplaceE, spec RS mp]) 1
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   263
	 ORELSE resolve_tac [subsetI, ReplaceI] 1
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   264
	 ORELSE (resolve_tac iffprems 1 THEN assume_tac 2))) ]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   265
   end);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   266
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   267
(*** Rules for RepFun ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   268
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   269
val RepFunI = prove_goalw ZF.thy [RepFun_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   270
    "!!a A. a : A ==> f(a) : {f(x). x:A}"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   271
 (fn _ => [ (REPEAT (ares_tac [ReplaceI,refl] 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   272
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   273
(*Useful for co-induction proofs*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   274
val RepFun_eqI = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   275
    "!!b a f. [| b=f(a);  a : A |] ==> b : {f(x). x:A}"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   276
 (fn _ => [ etac ssubst 1, etac RepFunI 1 ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   277
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   278
val RepFunE = prove_goalw ZF.thy [RepFun_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   279
    "[| b : {f(x). x:A};  \
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   280
\       !!x.[| x:A;  b=f(x) |] ==> P |] ==> \
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   281
\    P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   282
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   283
  [ (rtac (major RS ReplaceE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   284
    (REPEAT (ares_tac prems 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   285
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   286
val RepFun_cong = prove_goalw ZF.thy [RepFun_def]
6
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   287
    "[| A=B;  !!x. x:B ==> f(x)=g(x) |] ==> RepFun(A,f) = RepFun(B,g)"
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   288
 (fn prems=> [ (simp_tac (FOL_ss addcongs [Replace_cong] addsimps prems) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   289
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   290
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   291
(*** Rules for Collect -- forming a subset by separation ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   292
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   293
(*Separation is derivable from Replacement*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   294
val separation = prove_goalw ZF.thy [Collect_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   295
    "a : {x:A. P(x)} <-> a:A & P(a)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   296
 (fn _=> [ (fast_tac (FOL_cs addIs  [bexI,ReplaceI] 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   297
		             addSEs [bexE,ReplaceE]) 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   298
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   299
val CollectI = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   300
    "[| a:A;  P(a) |] ==> a : {x:A. P(x)}"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   301
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   302
  [ (rtac (separation RS iffD2) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   303
    (REPEAT (resolve_tac (prems@[conjI]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   304
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   305
val CollectE = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   306
    "[| a : {x:A. P(x)};  [| a:A; P(a) |] ==> R |] ==> R"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   307
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   308
  [ (rtac (separation RS iffD1 RS conjE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   309
    (REPEAT (ares_tac prems 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   310
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   311
val CollectD1 = prove_goal ZF.thy "a : {x:A. P(x)} ==> a:A"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   312
 (fn [major]=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   313
  [ (rtac (major RS CollectE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   314
    (assume_tac 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   315
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   316
val CollectD2 = prove_goal ZF.thy "a : {x:A. P(x)} ==> P(a)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   317
 (fn [major]=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   318
  [ (rtac (major RS CollectE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   319
    (assume_tac 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   320
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   321
val Collect_cong = prove_goalw ZF.thy [Collect_def] 
6
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   322
    "[| A=B;  !!x. x:B ==> P(x) <-> Q(x) |] ==> Collect(A,P) = Collect(B,Q)"
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   323
 (fn prems=> [ (simp_tac (FOL_ss addcongs [Replace_cong] addsimps prems) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   324
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   325
(*** Rules for Unions ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   326
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   327
(*The order of the premises presupposes that C is rigid; A may be flexible*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   328
val UnionI = prove_goal ZF.thy "[| B: C;  A: B |] ==> A: Union(C)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   329
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   330
  [ (resolve_tac [union_iff RS iffD2] 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   331
    (REPEAT (resolve_tac (prems @ [bexI]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   332
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   333
val UnionE = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   334
    "[| A : Union(C);  !!B.[| A: B;  B: C |] ==> R |] ==> R"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   335
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   336
  [ (resolve_tac [union_iff RS iffD1 RS bexE] 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   337
    (REPEAT (ares_tac prems 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   338
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   339
(*** Rules for Inter ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   340
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   341
(*Not obviously useful towards proving InterI, InterD, InterE*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   342
val Inter_iff = prove_goalw ZF.thy [Inter_def,Ball_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   343
    "A : Inter(C) <-> (ALL x:C. A: x) & (EX x. x:C)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   344
 (fn _=> [ (rtac (separation RS iff_trans) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   345
	   (fast_tac (FOL_cs addIs [UnionI] addSEs [UnionE]) 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   346
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   347
(* Intersection is well-behaved only if the family is non-empty! *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   348
val InterI = prove_goalw ZF.thy [Inter_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   349
    "[| !!x. x: C ==> A: x;  c:C |] ==> A : Inter(C)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   350
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   351
  [ (DEPTH_SOLVE (ares_tac ([CollectI,UnionI,ballI] @ prems) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   352
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   353
(*A "destruct" rule -- every B in C contains A as an element, but
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   354
  A:B can hold when B:C does not!  This rule is analogous to "spec". *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   355
val InterD = prove_goalw ZF.thy [Inter_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   356
    "[| A : Inter(C);  B : C |] ==> A : B"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   357
 (fn [major,minor]=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   358
  [ (rtac (major RS CollectD2 RS bspec) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   359
    (rtac minor 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   360
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   361
(*"Classical" elimination rule -- does not require exhibiting B:C *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   362
val InterE = prove_goalw ZF.thy [Inter_def]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   363
    "[| A : Inter(C);  A:B ==> R;  ~ B:C ==> R |] ==> R"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   364
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   365
  [ (rtac (major RS CollectD2 RS ballE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   366
    (REPEAT (eresolve_tac prems 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   367
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   368
(*** Rules for Unions of families ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   369
(* UN x:A. B(x) abbreviates Union({B(x). x:A}) *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   370
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   371
(*The order of the premises presupposes that A is rigid; b may be flexible*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   372
val UN_I = prove_goal ZF.thy "[| a: A;  b: B(a) |] ==> b: (UN x:A. B(x))"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   373
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   374
  [ (REPEAT (resolve_tac (prems@[UnionI,RepFunI]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   375
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   376
val UN_E = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   377
    "[| b : (UN x:A. B(x));  !!x.[| x: A;  b: B(x) |] ==> R |] ==> R"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   378
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   379
  [ (rtac (major RS UnionE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   380
    (REPEAT (eresolve_tac (prems@[asm_rl, RepFunE, subst]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   381
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   382
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   383
(*** Rules for Intersections of families ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   384
(* INT x:A. B(x) abbreviates Inter({B(x). x:A}) *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   385
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   386
val INT_I = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   387
    "[| !!x. x: A ==> b: B(x);  a: A |] ==> b: (INT x:A. B(x))"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   388
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   389
  [ (REPEAT (ares_tac (prems@[InterI,RepFunI]) 1
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   390
     ORELSE eresolve_tac [RepFunE,ssubst] 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   391
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   392
val INT_E = prove_goal ZF.thy
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   393
    "[| b : (INT x:A. B(x));  a: A |] ==> b : B(a)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   394
 (fn [major,minor]=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   395
  [ (rtac (major RS InterD) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   396
    (rtac (minor RS RepFunI) 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   397
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   398
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   399
(*** Rules for Powersets ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   400
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   401
val PowI = prove_goal ZF.thy "A <= B ==> A : Pow(B)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   402
 (fn [prem]=> [ (rtac (prem RS (power_set RS iffD2)) 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   403
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   404
val PowD = prove_goal ZF.thy "A : Pow(B)  ==>  A<=B"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   405
 (fn [major]=> [ (rtac (major RS (power_set RS iffD1)) 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   406
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   407
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   408
(*** Rules for the empty set ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   409
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   410
(*The set {x:0.False} is empty; by foundation it equals 0 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   411
  See Suppes, page 21.*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   412
val emptyE = prove_goal ZF.thy "a:0 ==> P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   413
 (fn [major]=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   414
  [ (rtac (foundation RS disjE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   415
    (etac (equalityD2 RS subsetD RS CollectD2 RS FalseE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   416
    (rtac major 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   417
    (etac bexE 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   418
    (etac (CollectD2 RS FalseE) 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   419
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   420
val empty_subsetI = prove_goal ZF.thy "0 <= A"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   421
 (fn _ => [ (REPEAT (ares_tac [equalityI,subsetI,emptyE] 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   422
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   423
val equals0I = prove_goal ZF.thy "[| !!y. y:A ==> False |] ==> A=0"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   424
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   425
  [ (REPEAT (ares_tac (prems@[empty_subsetI,subsetI,equalityI]) 1 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   426
      ORELSE eresolve_tac (prems RL [FalseE]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   427
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   428
val equals0D = prove_goal ZF.thy "[| A=0;  a:A |] ==> P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   429
 (fn [major,minor]=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   430
  [ (rtac (minor RS (major RS equalityD1 RS subsetD RS emptyE)) 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   431
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   432
val lemmas_cs = FOL_cs
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   433
  addSIs [ballI, InterI, CollectI, PowI, subsetI]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   434
  addIs [bexI, UnionI, ReplaceI, RepFunI]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   435
  addSEs [bexE, make_elim PowD, UnionE, ReplaceE, RepFunE,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   436
	  CollectE, emptyE]
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   437
  addEs [rev_ballE, InterD, make_elim InterD, subsetD, subsetCE];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   438
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   439
end;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   440
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   441
open ZF_Lemmas;