| author | wenzelm | 
| Tue, 07 Nov 2006 11:46:49 +0100 | |
| changeset 21207 | cef082634be9 | 
| parent 20380 | 14f9f2a1caa6 | 
| child 21210 | c17fd2df4e9e | 
| permissions | -rw-r--r-- | 
| 923 | 1 | (* Title: HOL/Set.thy | 
| 2 | ID: $Id$ | |
| 12257 | 3 | Author: Tobias Nipkow, Lawrence C Paulson and Markus Wenzel | 
| 923 | 4 | *) | 
| 5 | ||
| 11979 | 6 | header {* Set theory for higher-order logic *}
 | 
| 7 | ||
| 15131 | 8 | theory Set | 
| 17508 | 9 | imports LOrder | 
| 15131 | 10 | begin | 
| 11979 | 11 | |
| 12 | text {* A set in HOL is simply a predicate. *}
 | |
| 923 | 13 | |
| 2261 | 14 | |
| 11979 | 15 | subsection {* Basic syntax *}
 | 
| 2261 | 16 | |
| 3947 | 17 | global | 
| 18 | ||
| 11979 | 19 | typedecl 'a set | 
| 12338 
de0f4a63baa5
renamed class "term" to "type" (actually "HOL.type");
 wenzelm parents: 
12257diff
changeset | 20 | arities set :: (type) type | 
| 3820 | 21 | |
| 923 | 22 | consts | 
| 11979 | 23 |   "{}"          :: "'a set"                             ("{}")
 | 
| 24 | UNIV :: "'a set" | |
| 25 | insert :: "'a => 'a set => 'a set" | |
| 26 |   Collect       :: "('a => bool) => 'a set"              -- "comprehension"
 | |
| 27 | Int :: "'a set => 'a set => 'a set" (infixl 70) | |
| 28 | Un :: "'a set => 'a set => 'a set" (infixl 65) | |
| 29 |   UNION         :: "'a set => ('a => 'b set) => 'b set"  -- "general union"
 | |
| 30 |   INTER         :: "'a set => ('a => 'b set) => 'b set"  -- "general intersection"
 | |
| 31 | Union :: "'a set set => 'a set" -- "union of a set" | |
| 32 | Inter :: "'a set set => 'a set" -- "intersection of a set" | |
| 33 | Pow :: "'a set => 'a set set" -- "powerset" | |
| 34 |   Ball          :: "'a set => ('a => bool) => bool"      -- "bounded universal quantifiers"
 | |
| 35 |   Bex           :: "'a set => ('a => bool) => bool"      -- "bounded existential quantifiers"
 | |
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 36 |   Bex1          :: "'a set => ('a => bool) => bool"      -- "bounded unique existential quantifiers"
 | 
| 11979 | 37 |   image         :: "('a => 'b) => 'a set => 'b set"      (infixr "`" 90)
 | 
| 19656 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 38 | "op :" :: "'a => 'a set => bool" -- "membership" | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 39 | |
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 40 | const_syntax | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 41 |   "op :"  ("op :")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 42 |   "op :"  ("(_/ : _)" [50, 51] 50)
 | 
| 11979 | 43 | |
| 44 | local | |
| 45 | ||
| 14692 | 46 | instance set :: (type) "{ord, minus}" ..
 | 
| 923 | 47 | |
| 48 | ||
| 11979 | 49 | subsection {* Additional concrete syntax *}
 | 
| 2261 | 50 | |
| 19363 | 51 | abbreviation | 
| 19323 | 52 |   range :: "('a => 'b) => 'b set"             -- "of function"
 | 
| 19363 | 53 | "range f == f ` UNIV" | 
| 19323 | 54 | |
| 19656 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 55 | abbreviation | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 56 | "not_mem x A == ~ (x : A)" -- "non-membership" | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 57 | |
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 58 | const_syntax | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 59 |   not_mem  ("op ~:")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 60 |   not_mem  ("(_/ ~: _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 61 | |
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 62 | const_syntax (xsymbols) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 63 | "op Int" (infixl "\<inter>" 70) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 64 | "op Un" (infixl "\<union>" 65) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 65 |   "op :"  ("op \<in>")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 66 |   "op :"  ("(_/ \<in> _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 67 |   not_mem  ("op \<notin>")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 68 |   not_mem  ("(_/ \<notin> _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 69 |   Union  ("\<Union>_" [90] 90)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 70 |   Inter  ("\<Inter>_" [90] 90)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 71 | |
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 72 | const_syntax (HTML output) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 73 | "op Int" (infixl "\<inter>" 70) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 74 | "op Un" (infixl "\<union>" 65) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 75 |   "op :"  ("op \<in>")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 76 |   "op :"  ("(_/ \<in> _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 77 |   not_mem  ("op \<notin>")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 78 |   not_mem  ("(_/ \<notin> _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 79 | |
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 80 | abbreviation | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 81 | subset :: "'a set \<Rightarrow> 'a set \<Rightarrow> bool" | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 82 | "subset == less" | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 83 | subset_eq :: "'a set \<Rightarrow> 'a set \<Rightarrow> bool" | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 84 | "subset_eq == less_eq" | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 85 | |
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 86 | const_syntax (output) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 87 |   subset  ("op <")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 88 |   subset  ("(_/ < _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 89 |   subset_eq  ("op <=")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 90 |   subset_eq  ("(_/ <= _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 91 | |
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 92 | const_syntax (xsymbols) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 93 |   subset  ("op \<subset>")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 94 |   subset  ("(_/ \<subset> _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 95 |   subset_eq  ("op \<subseteq>")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 96 |   subset_eq  ("(_/ \<subseteq> _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 97 | |
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 98 | const_syntax (HTML output) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 99 |   subset  ("op \<subset>")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 100 |   subset  ("(_/ \<subset> _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 101 |   subset_eq  ("op \<subseteq>")
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 102 |   subset_eq  ("(_/ \<subseteq> _)" [50, 51] 50)
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 103 | |
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 104 | abbreviation (input) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 105 | supset :: "'a set \<Rightarrow> 'a set \<Rightarrow> bool" (infixl "\<supset>" 50) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 106 | "supset == greater" | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 107 | supset_eq :: "'a set \<Rightarrow> 'a set \<Rightarrow> bool" (infixl "\<supseteq>" 50) | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 108 | "supset_eq == greater_eq" | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 109 | |
| 923 | 110 | syntax | 
| 11979 | 111 |   "@Finset"     :: "args => 'a set"                       ("{(_)}")
 | 
| 112 |   "@Coll"       :: "pttrn => bool => 'a set"              ("(1{_./ _})")
 | |
| 113 |   "@SetCompr"   :: "'a => idts => bool => 'a set"         ("(1{_ |/_./ _})")
 | |
| 15535 | 114 |   "@Collect"    :: "idt => 'a set => bool => 'a set"      ("(1{_ :/ _./ _})")
 | 
| 11979 | 115 |   "@INTER1"     :: "pttrns => 'b set => 'b set"           ("(3INT _./ _)" 10)
 | 
| 116 |   "@UNION1"     :: "pttrns => 'b set => 'b set"           ("(3UN _./ _)" 10)
 | |
| 117 |   "@INTER"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3INT _:_./ _)" 10)
 | |
| 118 |   "@UNION"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3UN _:_./ _)" 10)
 | |
| 119 |   "_Ball"       :: "pttrn => 'a set => bool => bool"      ("(3ALL _:_./ _)" [0, 0, 10] 10)
 | |
| 120 |   "_Bex"        :: "pttrn => 'a set => bool => bool"      ("(3EX _:_./ _)" [0, 0, 10] 10)
 | |
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 121 |   "_Bex1"       :: "pttrn => 'a set => bool => bool"      ("(3EX! _:_./ _)" [0, 0, 10] 10)
 | 
| 18674 | 122 |   "_Bleast"       :: "id => 'a set => bool => 'a"      ("(3LEAST _:_./ _)" [0, 0, 10] 10)
 | 
| 123 | ||
| 7238 
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
 wenzelm parents: 
5931diff
changeset | 124 | syntax (HOL) | 
| 11979 | 125 |   "_Ball"       :: "pttrn => 'a set => bool => bool"      ("(3! _:_./ _)" [0, 0, 10] 10)
 | 
| 126 |   "_Bex"        :: "pttrn => 'a set => bool => bool"      ("(3? _:_./ _)" [0, 0, 10] 10)
 | |
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 127 |   "_Bex1"       :: "pttrn => 'a set => bool => bool"      ("(3?! _:_./ _)" [0, 0, 10] 10)
 | 
| 923 | 128 | |
| 129 | translations | |
| 130 |   "{x, xs}"     == "insert x {xs}"
 | |
| 131 |   "{x}"         == "insert x {}"
 | |
| 13764 | 132 |   "{x. P}"      == "Collect (%x. P)"
 | 
| 15535 | 133 |   "{x:A. P}"    => "{x. x:A & P}"
 | 
| 4159 
4aff9b7e5597
UNIV now a constant; UNION1, INTER1 now translations and no longer have
 paulson parents: 
4151diff
changeset | 134 | "UN x y. B" == "UN x. UN y. B" | 
| 
4aff9b7e5597
UNIV now a constant; UNION1, INTER1 now translations and no longer have
 paulson parents: 
4151diff
changeset | 135 | "UN x. B" == "UNION UNIV (%x. B)" | 
| 13858 | 136 | "UN x. B" == "UN x:UNIV. B" | 
| 7238 
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
 wenzelm parents: 
5931diff
changeset | 137 | "INT x y. B" == "INT x. INT y. B" | 
| 4159 
4aff9b7e5597
UNIV now a constant; UNION1, INTER1 now translations and no longer have
 paulson parents: 
4151diff
changeset | 138 | "INT x. B" == "INTER UNIV (%x. B)" | 
| 13858 | 139 | "INT x. B" == "INT x:UNIV. B" | 
| 13764 | 140 | "UN x:A. B" == "UNION A (%x. B)" | 
| 141 | "INT x:A. B" == "INTER A (%x. B)" | |
| 142 | "ALL x:A. P" == "Ball A (%x. P)" | |
| 143 | "EX x:A. P" == "Bex A (%x. P)" | |
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 144 | "EX! x:A. P" == "Bex1 A (%x. P)" | 
| 18674 | 145 | "LEAST x:A. P" => "LEAST x. x:A & P" | 
| 146 | ||
| 12114 
a8e860c86252
eliminated old "symbols" syntax, use "xsymbols" instead;
 wenzelm parents: 
12023diff
changeset | 147 | syntax (xsymbols) | 
| 14381 
1189a8212a12
Modified UN and INT xsymbol syntax: made index subscript
 nipkow parents: 
14335diff
changeset | 148 |   "_Ball"       :: "pttrn => 'a set => bool => bool"      ("(3\<forall>_\<in>_./ _)" [0, 0, 10] 10)
 | 
| 
1189a8212a12
Modified UN and INT xsymbol syntax: made index subscript
 nipkow parents: 
14335diff
changeset | 149 |   "_Bex"        :: "pttrn => 'a set => bool => bool"      ("(3\<exists>_\<in>_./ _)" [0, 0, 10] 10)
 | 
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 150 |   "_Bex1"       :: "pttrn => 'a set => bool => bool"      ("(3\<exists>!_\<in>_./ _)" [0, 0, 10] 10)
 | 
| 18674 | 151 |   "_Bleast"     :: "id => 'a set => bool => 'a"           ("(3LEAST_\<in>_./ _)" [0, 0, 10] 10)
 | 
| 14381 
1189a8212a12
Modified UN and INT xsymbol syntax: made index subscript
 nipkow parents: 
14335diff
changeset | 152 | |
| 14565 | 153 | syntax (HTML output) | 
| 154 |   "_Ball"       :: "pttrn => 'a set => bool => bool"      ("(3\<forall>_\<in>_./ _)" [0, 0, 10] 10)
 | |
| 155 |   "_Bex"        :: "pttrn => 'a set => bool => bool"      ("(3\<exists>_\<in>_./ _)" [0, 0, 10] 10)
 | |
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 156 |   "_Bex1"       :: "pttrn => 'a set => bool => bool"      ("(3\<exists>!_\<in>_./ _)" [0, 0, 10] 10)
 | 
| 14565 | 157 | |
| 15120 | 158 | syntax (xsymbols) | 
| 15535 | 159 |   "@Collect"    :: "idt => 'a set => bool => 'a set"      ("(1{_ \<in>/ _./ _})")
 | 
| 11979 | 160 |   "@UNION1"     :: "pttrns => 'b set => 'b set"           ("(3\<Union>_./ _)" 10)
 | 
| 161 |   "@INTER1"     :: "pttrns => 'b set => 'b set"           ("(3\<Inter>_./ _)" 10)
 | |
| 162 |   "@UNION"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Union>_\<in>_./ _)" 10)
 | |
| 163 |   "@INTER"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Inter>_\<in>_./ _)" 10)
 | |
| 19656 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 164 | |
| 15120 | 165 | syntax (latex output) | 
| 166 |   "@UNION1"     :: "pttrns => 'b set => 'b set"           ("(3\<Union>(00\<^bsub>_\<^esub>)/ _)" 10)
 | |
| 167 |   "@INTER1"     :: "pttrns => 'b set => 'b set"           ("(3\<Inter>(00\<^bsub>_\<^esub>)/ _)" 10)
 | |
| 168 |   "@UNION"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Union>(00\<^bsub>_\<in>_\<^esub>)/ _)" 10)
 | |
| 169 |   "@INTER"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Inter>(00\<^bsub>_\<in>_\<^esub>)/ _)" 10)
 | |
| 170 | ||
| 19656 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 171 | text{*
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 172 | Note the difference between ordinary xsymbol syntax of indexed | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 173 |   unions and intersections (e.g.\ @{text"\<Union>a\<^isub>1\<in>A\<^isub>1. B"})
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 174 |   and their \LaTeX\ rendition: @{term"\<Union>a\<^isub>1\<in>A\<^isub>1. B"}. The
 | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 175 | former does not make the index expression a subscript of the | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 176 | union/intersection symbol because this leads to problems with nested | 
| 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 177 | subscripts in Proof General. *} | 
| 2261 | 178 | |
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 179 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 180 | subsubsection "Bounded quantifiers" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 181 | |
| 19656 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 182 | syntax (output) | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 183 |   "_setlessAll" :: "[idt, 'a, bool] => bool"  ("(3ALL _<_./ _)"  [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 184 |   "_setlessEx"  :: "[idt, 'a, bool] => bool"  ("(3EX _<_./ _)"  [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 185 |   "_setleAll"   :: "[idt, 'a, bool] => bool"  ("(3ALL _<=_./ _)" [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 186 |   "_setleEx"    :: "[idt, 'a, bool] => bool"  ("(3EX _<=_./ _)" [0, 0, 10] 10)
 | 
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 187 |   "_setleEx1"   :: "[idt, 'a, bool] => bool"  ("(3EX! _<=_./ _)" [0, 0, 10] 10)
 | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 188 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 189 | syntax (xsymbols) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 190 |   "_setlessAll" :: "[idt, 'a, bool] => bool"   ("(3\<forall>_\<subset>_./ _)"  [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 191 |   "_setlessEx"  :: "[idt, 'a, bool] => bool"   ("(3\<exists>_\<subset>_./ _)"  [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 192 |   "_setleAll"   :: "[idt, 'a, bool] => bool"   ("(3\<forall>_\<subseteq>_./ _)" [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 193 |   "_setleEx"    :: "[idt, 'a, bool] => bool"   ("(3\<exists>_\<subseteq>_./ _)" [0, 0, 10] 10)
 | 
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 194 |   "_setleEx1"   :: "[idt, 'a, bool] => bool"   ("(3\<exists>!_\<subseteq>_./ _)" [0, 0, 10] 10)
 | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 195 | |
| 19656 
09be06943252
tuned concrete syntax -- abbreviation/const_syntax;
 wenzelm parents: 
19637diff
changeset | 196 | syntax (HOL output) | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 197 |   "_setlessAll" :: "[idt, 'a, bool] => bool"   ("(3! _<_./ _)"  [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 198 |   "_setlessEx"  :: "[idt, 'a, bool] => bool"   ("(3? _<_./ _)"  [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 199 |   "_setleAll"   :: "[idt, 'a, bool] => bool"   ("(3! _<=_./ _)" [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 200 |   "_setleEx"    :: "[idt, 'a, bool] => bool"   ("(3? _<=_./ _)" [0, 0, 10] 10)
 | 
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 201 |   "_setleEx1"   :: "[idt, 'a, bool] => bool"   ("(3?! _<=_./ _)" [0, 0, 10] 10)
 | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 202 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 203 | syntax (HTML output) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 204 |   "_setlessAll" :: "[idt, 'a, bool] => bool"   ("(3\<forall>_\<subset>_./ _)"  [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 205 |   "_setlessEx"  :: "[idt, 'a, bool] => bool"   ("(3\<exists>_\<subset>_./ _)"  [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 206 |   "_setleAll"   :: "[idt, 'a, bool] => bool"   ("(3\<forall>_\<subseteq>_./ _)" [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 207 |   "_setleEx"    :: "[idt, 'a, bool] => bool"   ("(3\<exists>_\<subseteq>_./ _)" [0, 0, 10] 10)
 | 
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 208 |   "_setleEx1"   :: "[idt, 'a, bool] => bool"   ("(3\<exists>!_\<subseteq>_./ _)" [0, 0, 10] 10)
 | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 209 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 210 | translations | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 211 | "\<forall>A\<subset>B. P" => "ALL A. A \<subset> B --> P" | 
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 212 | "\<exists>A\<subset>B. P" => "EX A. A \<subset> B & P" | 
| 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 213 | "\<forall>A\<subseteq>B. P" => "ALL A. A \<subseteq> B --> P" | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 214 | "\<exists>A\<subseteq>B. P" => "EX A. A \<subseteq> B & P" | 
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 215 | "\<exists>!A\<subseteq>B. P" => "EX! A. A \<subseteq> B & P" | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 216 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 217 | print_translation {*
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 218 | let | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 219 | fun | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 220 |     all_tr' [Const ("_bound",_) $ Free (v,Type(T,_)), 
 | 
| 19637 | 221 |              Const("op -->",_) $ (Const ("less",_) $ (Const ("_bound",_) $ Free (v',_)) $ n ) $ P] = 
 | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 222 | (if v=v' andalso T="set" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 223 | then Syntax.const "_setlessAll" $ Syntax.mark_bound v' $ n $ P | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 224 | else raise Match) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 225 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 226 |   | all_tr' [Const ("_bound",_) $ Free (v,Type(T,_)), 
 | 
| 19637 | 227 |              Const("op -->",_) $ (Const ("less_eq",_) $ (Const ("_bound",_) $ Free (v',_)) $ n ) $ P] = 
 | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 228 | (if v=v' andalso T="set" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 229 | then Syntax.const "_setleAll" $ Syntax.mark_bound v' $ n $ P | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 230 | else raise Match); | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 231 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 232 | fun | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 233 |     ex_tr' [Const ("_bound",_) $ Free (v,Type(T,_)), 
 | 
| 19637 | 234 |             Const("op &",_) $ (Const ("less",_) $ (Const ("_bound",_) $ Free (v',_)) $ n ) $ P] = 
 | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 235 | (if v=v' andalso T="set" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 236 | then Syntax.const "_setlessEx" $ Syntax.mark_bound v' $ n $ P | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 237 | else raise Match) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 238 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 239 |   | ex_tr' [Const ("_bound",_) $ Free (v,Type(T,_)), 
 | 
| 19637 | 240 |             Const("op &",_) $ (Const ("less_eq",_) $ (Const ("_bound",_) $ Free (v',_)) $ n ) $ P] = 
 | 
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 241 | (if v=v' andalso T="set" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 242 | then Syntax.const "_setleEx" $ Syntax.mark_bound v' $ n $ P | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 243 | else raise Match) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 244 | in | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 245 | [("ALL ", all_tr'), ("EX ", ex_tr')]
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 246 | end | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 247 | *} | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 248 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 249 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 250 | |
| 11979 | 251 | text {*
 | 
| 252 |   \medskip Translate between @{text "{e | x1...xn. P}"} and @{text
 | |
| 253 |   "{u. EX x1..xn. u = e & P}"}; @{text "{y. EX x1..xn. y = e & P}"} is
 | |
| 254 |   only translated if @{text "[0..n] subset bvs(e)"}.
 | |
| 255 | *} | |
| 256 | ||
| 257 | parse_translation {*
 | |
| 258 | let | |
| 259 |     val ex_tr = snd (mk_binder_tr ("EX ", "Ex"));
 | |
| 3947 | 260 | |
| 11979 | 261 |     fun nvars (Const ("_idts", _) $ _ $ idts) = nvars idts + 1
 | 
| 262 | | nvars _ = 1; | |
| 263 | ||
| 264 | fun setcompr_tr [e, idts, b] = | |
| 265 | let | |
| 266 | val eq = Syntax.const "op =" $ Bound (nvars idts) $ e; | |
| 267 | val P = Syntax.const "op &" $ eq $ b; | |
| 268 | val exP = ex_tr [idts, P]; | |
| 17784 | 269 | in Syntax.const "Collect" $ Term.absdummy (dummyT, exP) end; | 
| 11979 | 270 | |
| 271 |   in [("@SetCompr", setcompr_tr)] end;
 | |
| 272 | *} | |
| 923 | 273 | |
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 274 | (* To avoid eta-contraction of body: *) | 
| 11979 | 275 | print_translation {*
 | 
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 276 | let | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 277 | fun btr' syn [A,Abs abs] = | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 278 | let val (x,t) = atomic_abs_tr' abs | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 279 | in Syntax.const syn $ x $ A $ t end | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 280 | in | 
| 13858 | 281 | [("Ball", btr' "_Ball"),("Bex", btr' "_Bex"),
 | 
| 282 |  ("UNION", btr' "@UNION"),("INTER", btr' "@INTER")]
 | |
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 283 | end | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 284 | *} | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 285 | |
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 286 | print_translation {*
 | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 287 | let | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 288 |   val ex_tr' = snd (mk_binder_tr' ("Ex", "DUMMY"));
 | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 289 | |
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 290 | fun setcompr_tr' [Abs (abs as (_, _, P))] = | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 291 | let | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 292 |       fun check (Const ("Ex", _) $ Abs (_, _, P), n) = check (P, n + 1)
 | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 293 |         | check (Const ("op &", _) $ (Const ("op =", _) $ Bound m $ e) $ P, n) =
 | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 294 | n > 0 andalso m = n andalso not (loose_bvar1 (P, n)) andalso | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 295 | ((0 upto (n - 1)) subset add_loose_bnos (e, 0, [])) | 
| 13764 | 296 | | check _ = false | 
| 923 | 297 | |
| 11979 | 298 | fun tr' (_ $ abs) = | 
| 299 | let val _ $ idts $ (_ $ (_ $ _ $ e) $ Q) = ex_tr' [abs] | |
| 300 | in Syntax.const "@SetCompr" $ e $ idts $ Q end; | |
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 301 | in if check (P, 0) then tr' P | 
| 15535 | 302 | else let val (x as _ $ Free(xN,_), t) = atomic_abs_tr' abs | 
| 303 | val M = Syntax.const "@Coll" $ x $ t | |
| 304 | in case t of | |
| 305 |                  Const("op &",_)
 | |
| 306 |                    $ (Const("op :",_) $ (Const("_bound",_) $ Free(yN,_)) $ A)
 | |
| 307 | $ P => | |
| 308 | if xN=yN then Syntax.const "@Collect" $ x $ A $ P else M | |
| 309 | | _ => M | |
| 310 | end | |
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 311 | end; | 
| 11979 | 312 |   in [("Collect", setcompr_tr')] end;
 | 
| 313 | *} | |
| 314 | ||
| 315 | ||
| 316 | subsection {* Rules and definitions *}
 | |
| 317 | ||
| 318 | text {* Isomorphisms between predicates and sets. *}
 | |
| 923 | 319 | |
| 11979 | 320 | axioms | 
| 17085 | 321 |   mem_Collect_eq: "(a : {x. P(x)}) = P(a)"
 | 
| 322 |   Collect_mem_eq: "{x. x:A} = A"
 | |
| 17702 | 323 | finalconsts | 
| 324 | Collect | |
| 325 | "op :" | |
| 11979 | 326 | |
| 327 | defs | |
| 328 | Ball_def: "Ball A P == ALL x. x:A --> P(x)" | |
| 329 | Bex_def: "Bex A P == EX x. x:A & P(x)" | |
| 20217 
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
 webertj parents: 
19870diff
changeset | 330 | Bex1_def: "Bex1 A P == EX! x. x:A & P(x)" | 
| 11979 | 331 | |
| 332 | defs (overloaded) | |
| 333 | subset_def: "A <= B == ALL x:A. x:B" | |
| 334 | psubset_def: "A < B == (A::'a set) <= B & ~ A=B" | |
| 335 |   Compl_def:    "- A            == {x. ~x:A}"
 | |
| 12257 | 336 |   set_diff_def: "A - B          == {x. x:A & ~x:B}"
 | 
| 923 | 337 | |
| 338 | defs | |
| 11979 | 339 |   Un_def:       "A Un B         == {x. x:A | x:B}"
 | 
| 340 |   Int_def:      "A Int B        == {x. x:A & x:B}"
 | |
| 341 |   INTER_def:    "INTER A B      == {y. ALL x:A. y: B(x)}"
 | |
| 342 |   UNION_def:    "UNION A B      == {y. EX x:A. y: B(x)}"
 | |
| 343 | Inter_def: "Inter S == (INT x:S. x)" | |
| 344 | Union_def: "Union S == (UN x:S. x)" | |
| 345 |   Pow_def:      "Pow A          == {B. B <= A}"
 | |
| 346 |   empty_def:    "{}             == {x. False}"
 | |
| 347 |   UNIV_def:     "UNIV           == {x. True}"
 | |
| 348 |   insert_def:   "insert a B     == {x. x=a} Un B"
 | |
| 349 |   image_def:    "f`A            == {y. EX x:A. y = f(x)}"
 | |
| 350 | ||
| 351 | ||
| 352 | subsection {* Lemmas and proof tool setup *}
 | |
| 353 | ||
| 354 | subsubsection {* Relating predicates and sets *}
 | |
| 355 | ||
| 17085 | 356 | declare mem_Collect_eq [iff] Collect_mem_eq [simp] | 
| 357 | ||
| 12257 | 358 | lemma CollectI: "P(a) ==> a : {x. P(x)}"
 | 
| 11979 | 359 | by simp | 
| 360 | ||
| 361 | lemma CollectD: "a : {x. P(x)} ==> P(a)"
 | |
| 362 | by simp | |
| 363 | ||
| 364 | lemma Collect_cong: "(!!x. P x = Q x) ==> {x. P(x)} = {x. Q(x)}"
 | |
| 365 | by simp | |
| 366 | ||
| 12257 | 367 | lemmas CollectE = CollectD [elim_format] | 
| 11979 | 368 | |
| 369 | ||
| 370 | subsubsection {* Bounded quantifiers *}
 | |
| 371 | ||
| 372 | lemma ballI [intro!]: "(!!x. x:A ==> P x) ==> ALL x:A. P x" | |
| 373 | by (simp add: Ball_def) | |
| 374 | ||
| 375 | lemmas strip = impI allI ballI | |
| 376 | ||
| 377 | lemma bspec [dest?]: "ALL x:A. P x ==> x:A ==> P x" | |
| 378 | by (simp add: Ball_def) | |
| 379 | ||
| 380 | lemma ballE [elim]: "ALL x:A. P x ==> (P x ==> Q) ==> (x ~: A ==> Q) ==> Q" | |
| 381 | by (unfold Ball_def) blast | |
| 14098 | 382 | ML {* bind_thm("rev_ballE",permute_prems 1 1 (thm "ballE")) *}
 | 
| 11979 | 383 | |
| 384 | text {*
 | |
| 385 |   \medskip This tactic takes assumptions @{prop "ALL x:A. P x"} and
 | |
| 386 |   @{prop "a:A"}; creates assumption @{prop "P a"}.
 | |
| 387 | *} | |
| 388 | ||
| 389 | ML {*
 | |
| 390 | local val ballE = thm "ballE" | |
| 391 | in fun ball_tac i = etac ballE i THEN contr_tac (i + 1) end; | |
| 392 | *} | |
| 393 | ||
| 394 | text {*
 | |
| 395 | Gives better instantiation for bound: | |
| 396 | *} | |
| 397 | ||
| 398 | ML_setup {*
 | |
| 17875 | 399 |   change_claset (fn cs => cs addbefore ("bspec", datac (thm "bspec") 1));
 | 
| 11979 | 400 | *} | 
| 401 | ||
| 402 | lemma bexI [intro]: "P x ==> x:A ==> EX x:A. P x" | |
| 403 |   -- {* Normally the best argument order: @{prop "P x"} constrains the
 | |
| 404 |     choice of @{prop "x:A"}. *}
 | |
| 405 | by (unfold Bex_def) blast | |
| 406 | ||
| 13113 | 407 | lemma rev_bexI [intro?]: "x:A ==> P x ==> EX x:A. P x" | 
| 11979 | 408 |   -- {* The best argument order when there is only one @{prop "x:A"}. *}
 | 
| 409 | by (unfold Bex_def) blast | |
| 410 | ||
| 411 | lemma bexCI: "(ALL x:A. ~P x ==> P a) ==> a:A ==> EX x:A. P x" | |
| 412 | by (unfold Bex_def) blast | |
| 413 | ||
| 414 | lemma bexE [elim!]: "EX x:A. P x ==> (!!x. x:A ==> P x ==> Q) ==> Q" | |
| 415 | by (unfold Bex_def) blast | |
| 416 | ||
| 417 | lemma ball_triv [simp]: "(ALL x:A. P) = ((EX x. x:A) --> P)" | |
| 418 |   -- {* Trival rewrite rule. *}
 | |
| 419 | by (simp add: Ball_def) | |
| 420 | ||
| 421 | lemma bex_triv [simp]: "(EX x:A. P) = ((EX x. x:A) & P)" | |
| 422 |   -- {* Dual form for existentials. *}
 | |
| 423 | by (simp add: Bex_def) | |
| 424 | ||
| 425 | lemma bex_triv_one_point1 [simp]: "(EX x:A. x = a) = (a:A)" | |
| 426 | by blast | |
| 427 | ||
| 428 | lemma bex_triv_one_point2 [simp]: "(EX x:A. a = x) = (a:A)" | |
| 429 | by blast | |
| 430 | ||
| 431 | lemma bex_one_point1 [simp]: "(EX x:A. x = a & P x) = (a:A & P a)" | |
| 432 | by blast | |
| 433 | ||
| 434 | lemma bex_one_point2 [simp]: "(EX x:A. a = x & P x) = (a:A & P a)" | |
| 435 | by blast | |
| 436 | ||
| 437 | lemma ball_one_point1 [simp]: "(ALL x:A. x = a --> P x) = (a:A --> P a)" | |
| 438 | by blast | |
| 439 | ||
| 440 | lemma ball_one_point2 [simp]: "(ALL x:A. a = x --> P x) = (a:A --> P a)" | |
| 441 | by blast | |
| 442 | ||
| 443 | ML_setup {*
 | |
| 13462 | 444 | local | 
| 18328 | 445 | val unfold_bex_tac = unfold_tac [thm "Bex_def"]; | 
| 446 | fun prove_bex_tac ss = unfold_bex_tac ss THEN Quantifier1.prove_one_point_ex_tac; | |
| 11979 | 447 | val rearrange_bex = Quantifier1.rearrange_bex prove_bex_tac; | 
| 448 | ||
| 18328 | 449 | val unfold_ball_tac = unfold_tac [thm "Ball_def"]; | 
| 450 | fun prove_ball_tac ss = unfold_ball_tac ss THEN Quantifier1.prove_one_point_all_tac; | |
| 11979 | 451 | val rearrange_ball = Quantifier1.rearrange_ball prove_ball_tac; | 
| 452 | in | |
| 18328 | 453 | val defBEX_regroup = Simplifier.simproc (the_context ()) | 
| 13462 | 454 | "defined BEX" ["EX x:A. P x & Q x"] rearrange_bex; | 
| 18328 | 455 | val defBALL_regroup = Simplifier.simproc (the_context ()) | 
| 13462 | 456 | "defined BALL" ["ALL x:A. P x --> Q x"] rearrange_ball; | 
| 11979 | 457 | end; | 
| 13462 | 458 | |
| 459 | Addsimprocs [defBALL_regroup, defBEX_regroup]; | |
| 11979 | 460 | *} | 
| 461 | ||
| 462 | ||
| 463 | subsubsection {* Congruence rules *}
 | |
| 464 | ||
| 16636 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 465 | lemma ball_cong: | 
| 11979 | 466 | "A = B ==> (!!x. x:B ==> P x = Q x) ==> | 
| 467 | (ALL x:A. P x) = (ALL x:B. Q x)" | |
| 468 | by (simp add: Ball_def) | |
| 469 | ||
| 16636 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 470 | lemma strong_ball_cong [cong]: | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 471 | "A = B ==> (!!x. x:B =simp=> P x = Q x) ==> | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 472 | (ALL x:A. P x) = (ALL x:B. Q x)" | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 473 | by (simp add: simp_implies_def Ball_def) | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 474 | |
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 475 | lemma bex_cong: | 
| 11979 | 476 | "A = B ==> (!!x. x:B ==> P x = Q x) ==> | 
| 477 | (EX x:A. P x) = (EX x:B. Q x)" | |
| 478 | by (simp add: Bex_def cong: conj_cong) | |
| 1273 | 479 | |
| 16636 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 480 | lemma strong_bex_cong [cong]: | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 481 | "A = B ==> (!!x. x:B =simp=> P x = Q x) ==> | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 482 | (EX x:A. P x) = (EX x:B. Q x)" | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 483 | by (simp add: simp_implies_def Bex_def cong: conj_cong) | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 484 | |
| 7238 
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
 wenzelm parents: 
5931diff
changeset | 485 | |
| 11979 | 486 | subsubsection {* Subsets *}
 | 
| 487 | ||
| 19295 | 488 | lemma subsetI [atp,intro!]: "(!!x. x:A ==> x:B) ==> A \<subseteq> B" | 
| 11979 | 489 | by (simp add: subset_def) | 
| 490 | ||
| 491 | text {*
 | |
| 492 |   \medskip Map the type @{text "'a set => anything"} to just @{typ
 | |
| 493 |   'a}; for overloading constants whose first argument has type @{typ
 | |
| 494 | "'a set"}. | |
| 495 | *} | |
| 496 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 497 | lemma subsetD [elim]: "A \<subseteq> B ==> c \<in> A ==> c \<in> B" | 
| 11979 | 498 |   -- {* Rule in Modus Ponens style. *}
 | 
| 499 | by (unfold subset_def) blast | |
| 500 | ||
| 501 | declare subsetD [intro?] -- FIXME | |
| 502 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 503 | lemma rev_subsetD: "c \<in> A ==> A \<subseteq> B ==> c \<in> B" | 
| 11979 | 504 |   -- {* The same, with reversed premises for use with @{text erule} --
 | 
| 505 |       cf @{text rev_mp}. *}
 | |
| 506 | by (rule subsetD) | |
| 507 | ||
| 508 | declare rev_subsetD [intro?] -- FIXME | |
| 509 | ||
| 510 | text {*
 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 511 |   \medskip Converts @{prop "A \<subseteq> B"} to @{prop "x \<in> A ==> x \<in> B"}.
 | 
| 11979 | 512 | *} | 
| 513 | ||
| 514 | ML {*
 | |
| 515 | local val rev_subsetD = thm "rev_subsetD" | |
| 516 | in fun impOfSubs th = th RSN (2, rev_subsetD) end; | |
| 517 | *} | |
| 518 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 519 | lemma subsetCE [elim]: "A \<subseteq> B ==> (c \<notin> A ==> P) ==> (c \<in> B ==> P) ==> P" | 
| 11979 | 520 |   -- {* Classical elimination rule. *}
 | 
| 521 | by (unfold subset_def) blast | |
| 522 | ||
| 523 | text {*
 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 524 |   \medskip Takes assumptions @{prop "A \<subseteq> B"}; @{prop "c \<in> A"} and
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 525 |   creates the assumption @{prop "c \<in> B"}.
 | 
| 11979 | 526 | *} | 
| 527 | ||
| 528 | ML {*
 | |
| 529 | local val subsetCE = thm "subsetCE" | |
| 530 | in fun set_mp_tac i = etac subsetCE i THEN mp_tac i end; | |
| 531 | *} | |
| 532 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 533 | lemma contra_subsetD: "A \<subseteq> B ==> c \<notin> B ==> c \<notin> A" | 
| 11979 | 534 | by blast | 
| 535 | ||
| 19175 | 536 | lemma subset_refl [simp,atp]: "A \<subseteq> A" | 
| 11979 | 537 | by fast | 
| 538 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 539 | lemma subset_trans: "A \<subseteq> B ==> B \<subseteq> C ==> A \<subseteq> C" | 
| 11979 | 540 | by blast | 
| 923 | 541 | |
| 2261 | 542 | |
| 11979 | 543 | subsubsection {* Equality *}
 | 
| 544 | ||
| 13865 | 545 | lemma set_ext: assumes prem: "(!!x. (x:A) = (x:B))" shows "A = B" | 
| 546 | apply (rule prem [THEN ext, THEN arg_cong, THEN box_equals]) | |
| 547 | apply (rule Collect_mem_eq) | |
| 548 | apply (rule Collect_mem_eq) | |
| 549 | done | |
| 550 | ||
| 15554 | 551 | (* Due to Brian Huffman *) | 
| 552 | lemma expand_set_eq: "(A = B) = (ALL x. (x:A) = (x:B))" | |
| 553 | by(auto intro:set_ext) | |
| 554 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 555 | lemma subset_antisym [intro!]: "A \<subseteq> B ==> B \<subseteq> A ==> A = B" | 
| 11979 | 556 |   -- {* Anti-symmetry of the subset relation. *}
 | 
| 17589 | 557 | by (iprover intro: set_ext subsetD) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 558 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 559 | lemmas equalityI [intro!] = subset_antisym | 
| 11979 | 560 | |
| 561 | text {*
 | |
| 562 | \medskip Equality rules from ZF set theory -- are they appropriate | |
| 563 | here? | |
| 564 | *} | |
| 565 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 566 | lemma equalityD1: "A = B ==> A \<subseteq> B" | 
| 11979 | 567 | by (simp add: subset_refl) | 
| 568 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 569 | lemma equalityD2: "A = B ==> B \<subseteq> A" | 
| 11979 | 570 | by (simp add: subset_refl) | 
| 571 | ||
| 572 | text {*
 | |
| 573 |   \medskip Be careful when adding this to the claset as @{text
 | |
| 574 |   subset_empty} is in the simpset: @{prop "A = {}"} goes to @{prop "{}
 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 575 |   \<subseteq> A"} and @{prop "A \<subseteq> {}"} and then back to @{prop "A = {}"}!
 | 
| 11979 | 576 | *} | 
| 577 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 578 | lemma equalityE: "A = B ==> (A \<subseteq> B ==> B \<subseteq> A ==> P) ==> P" | 
| 11979 | 579 | by (simp add: subset_refl) | 
| 923 | 580 | |
| 11979 | 581 | lemma equalityCE [elim]: | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 582 | "A = B ==> (c \<in> A ==> c \<in> B ==> P) ==> (c \<notin> A ==> c \<notin> B ==> P) ==> P" | 
| 11979 | 583 | by blast | 
| 584 | ||
| 585 | lemma eqset_imp_iff: "A = B ==> (x : A) = (x : B)" | |
| 586 | by simp | |
| 587 | ||
| 13865 | 588 | lemma eqelem_imp_iff: "x = y ==> (x : A) = (y : A)" | 
| 589 | by simp | |
| 590 | ||
| 11979 | 591 | |
| 592 | subsubsection {* The universal set -- UNIV *}
 | |
| 593 | ||
| 594 | lemma UNIV_I [simp]: "x : UNIV" | |
| 595 | by (simp add: UNIV_def) | |
| 596 | ||
| 597 | declare UNIV_I [intro]  -- {* unsafe makes it less likely to cause problems *}
 | |
| 598 | ||
| 599 | lemma UNIV_witness [intro?]: "EX x. x : UNIV" | |
| 600 | by simp | |
| 601 | ||
| 18144 
4edcb5fdc3b0
duplicate axioms in ATP linkup, and general fixes
 paulson parents: 
17875diff
changeset | 602 | lemma subset_UNIV [simp]: "A \<subseteq> UNIV" | 
| 11979 | 603 | by (rule subsetI) (rule UNIV_I) | 
| 2388 | 604 | |
| 11979 | 605 | text {*
 | 
| 606 |   \medskip Eta-contracting these two rules (to remove @{text P})
 | |
| 607 | causes them to be ignored because of their interaction with | |
| 608 | congruence rules. | |
| 609 | *} | |
| 610 | ||
| 611 | lemma ball_UNIV [simp]: "Ball UNIV P = All P" | |
| 612 | by (simp add: Ball_def) | |
| 613 | ||
| 614 | lemma bex_UNIV [simp]: "Bex UNIV P = Ex P" | |
| 615 | by (simp add: Bex_def) | |
| 616 | ||
| 617 | ||
| 618 | subsubsection {* The empty set *}
 | |
| 619 | ||
| 620 | lemma empty_iff [simp]: "(c : {}) = False"
 | |
| 621 | by (simp add: empty_def) | |
| 622 | ||
| 623 | lemma emptyE [elim!]: "a : {} ==> P"
 | |
| 624 | by simp | |
| 625 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 626 | lemma empty_subsetI [iff]: "{} \<subseteq> A"
 | 
| 11979 | 627 |     -- {* One effect is to delete the ASSUMPTION @{prop "{} <= A"} *}
 | 
| 628 | by blast | |
| 629 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 630 | lemma equals0I: "(!!y. y \<in> A ==> False) ==> A = {}"
 | 
| 11979 | 631 | by blast | 
| 2388 | 632 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 633 | lemma equals0D: "A = {} ==> a \<notin> A"
 | 
| 11979 | 634 |     -- {* Use for reasoning about disjointness: @{prop "A Int B = {}"} *}
 | 
| 635 | by blast | |
| 636 | ||
| 637 | lemma ball_empty [simp]: "Ball {} P = True"
 | |
| 638 | by (simp add: Ball_def) | |
| 639 | ||
| 640 | lemma bex_empty [simp]: "Bex {} P = False"
 | |
| 641 | by (simp add: Bex_def) | |
| 642 | ||
| 643 | lemma UNIV_not_empty [iff]: "UNIV ~= {}"
 | |
| 644 | by (blast elim: equalityE) | |
| 645 | ||
| 646 | ||
| 12023 | 647 | subsubsection {* The Powerset operator -- Pow *}
 | 
| 11979 | 648 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 649 | lemma Pow_iff [iff]: "(A \<in> Pow B) = (A \<subseteq> B)" | 
| 11979 | 650 | by (simp add: Pow_def) | 
| 651 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 652 | lemma PowI: "A \<subseteq> B ==> A \<in> Pow B" | 
| 11979 | 653 | by (simp add: Pow_def) | 
| 654 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 655 | lemma PowD: "A \<in> Pow B ==> A \<subseteq> B" | 
| 11979 | 656 | by (simp add: Pow_def) | 
| 657 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 658 | lemma Pow_bottom: "{} \<in> Pow B"
 | 
| 11979 | 659 | by simp | 
| 660 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 661 | lemma Pow_top: "A \<in> Pow A" | 
| 11979 | 662 | by (simp add: subset_refl) | 
| 2684 | 663 | |
| 2388 | 664 | |
| 11979 | 665 | subsubsection {* Set complement *}
 | 
| 666 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 667 | lemma Compl_iff [simp]: "(c \<in> -A) = (c \<notin> A)" | 
| 11979 | 668 | by (unfold Compl_def) blast | 
| 669 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 670 | lemma ComplI [intro!]: "(c \<in> A ==> False) ==> c \<in> -A" | 
| 11979 | 671 | by (unfold Compl_def) blast | 
| 672 | ||
| 673 | text {*
 | |
| 674 | \medskip This form, with negated conclusion, works well with the | |
| 675 | Classical prover. Negated assumptions behave like formulae on the | |
| 676 | right side of the notional turnstile ... *} | |
| 677 | ||
| 17084 
fb0a80aef0be
classical rules must have names for ATP integration
 paulson parents: 
17002diff
changeset | 678 | lemma ComplD [dest!]: "c : -A ==> c~:A" | 
| 11979 | 679 | by (unfold Compl_def) blast | 
| 680 | ||
| 17084 
fb0a80aef0be
classical rules must have names for ATP integration
 paulson parents: 
17002diff
changeset | 681 | lemmas ComplE = ComplD [elim_format] | 
| 11979 | 682 | |
| 683 | ||
| 684 | subsubsection {* Binary union -- Un *}
 | |
| 923 | 685 | |
| 11979 | 686 | lemma Un_iff [simp]: "(c : A Un B) = (c:A | c:B)" | 
| 687 | by (unfold Un_def) blast | |
| 688 | ||
| 689 | lemma UnI1 [elim?]: "c:A ==> c : A Un B" | |
| 690 | by simp | |
| 691 | ||
| 692 | lemma UnI2 [elim?]: "c:B ==> c : A Un B" | |
| 693 | by simp | |
| 923 | 694 | |
| 11979 | 695 | text {*
 | 
| 696 |   \medskip Classical introduction rule: no commitment to @{prop A} vs
 | |
| 697 |   @{prop B}.
 | |
| 698 | *} | |
| 699 | ||
| 700 | lemma UnCI [intro!]: "(c~:B ==> c:A) ==> c : A Un B" | |
| 701 | by auto | |
| 702 | ||
| 703 | lemma UnE [elim!]: "c : A Un B ==> (c:A ==> P) ==> (c:B ==> P) ==> P" | |
| 704 | by (unfold Un_def) blast | |
| 705 | ||
| 706 | ||
| 12023 | 707 | subsubsection {* Binary intersection -- Int *}
 | 
| 923 | 708 | |
| 11979 | 709 | lemma Int_iff [simp]: "(c : A Int B) = (c:A & c:B)" | 
| 710 | by (unfold Int_def) blast | |
| 711 | ||
| 712 | lemma IntI [intro!]: "c:A ==> c:B ==> c : A Int B" | |
| 713 | by simp | |
| 714 | ||
| 715 | lemma IntD1: "c : A Int B ==> c:A" | |
| 716 | by simp | |
| 717 | ||
| 718 | lemma IntD2: "c : A Int B ==> c:B" | |
| 719 | by simp | |
| 720 | ||
| 721 | lemma IntE [elim!]: "c : A Int B ==> (c:A ==> c:B ==> P) ==> P" | |
| 722 | by simp | |
| 723 | ||
| 724 | ||
| 12023 | 725 | subsubsection {* Set difference *}
 | 
| 11979 | 726 | |
| 727 | lemma Diff_iff [simp]: "(c : A - B) = (c:A & c~:B)" | |
| 728 | by (unfold set_diff_def) blast | |
| 923 | 729 | |
| 11979 | 730 | lemma DiffI [intro!]: "c : A ==> c ~: B ==> c : A - B" | 
| 731 | by simp | |
| 732 | ||
| 733 | lemma DiffD1: "c : A - B ==> c : A" | |
| 734 | by simp | |
| 735 | ||
| 736 | lemma DiffD2: "c : A - B ==> c : B ==> P" | |
| 737 | by simp | |
| 738 | ||
| 739 | lemma DiffE [elim!]: "c : A - B ==> (c:A ==> c~:B ==> P) ==> P" | |
| 740 | by simp | |
| 741 | ||
| 742 | ||
| 743 | subsubsection {* Augmenting a set -- insert *}
 | |
| 744 | ||
| 745 | lemma insert_iff [simp]: "(a : insert b A) = (a = b | a:A)" | |
| 746 | by (unfold insert_def) blast | |
| 747 | ||
| 748 | lemma insertI1: "a : insert a B" | |
| 749 | by simp | |
| 750 | ||
| 751 | lemma insertI2: "a : B ==> a : insert b B" | |
| 752 | by simp | |
| 923 | 753 | |
| 11979 | 754 | lemma insertE [elim!]: "a : insert b A ==> (a = b ==> P) ==> (a:A ==> P) ==> P" | 
| 755 | by (unfold insert_def) blast | |
| 756 | ||
| 757 | lemma insertCI [intro!]: "(a~:B ==> a = b) ==> a: insert b B" | |
| 758 |   -- {* Classical introduction rule. *}
 | |
| 759 | by auto | |
| 760 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 761 | lemma subset_insert_iff: "(A \<subseteq> insert x B) = (if x:A then A - {x} \<subseteq> B else A \<subseteq> B)"
 | 
| 11979 | 762 | by auto | 
| 763 | ||
| 764 | ||
| 765 | subsubsection {* Singletons, using insert *}
 | |
| 766 | ||
| 767 | lemma singletonI [intro!]: "a : {a}"
 | |
| 768 |     -- {* Redundant? But unlike @{text insertCI}, it proves the subgoal immediately! *}
 | |
| 769 | by (rule insertI1) | |
| 770 | ||
| 17084 
fb0a80aef0be
classical rules must have names for ATP integration
 paulson parents: 
17002diff
changeset | 771 | lemma singletonD [dest!]: "b : {a} ==> b = a"
 | 
| 11979 | 772 | by blast | 
| 773 | ||
| 17084 
fb0a80aef0be
classical rules must have names for ATP integration
 paulson parents: 
17002diff
changeset | 774 | lemmas singletonE = singletonD [elim_format] | 
| 11979 | 775 | |
| 776 | lemma singleton_iff: "(b : {a}) = (b = a)"
 | |
| 777 | by blast | |
| 778 | ||
| 779 | lemma singleton_inject [dest!]: "{a} = {b} ==> a = b"
 | |
| 780 | by blast | |
| 781 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 782 | lemma singleton_insert_inj_eq [iff]: "({b} = insert a A) = (a = b & A \<subseteq> {b})"
 | 
| 11979 | 783 | by blast | 
| 784 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 785 | lemma singleton_insert_inj_eq' [iff]: "(insert a A = {b}) = (a = b & A \<subseteq> {b})"
 | 
| 11979 | 786 | by blast | 
| 787 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 788 | lemma subset_singletonD: "A \<subseteq> {x} ==> A = {} | A = {x}"
 | 
| 11979 | 789 | by fast | 
| 790 | ||
| 791 | lemma singleton_conv [simp]: "{x. x = a} = {a}"
 | |
| 792 | by blast | |
| 793 | ||
| 794 | lemma singleton_conv2 [simp]: "{x. a = x} = {a}"
 | |
| 795 | by blast | |
| 923 | 796 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 797 | lemma diff_single_insert: "A - {x} \<subseteq> B ==> x \<in> A ==> A \<subseteq> insert x B"
 | 
| 11979 | 798 | by blast | 
| 799 | ||
| 19870 | 800 | lemma doubleton_eq_iff: "({a,b} = {c,d}) = (a=c & b=d | a=d & b=c)"
 | 
| 801 | by (blast elim: equalityE) | |
| 802 | ||
| 11979 | 803 | |
| 804 | subsubsection {* Unions of families *}
 | |
| 805 | ||
| 806 | text {*
 | |
| 807 |   @{term [source] "UN x:A. B x"} is @{term "Union (B`A)"}.
 | |
| 808 | *} | |
| 809 | ||
| 810 | lemma UN_iff [simp]: "(b: (UN x:A. B x)) = (EX x:A. b: B x)" | |
| 811 | by (unfold UNION_def) blast | |
| 812 | ||
| 813 | lemma UN_I [intro]: "a:A ==> b: B a ==> b: (UN x:A. B x)" | |
| 814 |   -- {* The order of the premises presupposes that @{term A} is rigid;
 | |
| 815 |     @{term b} may be flexible. *}
 | |
| 816 | by auto | |
| 817 | ||
| 818 | lemma UN_E [elim!]: "b : (UN x:A. B x) ==> (!!x. x:A ==> b: B x ==> R) ==> R" | |
| 819 | by (unfold UNION_def) blast | |
| 923 | 820 | |
| 11979 | 821 | lemma UN_cong [cong]: | 
| 822 | "A = B ==> (!!x. x:B ==> C x = D x) ==> (UN x:A. C x) = (UN x:B. D x)" | |
| 823 | by (simp add: UNION_def) | |
| 824 | ||
| 825 | ||
| 826 | subsubsection {* Intersections of families *}
 | |
| 827 | ||
| 828 | text {* @{term [source] "INT x:A. B x"} is @{term "Inter (B`A)"}. *}
 | |
| 829 | ||
| 830 | lemma INT_iff [simp]: "(b: (INT x:A. B x)) = (ALL x:A. b: B x)" | |
| 831 | by (unfold INTER_def) blast | |
| 923 | 832 | |
| 11979 | 833 | lemma INT_I [intro!]: "(!!x. x:A ==> b: B x) ==> b : (INT x:A. B x)" | 
| 834 | by (unfold INTER_def) blast | |
| 835 | ||
| 836 | lemma INT_D [elim]: "b : (INT x:A. B x) ==> a:A ==> b: B a" | |
| 837 | by auto | |
| 838 | ||
| 839 | lemma INT_E [elim]: "b : (INT x:A. B x) ==> (b: B a ==> R) ==> (a~:A ==> R) ==> R" | |
| 840 |   -- {* "Classical" elimination -- by the Excluded Middle on @{prop "a:A"}. *}
 | |
| 841 | by (unfold INTER_def) blast | |
| 842 | ||
| 843 | lemma INT_cong [cong]: | |
| 844 | "A = B ==> (!!x. x:B ==> C x = D x) ==> (INT x:A. C x) = (INT x:B. D x)" | |
| 845 | by (simp add: INTER_def) | |
| 7238 
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
 wenzelm parents: 
5931diff
changeset | 846 | |
| 923 | 847 | |
| 11979 | 848 | subsubsection {* Union *}
 | 
| 849 | ||
| 850 | lemma Union_iff [simp]: "(A : Union C) = (EX X:C. A:X)" | |
| 851 | by (unfold Union_def) blast | |
| 852 | ||
| 853 | lemma UnionI [intro]: "X:C ==> A:X ==> A : Union C" | |
| 854 |   -- {* The order of the premises presupposes that @{term C} is rigid;
 | |
| 855 |     @{term A} may be flexible. *}
 | |
| 856 | by auto | |
| 857 | ||
| 858 | lemma UnionE [elim!]: "A : Union C ==> (!!X. A:X ==> X:C ==> R) ==> R" | |
| 859 | by (unfold Union_def) blast | |
| 860 | ||
| 861 | ||
| 862 | subsubsection {* Inter *}
 | |
| 863 | ||
| 864 | lemma Inter_iff [simp]: "(A : Inter C) = (ALL X:C. A:X)" | |
| 865 | by (unfold Inter_def) blast | |
| 866 | ||
| 867 | lemma InterI [intro!]: "(!!X. X:C ==> A:X) ==> A : Inter C" | |
| 868 | by (simp add: Inter_def) | |
| 869 | ||
| 870 | text {*
 | |
| 871 |   \medskip A ``destruct'' rule -- every @{term X} in @{term C}
 | |
| 872 |   contains @{term A} as an element, but @{prop "A:X"} can hold when
 | |
| 873 |   @{prop "X:C"} does not!  This rule is analogous to @{text spec}.
 | |
| 874 | *} | |
| 875 | ||
| 876 | lemma InterD [elim]: "A : Inter C ==> X:C ==> A:X" | |
| 877 | by auto | |
| 878 | ||
| 879 | lemma InterE [elim]: "A : Inter C ==> (X~:C ==> R) ==> (A:X ==> R) ==> R" | |
| 880 |   -- {* ``Classical'' elimination rule -- does not require proving
 | |
| 881 |     @{prop "X:C"}. *}
 | |
| 882 | by (unfold Inter_def) blast | |
| 883 | ||
| 884 | text {*
 | |
| 885 |   \medskip Image of a set under a function.  Frequently @{term b} does
 | |
| 886 |   not have the syntactic form of @{term "f x"}.
 | |
| 887 | *} | |
| 888 | ||
| 889 | lemma image_eqI [simp, intro]: "b = f x ==> x:A ==> b : f`A" | |
| 890 | by (unfold image_def) blast | |
| 891 | ||
| 892 | lemma imageI: "x : A ==> f x : f ` A" | |
| 893 | by (rule image_eqI) (rule refl) | |
| 894 | ||
| 895 | lemma rev_image_eqI: "x:A ==> b = f x ==> b : f`A" | |
| 896 |   -- {* This version's more effective when we already have the
 | |
| 897 |     required @{term x}. *}
 | |
| 898 | by (unfold image_def) blast | |
| 899 | ||
| 900 | lemma imageE [elim!]: | |
| 901 | "b : (%x. f x)`A ==> (!!x. b = f x ==> x:A ==> P) ==> P" | |
| 902 |   -- {* The eta-expansion gives variable-name preservation. *}
 | |
| 903 | by (unfold image_def) blast | |
| 904 | ||
| 905 | lemma image_Un: "f`(A Un B) = f`A Un f`B" | |
| 906 | by blast | |
| 907 | ||
| 908 | lemma image_iff: "(z : f`A) = (EX x:A. z = f x)" | |
| 909 | by blast | |
| 910 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 911 | lemma image_subset_iff: "(f`A \<subseteq> B) = (\<forall>x\<in>A. f x \<in> B)" | 
| 11979 | 912 |   -- {* This rewrite rule would confuse users if made default. *}
 | 
| 913 | by blast | |
| 914 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 915 | lemma subset_image_iff: "(B \<subseteq> f`A) = (EX AA. AA \<subseteq> A & B = f`AA)" | 
| 11979 | 916 | apply safe | 
| 917 | prefer 2 apply fast | |
| 14208 | 918 |   apply (rule_tac x = "{a. a : A & f a : B}" in exI, fast)
 | 
| 11979 | 919 | done | 
| 920 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 921 | lemma image_subsetI: "(!!x. x \<in> A ==> f x \<in> B) ==> f`A \<subseteq> B" | 
| 11979 | 922 |   -- {* Replaces the three steps @{text subsetI}, @{text imageE},
 | 
| 923 |     @{text hypsubst}, but breaks too many existing proofs. *}
 | |
| 924 | by blast | |
| 925 | ||
| 926 | text {*
 | |
| 927 | \medskip Range of a function -- just a translation for image! | |
| 928 | *} | |
| 929 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 930 | lemma range_eqI: "b = f x ==> b \<in> range f" | 
| 11979 | 931 | by simp | 
| 932 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 933 | lemma rangeI: "f x \<in> range f" | 
| 11979 | 934 | by simp | 
| 935 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 936 | lemma rangeE [elim?]: "b \<in> range (\<lambda>x. f x) ==> (!!x. b = f x ==> P) ==> P" | 
| 11979 | 937 | by blast | 
| 938 | ||
| 939 | ||
| 940 | subsubsection {* Set reasoning tools *}
 | |
| 941 | ||
| 942 | text {*
 | |
| 943 |   Rewrite rules for boolean case-splitting: faster than @{text
 | |
| 944 | "split_if [split]"}. | |
| 945 | *} | |
| 946 | ||
| 947 | lemma split_if_eq1: "((if Q then x else y) = b) = ((Q --> x = b) & (~ Q --> y = b))" | |
| 948 | by (rule split_if) | |
| 949 | ||
| 950 | lemma split_if_eq2: "(a = (if Q then x else y)) = ((Q --> a = x) & (~ Q --> a = y))" | |
| 951 | by (rule split_if) | |
| 952 | ||
| 953 | text {*
 | |
| 954 |   Split ifs on either side of the membership relation.  Not for @{text
 | |
| 955 | "[simp]"} -- can cause goals to blow up! | |
| 956 | *} | |
| 957 | ||
| 958 | lemma split_if_mem1: "((if Q then x else y) : b) = ((Q --> x : b) & (~ Q --> y : b))" | |
| 959 | by (rule split_if) | |
| 960 | ||
| 961 | lemma split_if_mem2: "(a : (if Q then x else y)) = ((Q --> a : x) & (~ Q --> a : y))" | |
| 962 | by (rule split_if) | |
| 963 | ||
| 964 | lemmas split_ifs = if_bool_eq_conj split_if_eq1 split_if_eq2 split_if_mem1 split_if_mem2 | |
| 965 | ||
| 966 | lemmas mem_simps = | |
| 967 | insert_iff empty_iff Un_iff Int_iff Compl_iff Diff_iff | |
| 968 | mem_Collect_eq UN_iff Union_iff INT_iff Inter_iff | |
| 969 |   -- {* Each of these has ALREADY been added @{text "[simp]"} above. *}
 | |
| 970 | ||
| 971 | (*Would like to add these, but the existing code only searches for the | |
| 972 | outer-level constant, which in this case is just "op :"; we instead need | |
| 973 | to use term-nets to associate patterns with rules. Also, if a rule fails to | |
| 974 | apply, then the formula should be kept. | |
| 19233 
77ca20b0ed77
renamed HOL + - * etc. to HOL.plus HOL.minus HOL.times etc.
 haftmann parents: 
19175diff
changeset | 975 |   [("HOL.uminus", Compl_iff RS iffD1), ("HOL.minus", [Diff_iff RS iffD1]),
 | 
| 11979 | 976 |    ("op Int", [IntD1,IntD2]),
 | 
| 977 |    ("Collect", [CollectD]), ("Inter", [InterD]), ("INTER", [INT_D])]
 | |
| 978 | *) | |
| 979 | ||
| 980 | ML_setup {*
 | |
| 981 |   val mksimps_pairs = [("Ball", [thm "bspec"])] @ mksimps_pairs;
 | |
| 17875 | 982 | change_simpset (fn ss => ss setmksimps (mksimps mksimps_pairs)); | 
| 11979 | 983 | *} | 
| 984 | ||
| 985 | ||
| 986 | subsubsection {* The ``proper subset'' relation *}
 | |
| 987 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 988 | lemma psubsetI [intro!]: "A \<subseteq> B ==> A \<noteq> B ==> A \<subset> B" | 
| 11979 | 989 | by (unfold psubset_def) blast | 
| 990 | ||
| 13624 | 991 | lemma psubsetE [elim!]: | 
| 992 | "[|A \<subset> B; [|A \<subseteq> B; ~ (B\<subseteq>A)|] ==> R|] ==> R" | |
| 993 | by (unfold psubset_def) blast | |
| 994 | ||
| 11979 | 995 | lemma psubset_insert_iff: | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 996 |   "(A \<subset> insert x B) = (if x \<in> B then A \<subset> B else if x \<in> A then A - {x} \<subset> B else A \<subseteq> B)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 997 | by (auto simp add: psubset_def subset_insert_iff) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 998 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 999 | lemma psubset_eq: "(A \<subset> B) = (A \<subseteq> B & A \<noteq> B)" | 
| 11979 | 1000 | by (simp only: psubset_def) | 
| 1001 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1002 | lemma psubset_imp_subset: "A \<subset> B ==> A \<subseteq> B" | 
| 11979 | 1003 | by (simp add: psubset_eq) | 
| 1004 | ||
| 14335 | 1005 | lemma psubset_trans: "[| A \<subset> B; B \<subset> C |] ==> A \<subset> C" | 
| 1006 | apply (unfold psubset_def) | |
| 1007 | apply (auto dest: subset_antisym) | |
| 1008 | done | |
| 1009 | ||
| 1010 | lemma psubsetD: "[| A \<subset> B; c \<in> A |] ==> c \<in> B" | |
| 1011 | apply (unfold psubset_def) | |
| 1012 | apply (auto dest: subsetD) | |
| 1013 | done | |
| 1014 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1015 | lemma psubset_subset_trans: "A \<subset> B ==> B \<subseteq> C ==> A \<subset> C" | 
| 11979 | 1016 | by (auto simp add: psubset_eq) | 
| 1017 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1018 | lemma subset_psubset_trans: "A \<subseteq> B ==> B \<subset> C ==> A \<subset> C" | 
| 11979 | 1019 | by (auto simp add: psubset_eq) | 
| 1020 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1021 | lemma psubset_imp_ex_mem: "A \<subset> B ==> \<exists>b. b \<in> (B - A)" | 
| 11979 | 1022 | by (unfold psubset_def) blast | 
| 1023 | ||
| 1024 | lemma atomize_ball: | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1025 | "(!!x. x \<in> A ==> P x) == Trueprop (\<forall>x\<in>A. P x)" | 
| 11979 | 1026 | by (simp only: Ball_def atomize_all atomize_imp) | 
| 1027 | ||
| 18832 | 1028 | lemmas [symmetric, rulify] = atomize_ball | 
| 1029 | and [symmetric, defn] = atomize_ball | |
| 11979 | 1030 | |
| 1031 | ||
| 1032 | subsection {* Further set-theory lemmas *}
 | |
| 1033 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1034 | subsubsection {* Derived rules involving subsets. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1035 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1036 | text {* @{text insert}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1037 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1038 | lemma subset_insertI: "B \<subseteq> insert a B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1039 | apply (rule subsetI) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1040 | apply (erule insertI2) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1041 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1042 | |
| 14302 | 1043 | lemma subset_insertI2: "A \<subseteq> B \<Longrightarrow> A \<subseteq> insert b B" | 
| 1044 | by blast | |
| 1045 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1046 | lemma subset_insert: "x \<notin> A ==> (A \<subseteq> insert x B) = (A \<subseteq> B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1047 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1048 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1049 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1050 | text {* \medskip Big Union -- least upper bound of a set. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1051 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1052 | lemma Union_upper: "B \<in> A ==> B \<subseteq> Union A" | 
| 17589 | 1053 | by (iprover intro: subsetI UnionI) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1054 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1055 | lemma Union_least: "(!!X. X \<in> A ==> X \<subseteq> C) ==> Union A \<subseteq> C" | 
| 17589 | 1056 | by (iprover intro: subsetI elim: UnionE dest: subsetD) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1057 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1058 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1059 | text {* \medskip General union. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1060 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1061 | lemma UN_upper: "a \<in> A ==> B a \<subseteq> (\<Union>x\<in>A. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1062 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1063 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1064 | lemma UN_least: "(!!x. x \<in> A ==> B x \<subseteq> C) ==> (\<Union>x\<in>A. B x) \<subseteq> C" | 
| 17589 | 1065 | by (iprover intro: subsetI elim: UN_E dest: subsetD) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1066 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1067 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1068 | text {* \medskip Big Intersection -- greatest lower bound of a set. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1069 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1070 | lemma Inter_lower: "B \<in> A ==> Inter A \<subseteq> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1071 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1072 | |
| 14551 | 1073 | lemma Inter_subset: | 
| 1074 |   "[| !!X. X \<in> A ==> X \<subseteq> B; A ~= {} |] ==> \<Inter>A \<subseteq> B"
 | |
| 1075 | by blast | |
| 1076 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1077 | lemma Inter_greatest: "(!!X. X \<in> A ==> C \<subseteq> X) ==> C \<subseteq> Inter A" | 
| 17589 | 1078 | by (iprover intro: InterI subsetI dest: subsetD) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1079 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1080 | lemma INT_lower: "a \<in> A ==> (\<Inter>x\<in>A. B x) \<subseteq> B a" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1081 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1082 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1083 | lemma INT_greatest: "(!!x. x \<in> A ==> C \<subseteq> B x) ==> C \<subseteq> (\<Inter>x\<in>A. B x)" | 
| 17589 | 1084 | by (iprover intro: INT_I subsetI dest: subsetD) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1085 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1086 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1087 | text {* \medskip Finite Union -- the least upper bound of two sets. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1088 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1089 | lemma Un_upper1: "A \<subseteq> A \<union> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1090 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1091 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1092 | lemma Un_upper2: "B \<subseteq> A \<union> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1093 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1094 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1095 | lemma Un_least: "A \<subseteq> C ==> B \<subseteq> C ==> A \<union> B \<subseteq> C" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1096 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1097 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1098 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1099 | text {* \medskip Finite Intersection -- the greatest lower bound of two sets. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1100 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1101 | lemma Int_lower1: "A \<inter> B \<subseteq> A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1102 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1103 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1104 | lemma Int_lower2: "A \<inter> B \<subseteq> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1105 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1106 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1107 | lemma Int_greatest: "C \<subseteq> A ==> C \<subseteq> B ==> C \<subseteq> A \<inter> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1108 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1109 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1110 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1111 | text {* \medskip Set difference. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1112 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1113 | lemma Diff_subset: "A - B \<subseteq> A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1114 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1115 | |
| 14302 | 1116 | lemma Diff_subset_conv: "(A - B \<subseteq> C) = (A \<subseteq> B \<union> C)" | 
| 1117 | by blast | |
| 1118 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1119 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1120 | text {* \medskip Monotonicity. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1121 | |
| 15206 
09d78ec709c7
Modified locales: improved implementation of "includes".
 ballarin parents: 
15140diff
changeset | 1122 | lemma mono_Un: "mono f ==> f A \<union> f B \<subseteq> f (A \<union> B)" | 
| 16773 | 1123 | by (auto simp add: mono_def) | 
| 15206 
09d78ec709c7
Modified locales: improved implementation of "includes".
 ballarin parents: 
15140diff
changeset | 1124 | |
| 
09d78ec709c7
Modified locales: improved implementation of "includes".
 ballarin parents: 
15140diff
changeset | 1125 | lemma mono_Int: "mono f ==> f (A \<inter> B) \<subseteq> f A \<inter> f B" | 
| 16773 | 1126 | by (auto simp add: mono_def) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1127 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1128 | subsubsection {* Equalities involving union, intersection, inclusion, etc. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1129 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1130 | text {* @{text "{}"}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1131 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1132 | lemma Collect_const [simp]: "{s. P} = (if P then UNIV else {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1133 |   -- {* supersedes @{text "Collect_False_empty"} *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1134 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1135 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1136 | lemma subset_empty [simp]: "(A \<subseteq> {}) = (A = {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1137 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1138 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1139 | lemma not_psubset_empty [iff]: "\<not> (A < {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1140 | by (unfold psubset_def) blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1141 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1142 | lemma Collect_empty_eq [simp]: "(Collect P = {}) = (\<forall>x. \<not> P x)"
 | 
| 18423 | 1143 | by blast | 
| 1144 | ||
| 1145 | lemma empty_Collect_eq [simp]: "({} = Collect P) = (\<forall>x. \<not> P x)"
 | |
| 1146 | by blast | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1147 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1148 | lemma Collect_neg_eq: "{x. \<not> P x} = - {x. P x}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1149 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1150 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1151 | lemma Collect_disj_eq: "{x. P x | Q x} = {x. P x} \<union> {x. Q x}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1152 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1153 | |
| 14812 | 1154 | lemma Collect_imp_eq: "{x. P x --> Q x} = -{x. P x} \<union> {x. Q x}"
 | 
| 1155 | by blast | |
| 1156 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1157 | lemma Collect_conj_eq: "{x. P x & Q x} = {x. P x} \<inter> {x. Q x}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1158 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1159 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1160 | lemma Collect_all_eq: "{x. \<forall>y. P x y} = (\<Inter>y. {x. P x y})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1161 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1162 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1163 | lemma Collect_ball_eq: "{x. \<forall>y\<in>A. P x y} = (\<Inter>y\<in>A. {x. P x y})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1164 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1165 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1166 | lemma Collect_ex_eq: "{x. \<exists>y. P x y} = (\<Union>y. {x. P x y})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1167 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1168 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1169 | lemma Collect_bex_eq: "{x. \<exists>y\<in>A. P x y} = (\<Union>y\<in>A. {x. P x y})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1170 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1171 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1172 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1173 | text {* \medskip @{text insert}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1174 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1175 | lemma insert_is_Un: "insert a A = {a} Un A"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1176 |   -- {* NOT SUITABLE FOR REWRITING since @{text "{a} == insert a {}"} *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1177 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1178 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1179 | lemma insert_not_empty [simp]: "insert a A \<noteq> {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1180 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1181 | |
| 17715 | 1182 | lemmas empty_not_insert = insert_not_empty [symmetric, standard] | 
| 1183 | declare empty_not_insert [simp] | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1184 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1185 | lemma insert_absorb: "a \<in> A ==> insert a A = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1186 |   -- {* @{text "[simp]"} causes recursive calls when there are nested inserts *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1187 |   -- {* with \emph{quadratic} running time *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1188 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1189 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1190 | lemma insert_absorb2 [simp]: "insert x (insert x A) = insert x A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1191 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1192 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1193 | lemma insert_commute: "insert x (insert y A) = insert y (insert x A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1194 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1195 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1196 | lemma insert_subset [simp]: "(insert x A \<subseteq> B) = (x \<in> B & A \<subseteq> B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1197 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1198 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1199 | lemma mk_disjoint_insert: "a \<in> A ==> \<exists>B. A = insert a B & a \<notin> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1200 |   -- {* use new @{text B} rather than @{text "A - {a}"} to avoid infinite unfolding *}
 | 
| 14208 | 1201 |   apply (rule_tac x = "A - {a}" in exI, blast)
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1202 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1203 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1204 | lemma insert_Collect: "insert a (Collect P) = {u. u \<noteq> a --> P u}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1205 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1206 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1207 | lemma UN_insert_distrib: "u \<in> A ==> (\<Union>x\<in>A. insert a (B x)) = insert a (\<Union>x\<in>A. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1208 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1209 | |
| 14302 | 1210 | lemma insert_inter_insert[simp]: "insert a A \<inter> insert a B = insert a (A \<inter> B)" | 
| 14742 | 1211 | by blast | 
| 14302 | 1212 | |
| 13103 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1213 | lemma insert_disjoint[simp]: | 
| 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1214 |  "(insert a A \<inter> B = {}) = (a \<notin> B \<and> A \<inter> B = {})"
 | 
| 14742 | 1215 |  "({} = insert a A \<inter> B) = (a \<notin> B \<and> {} = A \<inter> B)"
 | 
| 16773 | 1216 | by auto | 
| 13103 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1217 | |
| 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1218 | lemma disjoint_insert[simp]: | 
| 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1219 |  "(B \<inter> insert a A = {}) = (a \<notin> B \<and> B \<inter> A = {})"
 | 
| 14742 | 1220 |  "({} = A \<inter> insert b B) = (b \<notin> A \<and> {} = A \<inter> B)"
 | 
| 16773 | 1221 | by auto | 
| 14742 | 1222 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1223 | text {* \medskip @{text image}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1224 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1225 | lemma image_empty [simp]: "f`{} = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1226 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1227 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1228 | lemma image_insert [simp]: "f ` insert a B = insert (f a) (f`B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1229 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1230 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1231 | lemma image_constant: "x \<in> A ==> (\<lambda>x. c) ` A = {c}"
 | 
| 16773 | 1232 | by auto | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1233 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1234 | lemma image_image: "f ` (g ` A) = (\<lambda>x. f (g x)) ` A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1235 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1236 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1237 | lemma insert_image [simp]: "x \<in> A ==> insert (f x) (f`A) = f`A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1238 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1239 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1240 | lemma image_is_empty [iff]: "(f`A = {}) = (A = {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1241 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1242 | |
| 16773 | 1243 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1244 | lemma image_Collect: "f ` {x. P x} = {f x | x. P x}"
 | 
| 16773 | 1245 |   -- {* NOT suitable as a default simprule: the RHS isn't simpler than the LHS,
 | 
| 1246 | with its implicit quantifier and conjunction. Also image enjoys better | |
| 1247 | equational properties than does the RHS. *} | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1248 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1249 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1250 | lemma if_image_distrib [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1251 | "(\<lambda>x. if P x then f x else g x) ` S | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1252 |     = (f ` (S \<inter> {x. P x})) \<union> (g ` (S \<inter> {x. \<not> P x}))"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1253 | by (auto simp add: image_def) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1254 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1255 | lemma image_cong: "M = N ==> (!!x. x \<in> N ==> f x = g x) ==> f`M = g`N" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1256 | by (simp add: image_def) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1257 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1258 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1259 | text {* \medskip @{text range}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1260 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1261 | lemma full_SetCompr_eq: "{u. \<exists>x. u = f x} = range f"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1262 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1263 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1264 | lemma range_composition [simp]: "range (\<lambda>x. f (g x)) = f`range g" | 
| 14208 | 1265 | by (subst image_image, simp) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1266 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1267 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1268 | text {* \medskip @{text Int} *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1269 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1270 | lemma Int_absorb [simp]: "A \<inter> A = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1271 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1272 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1273 | lemma Int_left_absorb: "A \<inter> (A \<inter> B) = A \<inter> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1274 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1275 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1276 | lemma Int_commute: "A \<inter> B = B \<inter> A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1277 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1278 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1279 | lemma Int_left_commute: "A \<inter> (B \<inter> C) = B \<inter> (A \<inter> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1280 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1281 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1282 | lemma Int_assoc: "(A \<inter> B) \<inter> C = A \<inter> (B \<inter> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1283 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1284 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1285 | lemmas Int_ac = Int_assoc Int_left_absorb Int_commute Int_left_commute | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1286 |   -- {* Intersection is an AC-operator *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1287 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1288 | lemma Int_absorb1: "B \<subseteq> A ==> A \<inter> B = B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1289 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1290 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1291 | lemma Int_absorb2: "A \<subseteq> B ==> A \<inter> B = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1292 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1293 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1294 | lemma Int_empty_left [simp]: "{} \<inter> B = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1295 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1296 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1297 | lemma Int_empty_right [simp]: "A \<inter> {} = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1298 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1299 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1300 | lemma disjoint_eq_subset_Compl: "(A \<inter> B = {}) = (A \<subseteq> -B)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1301 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1302 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1303 | lemma disjoint_iff_not_equal: "(A \<inter> B = {}) = (\<forall>x\<in>A. \<forall>y\<in>B. x \<noteq> y)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1304 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1305 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1306 | lemma Int_UNIV_left [simp]: "UNIV \<inter> B = B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1307 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1308 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1309 | lemma Int_UNIV_right [simp]: "A \<inter> UNIV = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1310 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1311 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1312 | lemma Int_eq_Inter: "A \<inter> B = \<Inter>{A, B}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1313 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1314 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1315 | lemma Int_Un_distrib: "A \<inter> (B \<union> C) = (A \<inter> B) \<union> (A \<inter> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1316 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1317 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1318 | lemma Int_Un_distrib2: "(B \<union> C) \<inter> A = (B \<inter> A) \<union> (C \<inter> A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1319 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1320 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1321 | lemma Int_UNIV [simp]: "(A \<inter> B = UNIV) = (A = UNIV & B = UNIV)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1322 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1323 | |
| 15102 | 1324 | lemma Int_subset_iff [simp]: "(C \<subseteq> A \<inter> B) = (C \<subseteq> A & C \<subseteq> B)" | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1325 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1326 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1327 | lemma Int_Collect: "(x \<in> A \<inter> {x. P x}) = (x \<in> A & P x)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1328 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1329 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1330 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1331 | text {* \medskip @{text Un}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1332 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1333 | lemma Un_absorb [simp]: "A \<union> A = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1334 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1335 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1336 | lemma Un_left_absorb: "A \<union> (A \<union> B) = A \<union> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1337 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1338 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1339 | lemma Un_commute: "A \<union> B = B \<union> A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1340 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1341 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1342 | lemma Un_left_commute: "A \<union> (B \<union> C) = B \<union> (A \<union> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1343 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1344 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1345 | lemma Un_assoc: "(A \<union> B) \<union> C = A \<union> (B \<union> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1346 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1347 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1348 | lemmas Un_ac = Un_assoc Un_left_absorb Un_commute Un_left_commute | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1349 |   -- {* Union is an AC-operator *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1350 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1351 | lemma Un_absorb1: "A \<subseteq> B ==> A \<union> B = B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1352 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1353 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1354 | lemma Un_absorb2: "B \<subseteq> A ==> A \<union> B = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1355 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1356 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1357 | lemma Un_empty_left [simp]: "{} \<union> B = B"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1358 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1359 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1360 | lemma Un_empty_right [simp]: "A \<union> {} = A"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1361 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1362 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1363 | lemma Un_UNIV_left [simp]: "UNIV \<union> B = UNIV" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1364 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1365 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1366 | lemma Un_UNIV_right [simp]: "A \<union> UNIV = UNIV" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1367 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1368 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1369 | lemma Un_eq_Union: "A \<union> B = \<Union>{A, B}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1370 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1371 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1372 | lemma Un_insert_left [simp]: "(insert a B) \<union> C = insert a (B \<union> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1373 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1374 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1375 | lemma Un_insert_right [simp]: "A \<union> (insert a B) = insert a (A \<union> B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1376 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1377 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1378 | lemma Int_insert_left: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1379 | "(insert a B) Int C = (if a \<in> C then insert a (B \<inter> C) else B \<inter> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1380 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1381 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1382 | lemma Int_insert_right: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1383 | "A \<inter> (insert a B) = (if a \<in> A then insert a (A \<inter> B) else A \<inter> B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1384 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1385 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1386 | lemma Un_Int_distrib: "A \<union> (B \<inter> C) = (A \<union> B) \<inter> (A \<union> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1387 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1388 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1389 | lemma Un_Int_distrib2: "(B \<inter> C) \<union> A = (B \<union> A) \<inter> (C \<union> A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1390 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1391 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1392 | lemma Un_Int_crazy: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1393 | "(A \<inter> B) \<union> (B \<inter> C) \<union> (C \<inter> A) = (A \<union> B) \<inter> (B \<union> C) \<inter> (C \<union> A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1394 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1395 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1396 | lemma subset_Un_eq: "(A \<subseteq> B) = (A \<union> B = B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1397 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1398 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1399 | lemma Un_empty [iff]: "(A \<union> B = {}) = (A = {} & B = {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1400 | by blast | 
| 15102 | 1401 | |
| 1402 | lemma Un_subset_iff [simp]: "(A \<union> B \<subseteq> C) = (A \<subseteq> C & B \<subseteq> C)" | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1403 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1404 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1405 | lemma Un_Diff_Int: "(A - B) \<union> (A \<inter> B) = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1406 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1407 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1408 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1409 | text {* \medskip Set complement *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1410 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1411 | lemma Compl_disjoint [simp]: "A \<inter> -A = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1412 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1413 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1414 | lemma Compl_disjoint2 [simp]: "-A \<inter> A = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1415 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1416 | |
| 13818 | 1417 | lemma Compl_partition: "A \<union> -A = UNIV" | 
| 1418 | by blast | |
| 1419 | ||
| 1420 | lemma Compl_partition2: "-A \<union> A = UNIV" | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1421 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1422 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1423 | lemma double_complement [simp]: "- (-A) = (A::'a set)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1424 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1425 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1426 | lemma Compl_Un [simp]: "-(A \<union> B) = (-A) \<inter> (-B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1427 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1428 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1429 | lemma Compl_Int [simp]: "-(A \<inter> B) = (-A) \<union> (-B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1430 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1431 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1432 | lemma Compl_UN [simp]: "-(\<Union>x\<in>A. B x) = (\<Inter>x\<in>A. -B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1433 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1434 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1435 | lemma Compl_INT [simp]: "-(\<Inter>x\<in>A. B x) = (\<Union>x\<in>A. -B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1436 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1437 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1438 | lemma subset_Compl_self_eq: "(A \<subseteq> -A) = (A = {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1439 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1440 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1441 | lemma Un_Int_assoc_eq: "((A \<inter> B) \<union> C = A \<inter> (B \<union> C)) = (C \<subseteq> A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1442 |   -- {* Halmos, Naive Set Theory, page 16. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1443 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1444 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1445 | lemma Compl_UNIV_eq [simp]: "-UNIV = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1446 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1447 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1448 | lemma Compl_empty_eq [simp]: "-{} = UNIV"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1449 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1450 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1451 | lemma Compl_subset_Compl_iff [iff]: "(-A \<subseteq> -B) = (B \<subseteq> A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1452 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1453 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1454 | lemma Compl_eq_Compl_iff [iff]: "(-A = -B) = (A = (B::'a set))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1455 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1456 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1457 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1458 | text {* \medskip @{text Union}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1459 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1460 | lemma Union_empty [simp]: "Union({}) = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1461 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1462 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1463 | lemma Union_UNIV [simp]: "Union UNIV = UNIV" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1464 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1465 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1466 | lemma Union_insert [simp]: "Union (insert a B) = a \<union> \<Union>B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1467 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1468 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1469 | lemma Union_Un_distrib [simp]: "\<Union>(A Un B) = \<Union>A \<union> \<Union>B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1470 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1471 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1472 | lemma Union_Int_subset: "\<Union>(A \<inter> B) \<subseteq> \<Union>A \<inter> \<Union>B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1473 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1474 | |
| 18447 | 1475 | lemma Union_empty_conv [simp]: "(\<Union>A = {}) = (\<forall>x\<in>A. x = {})"
 | 
| 13653 | 1476 | by blast | 
| 1477 | ||
| 18447 | 1478 | lemma empty_Union_conv [simp]: "({} = \<Union>A) = (\<forall>x\<in>A. x = {})"
 | 
| 13653 | 1479 | by blast | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1480 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1481 | lemma Union_disjoint: "(\<Union>C \<inter> A = {}) = (\<forall>B\<in>C. B \<inter> A = {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1482 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1483 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1484 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1485 | text {* \medskip @{text Inter}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1486 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1487 | lemma Inter_empty [simp]: "\<Inter>{} = UNIV"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1488 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1489 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1490 | lemma Inter_UNIV [simp]: "\<Inter>UNIV = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1491 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1492 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1493 | lemma Inter_insert [simp]: "\<Inter>(insert a B) = a \<inter> \<Inter>B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1494 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1495 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1496 | lemma Inter_Un_subset: "\<Inter>A \<union> \<Inter>B \<subseteq> \<Inter>(A \<inter> B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1497 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1498 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1499 | lemma Inter_Un_distrib: "\<Inter>(A \<union> B) = \<Inter>A \<inter> \<Inter>B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1500 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1501 | |
| 18447 | 1502 | lemma Inter_UNIV_conv [simp]: | 
| 13653 | 1503 | "(\<Inter>A = UNIV) = (\<forall>x\<in>A. x = UNIV)" | 
| 1504 | "(UNIV = \<Inter>A) = (\<forall>x\<in>A. x = UNIV)" | |
| 14208 | 1505 | by blast+ | 
| 13653 | 1506 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1507 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1508 | text {*
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1509 |   \medskip @{text UN} and @{text INT}.
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1510 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1511 | Basic identities: *} | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1512 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1513 | lemma UN_empty [simp]: "(\<Union>x\<in>{}. B x) = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1514 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1515 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1516 | lemma UN_empty2 [simp]: "(\<Union>x\<in>A. {}) = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1517 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1518 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1519 | lemma UN_singleton [simp]: "(\<Union>x\<in>A. {x}) = A"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1520 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1521 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1522 | lemma UN_absorb: "k \<in> I ==> A k \<union> (\<Union>i\<in>I. A i) = (\<Union>i\<in>I. A i)" | 
| 15102 | 1523 | by auto | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1524 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1525 | lemma INT_empty [simp]: "(\<Inter>x\<in>{}. B x) = UNIV"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1526 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1527 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1528 | lemma INT_absorb: "k \<in> I ==> A k \<inter> (\<Inter>i\<in>I. A i) = (\<Inter>i\<in>I. A i)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1529 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1530 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1531 | lemma UN_insert [simp]: "(\<Union>x\<in>insert a A. B x) = B a \<union> UNION A B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1532 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1533 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1534 | lemma UN_Un: "(\<Union>i \<in> A \<union> B. M i) = (\<Union>i\<in>A. M i) \<union> (\<Union>i\<in>B. M i)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1535 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1536 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1537 | lemma UN_UN_flatten: "(\<Union>x \<in> (\<Union>y\<in>A. B y). C x) = (\<Union>y\<in>A. \<Union>x\<in>B y. C x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1538 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1539 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1540 | lemma UN_subset_iff: "((\<Union>i\<in>I. A i) \<subseteq> B) = (\<forall>i\<in>I. A i \<subseteq> B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1541 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1542 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1543 | lemma INT_subset_iff: "(B \<subseteq> (\<Inter>i\<in>I. A i)) = (\<forall>i\<in>I. B \<subseteq> A i)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1544 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1545 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1546 | lemma INT_insert [simp]: "(\<Inter>x \<in> insert a A. B x) = B a \<inter> INTER A B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1547 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1548 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1549 | lemma INT_Un: "(\<Inter>i \<in> A \<union> B. M i) = (\<Inter>i \<in> A. M i) \<inter> (\<Inter>i\<in>B. M i)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1550 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1551 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1552 | lemma INT_insert_distrib: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1553 | "u \<in> A ==> (\<Inter>x\<in>A. insert a (B x)) = insert a (\<Inter>x\<in>A. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1554 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1555 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1556 | lemma Union_image_eq [simp]: "\<Union>(B`A) = (\<Union>x\<in>A. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1557 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1558 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1559 | lemma image_Union: "f ` \<Union>S = (\<Union>x\<in>S. f ` x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1560 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1561 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1562 | lemma Inter_image_eq [simp]: "\<Inter>(B`A) = (\<Inter>x\<in>A. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1563 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1564 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1565 | lemma UN_constant [simp]: "(\<Union>y\<in>A. c) = (if A = {} then {} else c)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1566 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1567 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1568 | lemma INT_constant [simp]: "(\<Inter>y\<in>A. c) = (if A = {} then UNIV else c)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1569 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1570 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1571 | lemma UN_eq: "(\<Union>x\<in>A. B x) = \<Union>({Y. \<exists>x\<in>A. Y = B x})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1572 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1573 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1574 | lemma INT_eq: "(\<Inter>x\<in>A. B x) = \<Inter>({Y. \<exists>x\<in>A. Y = B x})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1575 |   -- {* Look: it has an \emph{existential} quantifier *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1576 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1577 | |
| 18447 | 1578 | lemma UNION_empty_conv[simp]: | 
| 13653 | 1579 |   "({} = (UN x:A. B x)) = (\<forall>x\<in>A. B x = {})"
 | 
| 1580 |   "((UN x:A. B x) = {}) = (\<forall>x\<in>A. B x = {})"
 | |
| 1581 | by blast+ | |
| 1582 | ||
| 18447 | 1583 | lemma INTER_UNIV_conv[simp]: | 
| 13653 | 1584 | "(UNIV = (INT x:A. B x)) = (\<forall>x\<in>A. B x = UNIV)" | 
| 1585 | "((INT x:A. B x) = UNIV) = (\<forall>x\<in>A. B x = UNIV)" | |
| 1586 | by blast+ | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1587 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1588 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1589 | text {* \medskip Distributive laws: *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1590 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1591 | lemma Int_Union: "A \<inter> \<Union>B = (\<Union>C\<in>B. A \<inter> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1592 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1593 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1594 | lemma Int_Union2: "\<Union>B \<inter> A = (\<Union>C\<in>B. C \<inter> A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1595 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1596 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1597 | lemma Un_Union_image: "(\<Union>x\<in>C. A x \<union> B x) = \<Union>(A`C) \<union> \<Union>(B`C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1598 |   -- {* Devlin, Fundamentals of Contemporary Set Theory, page 12, exercise 5: *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1599 |   -- {* Union of a family of unions *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1600 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1601 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1602 | lemma UN_Un_distrib: "(\<Union>i\<in>I. A i \<union> B i) = (\<Union>i\<in>I. A i) \<union> (\<Union>i\<in>I. B i)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1603 |   -- {* Equivalent version *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1604 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1605 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1606 | lemma Un_Inter: "A \<union> \<Inter>B = (\<Inter>C\<in>B. A \<union> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1607 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1608 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1609 | lemma Int_Inter_image: "(\<Inter>x\<in>C. A x \<inter> B x) = \<Inter>(A`C) \<inter> \<Inter>(B`C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1610 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1611 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1612 | lemma INT_Int_distrib: "(\<Inter>i\<in>I. A i \<inter> B i) = (\<Inter>i\<in>I. A i) \<inter> (\<Inter>i\<in>I. B i)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1613 |   -- {* Equivalent version *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1614 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1615 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1616 | lemma Int_UN_distrib: "B \<inter> (\<Union>i\<in>I. A i) = (\<Union>i\<in>I. B \<inter> A i)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1617 |   -- {* Halmos, Naive Set Theory, page 35. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1618 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1619 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1620 | lemma Un_INT_distrib: "B \<union> (\<Inter>i\<in>I. A i) = (\<Inter>i\<in>I. B \<union> A i)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1621 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1622 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1623 | lemma Int_UN_distrib2: "(\<Union>i\<in>I. A i) \<inter> (\<Union>j\<in>J. B j) = (\<Union>i\<in>I. \<Union>j\<in>J. A i \<inter> B j)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1624 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1625 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1626 | lemma Un_INT_distrib2: "(\<Inter>i\<in>I. A i) \<union> (\<Inter>j\<in>J. B j) = (\<Inter>i\<in>I. \<Inter>j\<in>J. A i \<union> B j)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1627 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1628 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1629 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1630 | text {* \medskip Bounded quantifiers.
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1631 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1632 | The following are not added to the default simpset because | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1633 |   (a) they duplicate the body and (b) there are no similar rules for @{text Int}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1634 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1635 | lemma ball_Un: "(\<forall>x \<in> A \<union> B. P x) = ((\<forall>x\<in>A. P x) & (\<forall>x\<in>B. P x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1636 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1637 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1638 | lemma bex_Un: "(\<exists>x \<in> A \<union> B. P x) = ((\<exists>x\<in>A. P x) | (\<exists>x\<in>B. P x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1639 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1640 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1641 | lemma ball_UN: "(\<forall>z \<in> UNION A B. P z) = (\<forall>x\<in>A. \<forall>z \<in> B x. P z)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1642 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1643 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1644 | lemma bex_UN: "(\<exists>z \<in> UNION A B. P z) = (\<exists>x\<in>A. \<exists>z\<in>B x. P z)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1645 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1646 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1647 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1648 | text {* \medskip Set difference. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1649 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1650 | lemma Diff_eq: "A - B = A \<inter> (-B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1651 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1652 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1653 | lemma Diff_eq_empty_iff [simp]: "(A - B = {}) = (A \<subseteq> B)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1654 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1655 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1656 | lemma Diff_cancel [simp]: "A - A = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1657 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1658 | |
| 14302 | 1659 | lemma Diff_idemp [simp]: "(A - B) - B = A - (B::'a set)" | 
| 1660 | by blast | |
| 1661 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1662 | lemma Diff_triv: "A \<inter> B = {} ==> A - B = A"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1663 | by (blast elim: equalityE) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1664 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1665 | lemma empty_Diff [simp]: "{} - A = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1666 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1667 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1668 | lemma Diff_empty [simp]: "A - {} = A"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1669 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1670 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1671 | lemma Diff_UNIV [simp]: "A - UNIV = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1672 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1673 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1674 | lemma Diff_insert0 [simp]: "x \<notin> A ==> A - insert x B = A - B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1675 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1676 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1677 | lemma Diff_insert: "A - insert a B = A - B - {a}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1678 |   -- {* NOT SUITABLE FOR REWRITING since @{text "{a} == insert a 0"} *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1679 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1680 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1681 | lemma Diff_insert2: "A - insert a B = A - {a} - B"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1682 |   -- {* NOT SUITABLE FOR REWRITING since @{text "{a} == insert a 0"} *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1683 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1684 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1685 | lemma insert_Diff_if: "insert x A - B = (if x \<in> B then A - B else insert x (A - B))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1686 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1687 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1688 | lemma insert_Diff1 [simp]: "x \<in> B ==> insert x A - B = A - B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1689 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1690 | |
| 14302 | 1691 | lemma insert_Diff_single[simp]: "insert a (A - {a}) = insert a A"
 | 
| 1692 | by blast | |
| 1693 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1694 | lemma insert_Diff: "a \<in> A ==> insert a (A - {a}) = A"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1695 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1696 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1697 | lemma Diff_insert_absorb: "x \<notin> A ==> (insert x A) - {x} = A"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1698 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1699 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1700 | lemma Diff_disjoint [simp]: "A \<inter> (B - A) = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1701 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1702 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1703 | lemma Diff_partition: "A \<subseteq> B ==> A \<union> (B - A) = B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1704 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1705 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1706 | lemma double_diff: "A \<subseteq> B ==> B \<subseteq> C ==> B - (C - A) = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1707 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1708 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1709 | lemma Un_Diff_cancel [simp]: "A \<union> (B - A) = A \<union> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1710 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1711 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1712 | lemma Un_Diff_cancel2 [simp]: "(B - A) \<union> A = B \<union> A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1713 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1714 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1715 | lemma Diff_Un: "A - (B \<union> C) = (A - B) \<inter> (A - C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1716 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1717 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1718 | lemma Diff_Int: "A - (B \<inter> C) = (A - B) \<union> (A - C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1719 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1720 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1721 | lemma Un_Diff: "(A \<union> B) - C = (A - C) \<union> (B - C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1722 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1723 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1724 | lemma Int_Diff: "(A \<inter> B) - C = A \<inter> (B - C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1725 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1726 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1727 | lemma Diff_Int_distrib: "C \<inter> (A - B) = (C \<inter> A) - (C \<inter> B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1728 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1729 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1730 | lemma Diff_Int_distrib2: "(A - B) \<inter> C = (A \<inter> C) - (B \<inter> C)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1731 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1732 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1733 | lemma Diff_Compl [simp]: "A - (- B) = A \<inter> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1734 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1735 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1736 | lemma Compl_Diff_eq [simp]: "- (A - B) = -A \<union> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1737 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1738 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1739 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1740 | text {* \medskip Quantification over type @{typ bool}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1741 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1742 | lemma all_bool_eq: "(\<forall>b::bool. P b) = (P True & P False)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1743 | apply auto | 
| 14208 | 1744 |   apply (tactic {* case_tac "b" 1 *}, auto)
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1745 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1746 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1747 | lemma bool_induct: "P True \<Longrightarrow> P False \<Longrightarrow> P x" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1748 | by (rule conjI [THEN all_bool_eq [THEN iffD2], THEN spec]) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1749 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1750 | lemma ex_bool_eq: "(\<exists>b::bool. P b) = (P True | P False)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1751 | apply auto | 
| 14208 | 1752 |   apply (tactic {* case_tac "b" 1 *}, auto)
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1753 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1754 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1755 | lemma Un_eq_UN: "A \<union> B = (\<Union>b. if b then A else B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1756 | by (auto simp add: split_if_mem2) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1757 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1758 | lemma UN_bool_eq: "(\<Union>b::bool. A b) = (A True \<union> A False)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1759 | apply auto | 
| 14208 | 1760 |   apply (tactic {* case_tac "b" 1 *}, auto)
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1761 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1762 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1763 | lemma INT_bool_eq: "(\<Inter>b::bool. A b) = (A True \<inter> A False)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1764 | apply auto | 
| 14208 | 1765 |   apply (tactic {* case_tac "b" 1 *}, auto)
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1766 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1767 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1768 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1769 | text {* \medskip @{text Pow} *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1770 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1771 | lemma Pow_empty [simp]: "Pow {} = {{}}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1772 | by (auto simp add: Pow_def) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1773 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1774 | lemma Pow_insert: "Pow (insert a A) = Pow A \<union> (insert a ` Pow A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1775 |   by (blast intro: image_eqI [where ?x = "u - {a}", standard])
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1776 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1777 | lemma Pow_Compl: "Pow (- A) = {-B | B. A \<in> Pow B}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1778 | by (blast intro: exI [where ?x = "- u", standard]) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1779 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1780 | lemma Pow_UNIV [simp]: "Pow UNIV = UNIV" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1781 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1782 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1783 | lemma Un_Pow_subset: "Pow A \<union> Pow B \<subseteq> Pow (A \<union> B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1784 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1785 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1786 | lemma UN_Pow_subset: "(\<Union>x\<in>A. Pow (B x)) \<subseteq> Pow (\<Union>x\<in>A. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1787 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1788 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1789 | lemma subset_Pow_Union: "A \<subseteq> Pow (\<Union>A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1790 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1791 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1792 | lemma Union_Pow_eq [simp]: "\<Union>(Pow A) = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1793 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1794 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1795 | lemma Pow_Int_eq [simp]: "Pow (A \<inter> B) = Pow A \<inter> Pow B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1796 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1797 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1798 | lemma Pow_INT_eq: "Pow (\<Inter>x\<in>A. B x) = (\<Inter>x\<in>A. Pow (B x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1799 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1800 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1801 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1802 | text {* \medskip Miscellany. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1803 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1804 | lemma set_eq_subset: "(A = B) = (A \<subseteq> B & B \<subseteq> A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1805 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1806 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1807 | lemma subset_iff: "(A \<subseteq> B) = (\<forall>t. t \<in> A --> t \<in> B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1808 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1809 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1810 | lemma subset_iff_psubset_eq: "(A \<subseteq> B) = ((A \<subset> B) | (A = B))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1811 | by (unfold psubset_def) blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1812 | |
| 18447 | 1813 | lemma all_not_in_conv [simp]: "(\<forall>x. x \<notin> A) = (A = {})"
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1814 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1815 | |
| 13831 | 1816 | lemma ex_in_conv: "(\<exists>x. x \<in> A) = (A \<noteq> {})"
 | 
| 1817 | by blast | |
| 1818 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1819 | lemma distinct_lemma: "f x \<noteq> f y ==> x \<noteq> y" | 
| 17589 | 1820 | by iprover | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1821 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1822 | |
| 13860 | 1823 | text {* \medskip Miniscoping: pushing in quantifiers and big Unions
 | 
| 1824 | and Intersections. *} | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1825 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1826 | lemma UN_simps [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1827 |   "!!a B C. (UN x:C. insert a (B x)) = (if C={} then {} else insert a (UN x:C. B x))"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1828 |   "!!A B C. (UN x:C. A x Un B)   = ((if C={} then {} else (UN x:C. A x) Un B))"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1829 |   "!!A B C. (UN x:C. A Un B x)   = ((if C={} then {} else A Un (UN x:C. B x)))"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1830 | "!!A B C. (UN x:C. A x Int B) = ((UN x:C. A x) Int B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1831 | "!!A B C. (UN x:C. A Int B x) = (A Int (UN x:C. B x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1832 | "!!A B C. (UN x:C. A x - B) = ((UN x:C. A x) - B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1833 | "!!A B C. (UN x:C. A - B x) = (A - (INT x:C. B x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1834 | "!!A B. (UN x: Union A. B x) = (UN y:A. UN x:y. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1835 | "!!A B C. (UN z: UNION A B. C z) = (UN x:A. UN z: B(x). C z)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1836 | "!!A B f. (UN x:f`A. B x) = (UN a:A. B (f a))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1837 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1838 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1839 | lemma INT_simps [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1840 |   "!!A B C. (INT x:C. A x Int B) = (if C={} then UNIV else (INT x:C. A x) Int B)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1841 |   "!!A B C. (INT x:C. A Int B x) = (if C={} then UNIV else A Int (INT x:C. B x))"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1842 |   "!!A B C. (INT x:C. A x - B)   = (if C={} then UNIV else (INT x:C. A x) - B)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1843 |   "!!A B C. (INT x:C. A - B x)   = (if C={} then UNIV else A - (UN x:C. B x))"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1844 | "!!a B C. (INT x:C. insert a (B x)) = insert a (INT x:C. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1845 | "!!A B C. (INT x:C. A x Un B) = ((INT x:C. A x) Un B)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1846 | "!!A B C. (INT x:C. A Un B x) = (A Un (INT x:C. B x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1847 | "!!A B. (INT x: Union A. B x) = (INT y:A. INT x:y. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1848 | "!!A B C. (INT z: UNION A B. C z) = (INT x:A. INT z: B(x). C z)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1849 | "!!A B f. (INT x:f`A. B x) = (INT a:A. B (f a))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1850 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1851 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1852 | lemma ball_simps [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1853 | "!!A P Q. (ALL x:A. P x | Q) = ((ALL x:A. P x) | Q)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1854 | "!!A P Q. (ALL x:A. P | Q x) = (P | (ALL x:A. Q x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1855 | "!!A P Q. (ALL x:A. P --> Q x) = (P --> (ALL x:A. Q x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1856 | "!!A P Q. (ALL x:A. P x --> Q) = ((EX x:A. P x) --> Q)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1857 |   "!!P. (ALL x:{}. P x) = True"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1858 | "!!P. (ALL x:UNIV. P x) = (ALL x. P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1859 | "!!a B P. (ALL x:insert a B. P x) = (P a & (ALL x:B. P x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1860 | "!!A P. (ALL x:Union A. P x) = (ALL y:A. ALL x:y. P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1861 | "!!A B P. (ALL x: UNION A B. P x) = (ALL a:A. ALL x: B a. P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1862 | "!!P Q. (ALL x:Collect Q. P x) = (ALL x. Q x --> P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1863 | "!!A P f. (ALL x:f`A. P x) = (ALL x:A. P (f x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1864 | "!!A P. (~(ALL x:A. P x)) = (EX x:A. ~P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1865 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1866 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1867 | lemma bex_simps [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1868 | "!!A P Q. (EX x:A. P x & Q) = ((EX x:A. P x) & Q)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1869 | "!!A P Q. (EX x:A. P & Q x) = (P & (EX x:A. Q x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1870 |   "!!P. (EX x:{}. P x) = False"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1871 | "!!P. (EX x:UNIV. P x) = (EX x. P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1872 | "!!a B P. (EX x:insert a B. P x) = (P(a) | (EX x:B. P x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1873 | "!!A P. (EX x:Union A. P x) = (EX y:A. EX x:y. P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1874 | "!!A B P. (EX x: UNION A B. P x) = (EX a:A. EX x:B a. P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1875 | "!!P Q. (EX x:Collect Q. P x) = (EX x. Q x & P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1876 | "!!A P f. (EX x:f`A. P x) = (EX x:A. P (f x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1877 | "!!A P. (~(EX x:A. P x)) = (ALL x:A. ~P x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1878 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1879 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1880 | lemma ball_conj_distrib: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1881 | "(ALL x:A. P x & Q x) = ((ALL x:A. P x) & (ALL x:A. Q x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1882 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1883 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1884 | lemma bex_disj_distrib: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1885 | "(EX x:A. P x | Q x) = ((EX x:A. P x) | (EX x:A. Q x))" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1886 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1887 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1888 | |
| 13860 | 1889 | text {* \medskip Maxiscoping: pulling out big Unions and Intersections. *}
 | 
| 1890 | ||
| 1891 | lemma UN_extend_simps: | |
| 1892 |   "!!a B C. insert a (UN x:C. B x) = (if C={} then {a} else (UN x:C. insert a (B x)))"
 | |
| 1893 |   "!!A B C. (UN x:C. A x) Un B    = (if C={} then B else (UN x:C. A x Un B))"
 | |
| 1894 |   "!!A B C. A Un (UN x:C. B x)   = (if C={} then A else (UN x:C. A Un B x))"
 | |
| 1895 | "!!A B C. ((UN x:C. A x) Int B) = (UN x:C. A x Int B)" | |
| 1896 | "!!A B C. (A Int (UN x:C. B x)) = (UN x:C. A Int B x)" | |
| 1897 | "!!A B C. ((UN x:C. A x) - B) = (UN x:C. A x - B)" | |
| 1898 | "!!A B C. (A - (INT x:C. B x)) = (UN x:C. A - B x)" | |
| 1899 | "!!A B. (UN y:A. UN x:y. B x) = (UN x: Union A. B x)" | |
| 1900 | "!!A B C. (UN x:A. UN z: B(x). C z) = (UN z: UNION A B. C z)" | |
| 1901 | "!!A B f. (UN a:A. B (f a)) = (UN x:f`A. B x)" | |
| 1902 | by auto | |
| 1903 | ||
| 1904 | lemma INT_extend_simps: | |
| 1905 |   "!!A B C. (INT x:C. A x) Int B = (if C={} then B else (INT x:C. A x Int B))"
 | |
| 1906 |   "!!A B C. A Int (INT x:C. B x) = (if C={} then A else (INT x:C. A Int B x))"
 | |
| 1907 |   "!!A B C. (INT x:C. A x) - B   = (if C={} then UNIV-B else (INT x:C. A x - B))"
 | |
| 1908 |   "!!A B C. A - (UN x:C. B x)   = (if C={} then A else (INT x:C. A - B x))"
 | |
| 1909 | "!!a B C. insert a (INT x:C. B x) = (INT x:C. insert a (B x))" | |
| 1910 | "!!A B C. ((INT x:C. A x) Un B) = (INT x:C. A x Un B)" | |
| 1911 | "!!A B C. A Un (INT x:C. B x) = (INT x:C. A Un B x)" | |
| 1912 | "!!A B. (INT y:A. INT x:y. B x) = (INT x: Union A. B x)" | |
| 1913 | "!!A B C. (INT x:A. INT z: B(x). C z) = (INT z: UNION A B. C z)" | |
| 1914 | "!!A B f. (INT a:A. B (f a)) = (INT x:f`A. B x)" | |
| 1915 | by auto | |
| 1916 | ||
| 1917 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1918 | subsubsection {* Monotonicity of various operations *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1919 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1920 | lemma image_mono: "A \<subseteq> B ==> f`A \<subseteq> f`B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1921 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1922 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1923 | lemma Pow_mono: "A \<subseteq> B ==> Pow A \<subseteq> Pow B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1924 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1925 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1926 | lemma Union_mono: "A \<subseteq> B ==> \<Union>A \<subseteq> \<Union>B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1927 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1928 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1929 | lemma Inter_anti_mono: "B \<subseteq> A ==> \<Inter>A \<subseteq> \<Inter>B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1930 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1931 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1932 | lemma UN_mono: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1933 | "A \<subseteq> B ==> (!!x. x \<in> A ==> f x \<subseteq> g x) ==> | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1934 | (\<Union>x\<in>A. f x) \<subseteq> (\<Union>x\<in>B. g x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1935 | by (blast dest: subsetD) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1936 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1937 | lemma INT_anti_mono: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1938 | "B \<subseteq> A ==> (!!x. x \<in> A ==> f x \<subseteq> g x) ==> | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1939 | (\<Inter>x\<in>A. f x) \<subseteq> (\<Inter>x\<in>A. g x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1940 |   -- {* The last inclusion is POSITIVE! *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1941 | by (blast dest: subsetD) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1942 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1943 | lemma insert_mono: "C \<subseteq> D ==> insert a C \<subseteq> insert a D" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1944 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1945 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1946 | lemma Un_mono: "A \<subseteq> C ==> B \<subseteq> D ==> A \<union> B \<subseteq> C \<union> D" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1947 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1948 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1949 | lemma Int_mono: "A \<subseteq> C ==> B \<subseteq> D ==> A \<inter> B \<subseteq> C \<inter> D" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1950 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1951 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1952 | lemma Diff_mono: "A \<subseteq> C ==> D \<subseteq> B ==> A - B \<subseteq> C - D" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1953 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1954 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1955 | lemma Compl_anti_mono: "A \<subseteq> B ==> -B \<subseteq> -A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1956 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1957 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1958 | text {* \medskip Monotonicity of implications. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1959 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1960 | lemma in_mono: "A \<subseteq> B ==> x \<in> A --> x \<in> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1961 | apply (rule impI) | 
| 14208 | 1962 | apply (erule subsetD, assumption) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1963 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1964 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1965 | lemma conj_mono: "P1 --> Q1 ==> P2 --> Q2 ==> (P1 & P2) --> (Q1 & Q2)" | 
| 17589 | 1966 | by iprover | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1967 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1968 | lemma disj_mono: "P1 --> Q1 ==> P2 --> Q2 ==> (P1 | P2) --> (Q1 | Q2)" | 
| 17589 | 1969 | by iprover | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1970 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1971 | lemma imp_mono: "Q1 --> P1 ==> P2 --> Q2 ==> (P1 --> P2) --> (Q1 --> Q2)" | 
| 17589 | 1972 | by iprover | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1973 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1974 | lemma imp_refl: "P --> P" .. | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1975 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1976 | lemma ex_mono: "(!!x. P x --> Q x) ==> (EX x. P x) --> (EX x. Q x)" | 
| 17589 | 1977 | by iprover | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1978 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1979 | lemma all_mono: "(!!x. P x --> Q x) ==> (ALL x. P x) --> (ALL x. Q x)" | 
| 17589 | 1980 | by iprover | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1981 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1982 | lemma Collect_mono: "(!!x. P x --> Q x) ==> Collect P \<subseteq> Collect Q" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1983 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1984 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1985 | lemma Int_Collect_mono: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1986 | "A \<subseteq> B ==> (!!x. x \<in> A ==> P x --> Q x) ==> A \<inter> Collect P \<subseteq> B \<inter> Collect Q" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1987 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1988 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1989 | lemmas basic_monos = | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1990 | subset_refl imp_refl disj_mono conj_mono | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1991 | ex_mono Collect_mono in_mono | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1992 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1993 | lemma eq_to_mono: "a = b ==> c = d ==> b --> d ==> a --> c" | 
| 17589 | 1994 | by iprover | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1995 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1996 | lemma eq_to_mono2: "a = b ==> c = d ==> ~ b --> ~ d ==> ~ a --> ~ c" | 
| 17589 | 1997 | by iprover | 
| 11979 | 1998 | |
| 11982 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 1999 | lemma Least_mono: | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 2000 | "mono (f::'a::order => 'b::order) ==> EX x:S. ALL y:S. x <= y | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 2001 | ==> (LEAST y. y : f ` S) = f (LEAST x. x : S)" | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 2002 |     -- {* Courtesy of Stephan Merz *}
 | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 2003 | apply clarify | 
| 15950 | 2004 | apply (erule_tac P = "%x. x : S" in LeastI2_order, fast) | 
| 2005 | apply (rule LeastI2_order) | |
| 11982 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 2006 | apply (auto elim: monoD intro!: order_antisym) | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 2007 | done | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 2008 | |
| 12020 | 2009 | |
| 12257 | 2010 | subsection {* Inverse image of a function *}
 | 
| 2011 | ||
| 2012 | constdefs | |
| 2013 |   vimage :: "('a => 'b) => 'b set => 'a set"    (infixr "-`" 90)
 | |
| 2014 |   "f -` B == {x. f x : B}"
 | |
| 2015 | ||
| 2016 | ||
| 2017 | subsubsection {* Basic rules *}
 | |
| 2018 | ||
| 2019 | lemma vimage_eq [simp]: "(a : f -` B) = (f a : B)" | |
| 2020 | by (unfold vimage_def) blast | |
| 2021 | ||
| 2022 | lemma vimage_singleton_eq: "(a : f -` {b}) = (f a = b)"
 | |
| 2023 | by simp | |
| 2024 | ||
| 2025 | lemma vimageI [intro]: "f a = b ==> b:B ==> a : f -` B" | |
| 2026 | by (unfold vimage_def) blast | |
| 2027 | ||
| 2028 | lemma vimageI2: "f a : A ==> a : f -` A" | |
| 2029 | by (unfold vimage_def) fast | |
| 2030 | ||
| 2031 | lemma vimageE [elim!]: "a: f -` B ==> (!!x. f a = x ==> x:B ==> P) ==> P" | |
| 2032 | by (unfold vimage_def) blast | |
| 2033 | ||
| 2034 | lemma vimageD: "a : f -` A ==> f a : A" | |
| 2035 | by (unfold vimage_def) fast | |
| 2036 | ||
| 2037 | ||
| 2038 | subsubsection {* Equations *}
 | |
| 2039 | ||
| 2040 | lemma vimage_empty [simp]: "f -` {} = {}"
 | |
| 2041 | by blast | |
| 2042 | ||
| 2043 | lemma vimage_Compl: "f -` (-A) = -(f -` A)" | |
| 2044 | by blast | |
| 2045 | ||
| 2046 | lemma vimage_Un [simp]: "f -` (A Un B) = (f -` A) Un (f -` B)" | |
| 2047 | by blast | |
| 2048 | ||
| 2049 | lemma vimage_Int [simp]: "f -` (A Int B) = (f -` A) Int (f -` B)" | |
| 2050 | by fast | |
| 2051 | ||
| 2052 | lemma vimage_Union: "f -` (Union A) = (UN X:A. f -` X)" | |
| 2053 | by blast | |
| 2054 | ||
| 2055 | lemma vimage_UN: "f-`(UN x:A. B x) = (UN x:A. f -` B x)" | |
| 2056 | by blast | |
| 2057 | ||
| 2058 | lemma vimage_INT: "f-`(INT x:A. B x) = (INT x:A. f -` B x)" | |
| 2059 | by blast | |
| 2060 | ||
| 2061 | lemma vimage_Collect_eq [simp]: "f -` Collect P = {y. P (f y)}"
 | |
| 2062 | by blast | |
| 2063 | ||
| 2064 | lemma vimage_Collect: "(!!x. P (f x) = Q x) ==> f -` (Collect P) = Collect Q" | |
| 2065 | by blast | |
| 2066 | ||
| 2067 | lemma vimage_insert: "f-`(insert a B) = (f-`{a}) Un (f-`B)"
 | |
| 2068 |   -- {* NOT suitable for rewriting because of the recurrence of @{term "{a}"}. *}
 | |
| 2069 | by blast | |
| 2070 | ||
| 2071 | lemma vimage_Diff: "f -` (A - B) = (f -` A) - (f -` B)" | |
| 2072 | by blast | |
| 2073 | ||
| 2074 | lemma vimage_UNIV [simp]: "f -` UNIV = UNIV" | |
| 2075 | by blast | |
| 2076 | ||
| 2077 | lemma vimage_eq_UN: "f-`B = (UN y: B. f-`{y})"
 | |
| 2078 |   -- {* NOT suitable for rewriting *}
 | |
| 2079 | by blast | |
| 2080 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 2081 | lemma vimage_mono: "A \<subseteq> B ==> f -` A \<subseteq> f -` B" | 
| 12257 | 2082 |   -- {* monotonicity *}
 | 
| 2083 | by blast | |
| 2084 | ||
| 2085 | ||
| 14479 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2086 | subsection {* Getting the Contents of a Singleton Set *}
 | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2087 | |
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2088 | constdefs | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2089 | contents :: "'a set => 'a" | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2090 |    "contents X == THE x. X = {x}"
 | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2091 | |
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2092 | lemma contents_eq [simp]: "contents {x} = x"
 | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2093 | by (simp add: contents_def) | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2094 | |
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2095 | |
| 12023 | 2096 | subsection {* Transitivity rules for calculational reasoning *}
 | 
| 12020 | 2097 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 2098 | lemma set_rev_mp: "x:A ==> A \<subseteq> B ==> x:B" | 
| 12020 | 2099 | by (rule subsetD) | 
| 2100 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 2101 | lemma set_mp: "A \<subseteq> B ==> x:A ==> x:B" | 
| 12020 | 2102 | by (rule subsetD) | 
| 2103 | ||
| 2104 | lemma ord_le_eq_trans: "a <= b ==> b = c ==> a <= c" | |
| 2105 | by (rule subst) | |
| 2106 | ||
| 2107 | lemma ord_eq_le_trans: "a = b ==> b <= c ==> a <= c" | |
| 2108 | by (rule ssubst) | |
| 2109 | ||
| 2110 | lemma ord_less_eq_trans: "a < b ==> b = c ==> a < c" | |
| 2111 | by (rule subst) | |
| 2112 | ||
| 2113 | lemma ord_eq_less_trans: "a = b ==> b < c ==> a < c" | |
| 2114 | by (rule ssubst) | |
| 2115 | ||
| 2116 | lemma order_less_subst2: "(a::'a::order) < b ==> f b < (c::'c::order) ==> | |
| 2117 | (!!x y. x < y ==> f x < f y) ==> f a < c" | |
| 2118 | proof - | |
| 2119 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2120 | assume "a < b" hence "f a < f b" by (rule r) | |
| 2121 | also assume "f b < c" | |
| 2122 | finally (order_less_trans) show ?thesis . | |
| 2123 | qed | |
| 2124 | ||
| 2125 | lemma order_less_subst1: "(a::'a::order) < f b ==> (b::'b::order) < c ==> | |
| 2126 | (!!x y. x < y ==> f x < f y) ==> a < f c" | |
| 2127 | proof - | |
| 2128 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2129 | assume "a < f b" | |
| 2130 | also assume "b < c" hence "f b < f c" by (rule r) | |
| 2131 | finally (order_less_trans) show ?thesis . | |
| 2132 | qed | |
| 2133 | ||
| 2134 | lemma order_le_less_subst2: "(a::'a::order) <= b ==> f b < (c::'c::order) ==> | |
| 2135 | (!!x y. x <= y ==> f x <= f y) ==> f a < c" | |
| 2136 | proof - | |
| 2137 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2138 | assume "a <= b" hence "f a <= f b" by (rule r) | |
| 2139 | also assume "f b < c" | |
| 2140 | finally (order_le_less_trans) show ?thesis . | |
| 2141 | qed | |
| 2142 | ||
| 2143 | lemma order_le_less_subst1: "(a::'a::order) <= f b ==> (b::'b::order) < c ==> | |
| 2144 | (!!x y. x < y ==> f x < f y) ==> a < f c" | |
| 2145 | proof - | |
| 2146 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2147 | assume "a <= f b" | |
| 2148 | also assume "b < c" hence "f b < f c" by (rule r) | |
| 2149 | finally (order_le_less_trans) show ?thesis . | |
| 2150 | qed | |
| 2151 | ||
| 2152 | lemma order_less_le_subst2: "(a::'a::order) < b ==> f b <= (c::'c::order) ==> | |
| 2153 | (!!x y. x < y ==> f x < f y) ==> f a < c" | |
| 2154 | proof - | |
| 2155 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2156 | assume "a < b" hence "f a < f b" by (rule r) | |
| 2157 | also assume "f b <= c" | |
| 2158 | finally (order_less_le_trans) show ?thesis . | |
| 2159 | qed | |
| 2160 | ||
| 2161 | lemma order_less_le_subst1: "(a::'a::order) < f b ==> (b::'b::order) <= c ==> | |
| 2162 | (!!x y. x <= y ==> f x <= f y) ==> a < f c" | |
| 2163 | proof - | |
| 2164 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2165 | assume "a < f b" | |
| 2166 | also assume "b <= c" hence "f b <= f c" by (rule r) | |
| 2167 | finally (order_less_le_trans) show ?thesis . | |
| 2168 | qed | |
| 2169 | ||
| 2170 | lemma order_subst1: "(a::'a::order) <= f b ==> (b::'b::order) <= c ==> | |
| 2171 | (!!x y. x <= y ==> f x <= f y) ==> a <= f c" | |
| 2172 | proof - | |
| 2173 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2174 | assume "a <= f b" | |
| 2175 | also assume "b <= c" hence "f b <= f c" by (rule r) | |
| 2176 | finally (order_trans) show ?thesis . | |
| 2177 | qed | |
| 2178 | ||
| 2179 | lemma order_subst2: "(a::'a::order) <= b ==> f b <= (c::'c::order) ==> | |
| 2180 | (!!x y. x <= y ==> f x <= f y) ==> f a <= c" | |
| 2181 | proof - | |
| 2182 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2183 | assume "a <= b" hence "f a <= f b" by (rule r) | |
| 2184 | also assume "f b <= c" | |
| 2185 | finally (order_trans) show ?thesis . | |
| 2186 | qed | |
| 2187 | ||
| 2188 | lemma ord_le_eq_subst: "a <= b ==> f b = c ==> | |
| 2189 | (!!x y. x <= y ==> f x <= f y) ==> f a <= c" | |
| 2190 | proof - | |
| 2191 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2192 | assume "a <= b" hence "f a <= f b" by (rule r) | |
| 2193 | also assume "f b = c" | |
| 2194 | finally (ord_le_eq_trans) show ?thesis . | |
| 2195 | qed | |
| 2196 | ||
| 2197 | lemma ord_eq_le_subst: "a = f b ==> b <= c ==> | |
| 2198 | (!!x y. x <= y ==> f x <= f y) ==> a <= f c" | |
| 2199 | proof - | |
| 2200 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2201 | assume "a = f b" | |
| 2202 | also assume "b <= c" hence "f b <= f c" by (rule r) | |
| 2203 | finally (ord_eq_le_trans) show ?thesis . | |
| 2204 | qed | |
| 2205 | ||
| 2206 | lemma ord_less_eq_subst: "a < b ==> f b = c ==> | |
| 2207 | (!!x y. x < y ==> f x < f y) ==> f a < c" | |
| 2208 | proof - | |
| 2209 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2210 | assume "a < b" hence "f a < f b" by (rule r) | |
| 2211 | also assume "f b = c" | |
| 2212 | finally (ord_less_eq_trans) show ?thesis . | |
| 2213 | qed | |
| 2214 | ||
| 2215 | lemma ord_eq_less_subst: "a = f b ==> b < c ==> | |
| 2216 | (!!x y. x < y ==> f x < f y) ==> a < f c" | |
| 2217 | proof - | |
| 2218 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2219 | assume "a = f b" | |
| 2220 | also assume "b < c" hence "f b < f c" by (rule r) | |
| 2221 | finally (ord_eq_less_trans) show ?thesis . | |
| 2222 | qed | |
| 2223 | ||
| 2224 | text {*
 | |
| 2225 | Note that this list of rules is in reverse order of priorities. | |
| 2226 | *} | |
| 2227 | ||
| 2228 | lemmas basic_trans_rules [trans] = | |
| 2229 | order_less_subst2 | |
| 2230 | order_less_subst1 | |
| 2231 | order_le_less_subst2 | |
| 2232 | order_le_less_subst1 | |
| 2233 | order_less_le_subst2 | |
| 2234 | order_less_le_subst1 | |
| 2235 | order_subst2 | |
| 2236 | order_subst1 | |
| 2237 | ord_le_eq_subst | |
| 2238 | ord_eq_le_subst | |
| 2239 | ord_less_eq_subst | |
| 2240 | ord_eq_less_subst | |
| 2241 | forw_subst | |
| 2242 | back_subst | |
| 2243 | rev_mp | |
| 2244 | mp | |
| 2245 | set_rev_mp | |
| 2246 | set_mp | |
| 2247 | order_neq_le_trans | |
| 2248 | order_le_neq_trans | |
| 2249 | order_less_trans | |
| 2250 | order_less_asym' | |
| 2251 | order_le_less_trans | |
| 2252 | order_less_le_trans | |
| 2253 | order_trans | |
| 2254 | order_antisym | |
| 2255 | ord_le_eq_trans | |
| 2256 | ord_eq_le_trans | |
| 2257 | ord_less_eq_trans | |
| 2258 | ord_eq_less_trans | |
| 2259 | trans | |
| 2260 | ||
| 11979 | 2261 | end |