src/ZF/upair.ML
author paulson
Fri, 03 Jan 1997 15:01:55 +0100
changeset 2469 b50b8c0eec01
parent 1609 5324067d993f
child 2493 bdeb5024353a
permissions -rw-r--r--
Implicit simpsets and clasets for FOL and ZF
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1017
diff changeset
     1
(*  Title:      ZF/upair
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     2
    ID:         $Id$
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1017
diff changeset
     3
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     4
    Copyright   1991  University of Cambridge
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     5
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     6
UNORDERED pairs in Zermelo-Fraenkel Set Theory 
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     7
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     8
Observe the order of dependence:
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     9
    Upair is defined in terms of Replace
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    10
    Un is defined in terms of Upair and Union (similarly for Int)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    11
    cons is defined in terms of Upair and Un
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
    Ordered pairs and descriptions are defined using cons ("set notation")
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    13
*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    14
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    15
(*** Lemmas about power sets  ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    16
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1017
diff changeset
    17
val Pow_bottom = empty_subsetI RS PowI;         (* 0 : Pow(B) *)
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1017
diff changeset
    18
val Pow_top = subset_refl RS PowI;              (* A : Pow(A) *)
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1017
diff changeset
    19
val Pow_neq_0 = Pow_top RSN (2,equals0D);       (* Pow(a)=0 ==> P *) 
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    20
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    21
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    22
(*** Unordered pairs - Upair ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    23
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    24
qed_goalw "Upair_iff" thy [Upair_def]
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    25
    "c : Upair(a,b) <-> (c=a | c=b)"
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    26
 (fn _ => [ (fast_tac (!claset addEs [Pow_neq_0, sym RS Pow_neq_0]) 1) ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    27
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    28
Addsimps [Upair_iff];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    29
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    30
qed_goal "UpairI1" thy "a : Upair(a,b)"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    31
 (fn _ => [ Simp_tac 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    32
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    33
qed_goal "UpairI2" thy "b : Upair(a,b)"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    34
 (fn _ => [ Simp_tac 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    35
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    36
qed_goal "UpairE" thy
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    37
    "[| a : Upair(b,c);  a=b ==> P;  a=c ==> P |] ==> P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    38
 (fn major::prems=>
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    39
  [ (rtac (major RS (Upair_iff RS iffD1 RS disjE)) 1),
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    40
    (REPEAT (eresolve_tac prems 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    41
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    42
(*UpairI1/2 should become UpairCI?*)
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    43
AddSIs [UpairI1,UpairI2];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    44
AddSEs [UpairE];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    45
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    46
(*** Rules for binary union -- Un -- defined via Upair ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    47
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    48
qed_goalw "Un_iff" thy [Un_def] "c : A Un B <-> (c:A | c:B)"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    49
 (fn _ => [ Fast_tac 1 ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    50
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    51
Addsimps [Un_iff];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    52
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    53
qed_goal "UnI1" thy "!!c. c : A ==> c : A Un B"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    54
 (fn _ => [ Asm_simp_tac 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    55
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    56
qed_goal "UnI2" thy "!!c. c : B ==> c : A Un B"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    57
 (fn _ => [ Asm_simp_tac 1 ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    58
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    59
qed_goal "UnE" thy 
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    60
    "[| c : A Un B;  c:A ==> P;  c:B ==> P |] ==> P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    61
 (fn major::prems=>
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    62
  [ (rtac (major RS (Un_iff RS iffD1 RS disjE)) 1),
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    63
    (REPEAT (eresolve_tac prems 1)) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    64
572
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    65
(*Stronger version of the rule above*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    66
qed_goal "UnE'" thy
572
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    67
    "[| c : A Un B;  c:A ==> P;  [| c:B;  c~:A |] ==> P |] ==> P"
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    68
 (fn major::prems =>
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    69
  [(rtac (major RS UnE) 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    70
   (eresolve_tac prems 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    71
   (rtac classical 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    72
   (eresolve_tac prems 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    73
   (swap_res_tac prems 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    74
   (etac notnotD 1)]);
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
    75
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    76
(*Classical introduction rule: no commitment to A vs B*)
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    77
qed_goal "UnCI" thy "(c ~: B ==> c : A) ==> c : A Un B"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    78
 (fn prems=>
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    79
  [ Simp_tac 1, fast_tac (!claset addIs prems) 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    80
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    81
AddSIs [UnCI];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    82
AddSEs [UnE];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    83
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    84
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    85
(*** Rules for small intersection -- Int -- defined via Upair ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    86
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    87
qed_goalw "Int_iff" thy [Int_def] "c : A Int B <-> (c:A & c:B)"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    88
 (fn _ => [ Fast_tac 1 ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    89
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    90
Addsimps [Int_iff];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    91
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    92
qed_goal "IntI" thy "!!c. [| c : A;  c : B |] ==> c : A Int B"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    93
 (fn _ => [ Asm_simp_tac 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    94
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    95
qed_goal "IntD1" thy "!!c. c : A Int B ==> c : A"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    96
 (fn _ => [ Asm_full_simp_tac 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    97
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    98
qed_goal "IntD2" thy "!!c. c : A Int B ==> c : B"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
    99
 (fn _ => [ Asm_full_simp_tac 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   100
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   101
qed_goal "IntE" thy
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   102
    "[| c : A Int B;  [| c:A; c:B |] ==> P |] ==> P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   103
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   104
  [ (resolve_tac prems 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   105
    (REPEAT (resolve_tac (prems RL [IntD1,IntD2]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   106
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   107
AddSIs [IntI];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   108
AddSEs [IntE];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   109
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   110
(*** Rules for set difference -- defined via Upair ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   111
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   112
qed_goalw "Diff_iff" thy [Diff_def] "c : A-B <-> (c:A & c~:B)"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   113
 (fn _ => [ Fast_tac 1 ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   114
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   115
Addsimps [Diff_iff];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   116
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   117
qed_goal "DiffI" thy "!!c. [| c : A;  c ~: B |] ==> c : A - B"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   118
 (fn _ => [ Asm_simp_tac 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   119
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   120
qed_goal "DiffD1" thy "!!c. c : A - B ==> c : A"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   121
 (fn _ => [ Asm_full_simp_tac 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   122
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   123
qed_goal "DiffD2" thy "!!c. c : A - B ==> c ~: B"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   124
 (fn _ => [ Asm_full_simp_tac 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   125
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   126
qed_goal "DiffE" thy
37
cebe01deba80 added ~: for "not in"
lcp
parents: 14
diff changeset
   127
    "[| c : A - B;  [| c:A; c~:B |] ==> P |] ==> P"
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   128
 (fn prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   129
  [ (resolve_tac prems 1),
485
5e00a676a211 Axiom of choice, cardinality results, etc.
lcp
parents: 437
diff changeset
   130
    (REPEAT (ares_tac (prems RL [DiffD1, DiffD2]) 1)) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   131
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   132
AddSIs [DiffI];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   133
AddSEs [DiffE];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   134
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   135
(*** Rules for cons -- defined via Un and Upair ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   136
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   137
qed_goalw "cons_iff" thy [cons_def] "a : cons(b,A) <-> (a=b | a:A)"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   138
 (fn _ => [ Fast_tac 1 ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   139
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   140
Addsimps [cons_iff];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   141
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   142
qed_goal "consI1" thy "a : cons(a,B)"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   143
 (fn _ => [ Simp_tac 1 ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   144
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   145
Addsimps [consI1];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   146
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   147
qed_goal "consI2" thy "!!B. a : B ==> a : cons(b,B)"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   148
 (fn _ => [ Asm_simp_tac 1 ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   149
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   150
qed_goal "consE" thy
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   151
    "[| a : cons(b,A);  a=b ==> P;  a:A ==> P |] ==> P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   152
 (fn major::prems=>
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   153
  [ (rtac (major RS (cons_iff RS iffD1 RS disjE)) 1),
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   154
    (REPEAT (eresolve_tac (prems @ [UpairE]) 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   155
572
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   156
(*Stronger version of the rule above*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   157
qed_goal "consE'" thy
572
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   158
    "[| a : cons(b,A);  a=b ==> P;  [| a:A;  a~=b |] ==> P |] ==> P"
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   159
 (fn major::prems =>
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   160
  [(rtac (major RS consE) 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   161
   (eresolve_tac prems 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   162
   (rtac classical 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   163
   (eresolve_tac prems 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   164
   (swap_res_tac prems 1),
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   165
   (etac notnotD 1)]);
13c30ac40f8f ZF/upair/consE', UnE': new
lcp
parents: 485
diff changeset
   166
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   167
(*Classical introduction rule*)
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   168
qed_goal "consCI" thy "(a~:B ==> a=b) ==> a: cons(b,B)"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   169
 (fn prems=>
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   170
  [ Simp_tac 1, fast_tac (!claset addIs prems) 1 ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   171
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   172
AddSIs [consCI];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   173
AddSEs [consE];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   174
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   175
qed_goal "cons_not_0" thy "cons(a,B) ~= 0"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   176
 (fn _ => [ (fast_tac (!claset addEs [equalityE]) 1) ]);
1609
5324067d993f New lemmas for Mutilated Checkerboard
paulson
parents: 1461
diff changeset
   177
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   178
bind_thm ("cons_neq_0", cons_not_0 RS notE);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   179
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   180
Addsimps [cons_not_0, cons_not_0 RS not_sym];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   181
1609
5324067d993f New lemmas for Mutilated Checkerboard
paulson
parents: 1461
diff changeset
   182
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   183
(*** Singletons - using cons ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   184
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   185
qed_goal "singleton_iff" thy "a : {b} <-> a=b"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   186
 (fn _ => [ Simp_tac 1 ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   187
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   188
qed_goal "singletonI" thy "a : {a}"
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   189
 (fn _=> [ (rtac consI1 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   190
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   191
bind_thm ("singletonE", make_elim (singleton_iff RS iffD1));
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   192
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   193
AddSIs [singletonI];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   194
AddSEs [singletonE];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   195
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   196
(*** Rules for Descriptions ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   197
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   198
qed_goalw "the_equality" thy [the_def]
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   199
    "[| P(a);  !!x. P(x) ==> x=a |] ==> (THE x. P(x)) = a"
738
3054a10ed5b5 the_equality: more careful use of addSIs and addIs
lcp
parents: 686
diff changeset
   200
 (fn [pa,eq] =>
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   201
  [ (fast_tac (!claset addSIs [pa] addIs [equalityI]
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   202
	               addEs [eq RS subst]) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   203
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   204
(* Only use this if you already know EX!x. P(x) *)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   205
qed_goal "the_equality2" thy
673
023cef668158 ZF/upair/mem_asym,succ_inject: tidied
lcp
parents: 572
diff changeset
   206
    "!!P. [| EX! x. P(x);  P(a) |] ==> (THE x. P(x)) = a"
023cef668158 ZF/upair/mem_asym,succ_inject: tidied
lcp
parents: 572
diff changeset
   207
 (fn _ =>
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   208
  [ (deepen_tac (!claset addSIs [the_equality]) 1 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   209
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   210
qed_goal "theI" thy "EX! x. P(x) ==> P(THE x. P(x))"
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   211
 (fn [major]=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   212
  [ (rtac (major RS ex1E) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   213
    (resolve_tac [major RS the_equality2 RS ssubst] 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   214
    (REPEAT (assume_tac 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   215
686
be908d8d41ef ZF/upair/theI2: new
lcp
parents: 673
diff changeset
   216
(*Easier to apply than theI: conclusion has only one occurrence of P*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   217
qed_goal "theI2" thy
686
be908d8d41ef ZF/upair/theI2: new
lcp
parents: 673
diff changeset
   218
    "[| EX! x. P(x);  !!x. P(x) ==> Q(x) |] ==> Q(THE x.P(x))"
be908d8d41ef ZF/upair/theI2: new
lcp
parents: 673
diff changeset
   219
 (fn prems => [ resolve_tac prems 1, 
1461
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1017
diff changeset
   220
                rtac theI 1, 
6bcb44e4d6e5 expanded tabs
clasohm
parents: 1017
diff changeset
   221
                resolve_tac prems 1 ]);
686
be908d8d41ef ZF/upair/theI2: new
lcp
parents: 673
diff changeset
   222
435
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents: 37
diff changeset
   223
(*the_cong is no longer necessary: if (ALL y.P(y)<->Q(y)) then 
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents: 37
diff changeset
   224
  (THE x.P(x))  rewrites to  (THE x. Q(x))  *)
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents: 37
diff changeset
   225
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents: 37
diff changeset
   226
(*If it's "undefined", it's zero!*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   227
qed_goalw "the_0" thy [the_def]
435
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents: 37
diff changeset
   228
    "!!P. ~ (EX! x. P(x)) ==> (THE x. P(x))=0"
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   229
 (fn _ => [ (fast_tac (!claset addIs [equalityI] addSEs [ReplaceE]) 1) ]);
435
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents: 37
diff changeset
   230
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   231
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   232
(*** if -- a conditional expression for formulae ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   233
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   234
goalw thy [if_def] "if(True,a,b) = a";
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   235
by (fast_tac (!claset addIs [the_equality]) 1);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 738
diff changeset
   236
qed "if_true";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   237
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   238
goalw thy [if_def] "if(False,a,b) = b";
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   239
by (fast_tac (!claset addIs [the_equality]) 1);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 738
diff changeset
   240
qed "if_false";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   241
6
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   242
(*Never use with case splitting, or if P is known to be true or false*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   243
val prems = goalw thy [if_def]
6
8ce8c4d13d4d Installation of new simplifier for ZF. Deleted all congruence rules not
lcp
parents: 0
diff changeset
   244
    "[| P<->Q;  Q ==> a=c;  ~Q ==> b=d |] ==> if(P,a,b) = if(Q,c,d)";
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   245
by (simp_tac (!simpset addsimps prems addcongs [conj_cong]) 1);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 738
diff changeset
   246
qed "if_cong";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   247
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   248
(*Not needed for rewriting, since P would rewrite to True anyway*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   249
goalw thy [if_def] "!!P. P ==> if(P,a,b) = a";
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   250
by (fast_tac (!claset addSIs [the_equality]) 1);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 738
diff changeset
   251
qed "if_P";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   252
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   253
(*Not needed for rewriting, since P would rewrite to False anyway*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   254
goalw thy [if_def] "!!P. ~P ==> if(P,a,b) = b";
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   255
by (fast_tac (!claset addSIs [the_equality]) 1);
760
f0200e91b272 added qed and qed_goal[w]
clasohm
parents: 738
diff changeset
   256
qed "if_not_P";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   257
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   258
Addsimps [if_true, if_false];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   259
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   260
qed_goal "expand_if" thy
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   261
    "P(if(Q,x,y)) <-> ((Q --> P(x)) & (~Q --> P(y)))"
437
435875e4b21d modifications for cardinal arithmetic
lcp
parents: 435
diff changeset
   262
 (fn _=> [ (excluded_middle_tac "Q" 1),
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   263
           (Asm_simp_tac 1),
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   264
           (Asm_simp_tac 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   265
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   266
qed_goal "if_iff" thy "a: if(P,x,y) <-> P & a:x | ~P & a:y"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   267
 (fn _=> [ (simp_tac (!simpset setloop split_tac [expand_if]) 1) ]);
1017
6a402dc505cf Proved if_iff and used it to simplify proof of if_type.
lcp
parents: 985
diff changeset
   268
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   269
qed_goal "if_type" thy
1017
6a402dc505cf Proved if_iff and used it to simplify proof of if_type.
lcp
parents: 985
diff changeset
   270
    "[| P ==> a: A;  ~P ==> b: A |] ==> if(P,a,b): A"
6a402dc505cf Proved if_iff and used it to simplify proof of if_type.
lcp
parents: 985
diff changeset
   271
 (fn prems=> [ (simp_tac 
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   272
                (!simpset addsimps prems setloop split_tac [expand_if]) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   273
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   274
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   275
(*** Foundation lemmas ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   276
437
435875e4b21d modifications for cardinal arithmetic
lcp
parents: 435
diff changeset
   277
(*was called mem_anti_sym*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   278
qed_goal "mem_asym" thy "!!P. [| a:b;  b:a |] ==> P"
673
023cef668158 ZF/upair/mem_asym,succ_inject: tidied
lcp
parents: 572
diff changeset
   279
 (fn _=>
023cef668158 ZF/upair/mem_asym,succ_inject: tidied
lcp
parents: 572
diff changeset
   280
  [ (res_inst_tac [("A1","{a,b}")] (foundation RS disjE) 1),
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   281
    REPEAT (fast_tac (!claset addSEs [equalityE]) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   282
437
435875e4b21d modifications for cardinal arithmetic
lcp
parents: 435
diff changeset
   283
(*was called mem_anti_refl*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   284
qed_goal "mem_irrefl" thy "a:a ==> P"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   285
 (fn [major]=> [ (rtac ([major,major] MRS mem_asym) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   286
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   287
(*mem_irrefl should NOT be added to default databases:
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   288
      it would be tried on most goals, making proofs slower!*)
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   289
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   290
qed_goal "mem_not_refl" thy "a ~: a"
437
435875e4b21d modifications for cardinal arithmetic
lcp
parents: 435
diff changeset
   291
 (K [ (rtac notI 1), (etac mem_irrefl 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   292
435
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents: 37
diff changeset
   293
(*Good for proving inequalities by rewriting*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   294
qed_goal "mem_imp_not_eq" thy "!!a A. a:A ==> a ~= A"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   295
 (fn _=> [ fast_tac (!claset addSEs [mem_irrefl]) 1 ]);
435
ca5356bd315a Addition of cardinals and order types, various tidying
lcp
parents: 37
diff changeset
   296
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   297
(*** Rules for succ ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   298
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   299
qed_goalw "succ_iff" thy [succ_def] "i : succ(j) <-> i=j | i:j"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   300
 (fn _ => [ Fast_tac 1 ]);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   301
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   302
qed_goalw "succI1" thy [succ_def] "i : succ(i)"
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   303
 (fn _=> [ (rtac consI1 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   304
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   305
Addsimps [succI1];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   306
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   307
qed_goalw "succI2" thy [succ_def]
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   308
    "i : j ==> i : succ(j)"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   309
 (fn [prem]=> [ (rtac (prem RS consI2) 1) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   310
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   311
qed_goalw "succE" thy [succ_def]
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   312
    "[| i : succ(j);  i=j ==> P;  i:j ==> P |] ==> P"
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   313
 (fn major::prems=>
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   314
  [ (rtac (major RS consE) 1),
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   315
    (REPEAT (eresolve_tac prems 1)) ]);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   316
14
1c0926788772 ex/{bin.ML,comb.ML,prop.ML}: replaced NewSext by Syntax.simple_sext
lcp
parents: 6
diff changeset
   317
(*Classical introduction rule*)
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   318
qed_goal "succCI" thy "(i~:j ==> i=j) ==> i: succ(j)"
14
1c0926788772 ex/{bin.ML,comb.ML,prop.ML}: replaced NewSext by Syntax.simple_sext
lcp
parents: 6
diff changeset
   319
 (fn [prem]=>
1c0926788772 ex/{bin.ML,comb.ML,prop.ML}: replaced NewSext by Syntax.simple_sext
lcp
parents: 6
diff changeset
   320
  [ (rtac (disjCI RS (succ_iff RS iffD2)) 1),
1c0926788772 ex/{bin.ML,comb.ML,prop.ML}: replaced NewSext by Syntax.simple_sext
lcp
parents: 6
diff changeset
   321
    (etac prem 1) ]);
1c0926788772 ex/{bin.ML,comb.ML,prop.ML}: replaced NewSext by Syntax.simple_sext
lcp
parents: 6
diff changeset
   322
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   323
AddSIs [succCI];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   324
AddSEs [succE];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   325
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   326
qed_goal "succ_not_0" thy "succ(n) ~= 0"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   327
 (fn _=> [ (fast_tac (!claset addSEs [equalityE]) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   328
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   329
bind_thm ("succ_neq_0", succ_not_0 RS notE);
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   330
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   331
Addsimps [succ_not_0, succ_not_0 RS not_sym];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   332
AddSEs [succ_neq_0, sym RS succ_neq_0];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   333
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   334
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   335
(* succ(c) <= B ==> c : B *)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   336
val succ_subsetD = succI1 RSN (2,subsetD);
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   337
1609
5324067d993f New lemmas for Mutilated Checkerboard
paulson
parents: 1461
diff changeset
   338
(* succ(b) ~= b *)
5324067d993f New lemmas for Mutilated Checkerboard
paulson
parents: 1461
diff changeset
   339
bind_thm ("succ_neq_self", succI1 RS mem_imp_not_eq RS not_sym);
5324067d993f New lemmas for Mutilated Checkerboard
paulson
parents: 1461
diff changeset
   340
5324067d993f New lemmas for Mutilated Checkerboard
paulson
parents: 1461
diff changeset
   341
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   342
qed_goal "succ_inject_iff" thy "succ(m) = succ(n) <-> m=n"
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   343
 (fn _=> [ (fast_tac (!claset addEs [mem_asym, equalityE]) 1) ]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   344
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   345
bind_thm ("succ_inject", succ_inject_iff RS iffD1);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   346
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   347
Addsimps [succ_inject_iff];
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   348
AddSDs [succ_inject];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   349
2469
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   350
b50b8c0eec01 Implicit simpsets and clasets for FOL and ZF
paulson
parents: 1609
diff changeset
   351
use"simpdata.ML";