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