| author | huffman | 
| Wed, 06 Jul 2005 00:08:57 +0200 | |
| changeset 16701 | abd0abd66387 | 
| parent 16636 | 1ed737a98198 | 
| child 16773 | 33c4d8fe6f78 | 
| 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 | 
| 15524 
2ef571f80a55
Moved oderings from HOL into the new Orderings.thy
 nipkow parents: 
15206diff
changeset | 9 | imports Orderings | 
| 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"
 | |
| 36 |   image         :: "('a => 'b) => 'a set => 'b set"      (infixr "`" 90)
 | |
| 37 | ||
| 38 | syntax | |
| 39 |   "op :"        :: "'a => 'a set => bool"                ("op :")
 | |
| 40 | consts | |
| 41 |   "op :"        :: "'a => 'a set => bool"                ("(_/ : _)" [50, 51] 50)  -- "membership"
 | |
| 42 | ||
| 43 | local | |
| 44 | ||
| 14692 | 45 | instance set :: (type) "{ord, minus}" ..
 | 
| 923 | 46 | |
| 47 | ||
| 11979 | 48 | subsection {* Additional concrete syntax *}
 | 
| 2261 | 49 | |
| 923 | 50 | syntax | 
| 11979 | 51 |   range         :: "('a => 'b) => 'b set"             -- "of function"
 | 
| 923 | 52 | |
| 11979 | 53 |   "op ~:"       :: "'a => 'a set => bool"                 ("op ~:")  -- "non-membership"
 | 
| 54 |   "op ~:"       :: "'a => 'a set => bool"                 ("(_/ ~: _)" [50, 51] 50)
 | |
| 7238 
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
 wenzelm parents: 
5931diff
changeset | 55 | |
| 11979 | 56 |   "@Finset"     :: "args => 'a set"                       ("{(_)}")
 | 
| 57 |   "@Coll"       :: "pttrn => bool => 'a set"              ("(1{_./ _})")
 | |
| 58 |   "@SetCompr"   :: "'a => idts => bool => 'a set"         ("(1{_ |/_./ _})")
 | |
| 15535 | 59 |   "@Collect"    :: "idt => 'a set => bool => 'a set"      ("(1{_ :/ _./ _})")
 | 
| 11979 | 60 |   "@INTER1"     :: "pttrns => 'b set => 'b set"           ("(3INT _./ _)" 10)
 | 
| 61 |   "@UNION1"     :: "pttrns => 'b set => 'b set"           ("(3UN _./ _)" 10)
 | |
| 62 |   "@INTER"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3INT _:_./ _)" 10)
 | |
| 63 |   "@UNION"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3UN _:_./ _)" 10)
 | |
| 923 | 64 | |
| 11979 | 65 |   "_Ball"       :: "pttrn => 'a set => bool => bool"      ("(3ALL _:_./ _)" [0, 0, 10] 10)
 | 
| 66 |   "_Bex"        :: "pttrn => 'a set => bool => bool"      ("(3EX _:_./ _)" [0, 0, 10] 10)
 | |
| 923 | 67 | |
| 7238 
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
 wenzelm parents: 
5931diff
changeset | 68 | syntax (HOL) | 
| 11979 | 69 |   "_Ball"       :: "pttrn => 'a set => bool => bool"      ("(3! _:_./ _)" [0, 0, 10] 10)
 | 
| 70 |   "_Bex"        :: "pttrn => 'a set => bool => bool"      ("(3? _:_./ _)" [0, 0, 10] 10)
 | |
| 923 | 71 | |
| 72 | translations | |
| 10832 | 73 | "range f" == "f`UNIV" | 
| 923 | 74 | "x ~: y" == "~ (x : y)" | 
| 75 |   "{x, xs}"     == "insert x {xs}"
 | |
| 76 |   "{x}"         == "insert x {}"
 | |
| 13764 | 77 |   "{x. P}"      == "Collect (%x. P)"
 | 
| 15535 | 78 |   "{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 | 79 | "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 | 80 | "UN x. B" == "UNION UNIV (%x. B)" | 
| 13858 | 81 | "UN x. B" == "UN x:UNIV. B" | 
| 7238 
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
 wenzelm parents: 
5931diff
changeset | 82 | "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 | 83 | "INT x. B" == "INTER UNIV (%x. B)" | 
| 13858 | 84 | "INT x. B" == "INT x:UNIV. B" | 
| 13764 | 85 | "UN x:A. B" == "UNION A (%x. B)" | 
| 86 | "INT x:A. B" == "INTER A (%x. B)" | |
| 87 | "ALL x:A. P" == "Ball A (%x. P)" | |
| 88 | "EX x:A. P" == "Bex A (%x. P)" | |
| 923 | 89 | |
| 12633 | 90 | syntax (output) | 
| 11979 | 91 |   "_setle"      :: "'a set => 'a set => bool"             ("op <=")
 | 
| 92 |   "_setle"      :: "'a set => 'a set => bool"             ("(_/ <= _)" [50, 51] 50)
 | |
| 93 |   "_setless"    :: "'a set => 'a set => bool"             ("op <")
 | |
| 94 |   "_setless"    :: "'a set => 'a set => bool"             ("(_/ < _)" [50, 51] 50)
 | |
| 923 | 95 | |
| 12114 
a8e860c86252
eliminated old "symbols" syntax, use "xsymbols" instead;
 wenzelm parents: 
12023diff
changeset | 96 | syntax (xsymbols) | 
| 11979 | 97 |   "_setle"      :: "'a set => 'a set => bool"             ("op \<subseteq>")
 | 
| 98 |   "_setle"      :: "'a set => 'a set => bool"             ("(_/ \<subseteq> _)" [50, 51] 50)
 | |
| 99 |   "_setless"    :: "'a set => 'a set => bool"             ("op \<subset>")
 | |
| 100 |   "_setless"    :: "'a set => 'a set => bool"             ("(_/ \<subset> _)" [50, 51] 50)
 | |
| 101 | "op Int" :: "'a set => 'a set => 'a set" (infixl "\<inter>" 70) | |
| 102 | "op Un" :: "'a set => 'a set => 'a set" (infixl "\<union>" 65) | |
| 103 |   "op :"        :: "'a => 'a set => bool"                 ("op \<in>")
 | |
| 104 |   "op :"        :: "'a => 'a set => bool"                 ("(_/ \<in> _)" [50, 51] 50)
 | |
| 105 |   "op ~:"       :: "'a => 'a set => bool"                 ("op \<notin>")
 | |
| 106 |   "op ~:"       :: "'a => 'a set => bool"                 ("(_/ \<notin> _)" [50, 51] 50)
 | |
| 14381 
1189a8212a12
Modified UN and INT xsymbol syntax: made index subscript
 nipkow parents: 
14335diff
changeset | 107 |   Union         :: "'a set set => 'a set"                 ("\<Union>_" [90] 90)
 | 
| 
1189a8212a12
Modified UN and INT xsymbol syntax: made index subscript
 nipkow parents: 
14335diff
changeset | 108 |   Inter         :: "'a set set => 'a set"                 ("\<Inter>_" [90] 90)
 | 
| 
1189a8212a12
Modified UN and INT xsymbol syntax: made index subscript
 nipkow parents: 
14335diff
changeset | 109 |   "_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 | 110 |   "_Bex"        :: "pttrn => 'a set => bool => bool"      ("(3\<exists>_\<in>_./ _)" [0, 0, 10] 10)
 | 
| 
1189a8212a12
Modified UN and INT xsymbol syntax: made index subscript
 nipkow parents: 
14335diff
changeset | 111 | |
| 14565 | 112 | syntax (HTML output) | 
| 113 |   "_setle"      :: "'a set => 'a set => bool"             ("op \<subseteq>")
 | |
| 114 |   "_setle"      :: "'a set => 'a set => bool"             ("(_/ \<subseteq> _)" [50, 51] 50)
 | |
| 115 |   "_setless"    :: "'a set => 'a set => bool"             ("op \<subset>")
 | |
| 116 |   "_setless"    :: "'a set => 'a set => bool"             ("(_/ \<subset> _)" [50, 51] 50)
 | |
| 117 | "op Int" :: "'a set => 'a set => 'a set" (infixl "\<inter>" 70) | |
| 118 | "op Un" :: "'a set => 'a set => 'a set" (infixl "\<union>" 65) | |
| 119 |   "op :"        :: "'a => 'a set => bool"                 ("op \<in>")
 | |
| 120 |   "op :"        :: "'a => 'a set => bool"                 ("(_/ \<in> _)" [50, 51] 50)
 | |
| 121 |   "op ~:"       :: "'a => 'a set => bool"                 ("op \<notin>")
 | |
| 122 |   "op ~:"       :: "'a => 'a set => bool"                 ("(_/ \<notin> _)" [50, 51] 50)
 | |
| 123 |   "_Ball"       :: "pttrn => 'a set => bool => bool"      ("(3\<forall>_\<in>_./ _)" [0, 0, 10] 10)
 | |
| 124 |   "_Bex"        :: "pttrn => 'a set => bool => bool"      ("(3\<exists>_\<in>_./ _)" [0, 0, 10] 10)
 | |
| 125 | ||
| 15120 | 126 | syntax (xsymbols) | 
| 15535 | 127 |   "@Collect"    :: "idt => 'a set => bool => 'a set"      ("(1{_ \<in>/ _./ _})")
 | 
| 11979 | 128 |   "@UNION1"     :: "pttrns => 'b set => 'b set"           ("(3\<Union>_./ _)" 10)
 | 
| 129 |   "@INTER1"     :: "pttrns => 'b set => 'b set"           ("(3\<Inter>_./ _)" 10)
 | |
| 130 |   "@UNION"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Union>_\<in>_./ _)" 10)
 | |
| 131 |   "@INTER"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Inter>_\<in>_./ _)" 10)
 | |
| 15120 | 132 | (* | 
| 14381 
1189a8212a12
Modified UN and INT xsymbol syntax: made index subscript
 nipkow parents: 
14335diff
changeset | 133 | syntax (xsymbols) | 
| 14845 | 134 |   "@UNION1"     :: "pttrns => 'b set => 'b set"           ("(3\<Union>(00\<^bsub>_\<^esub>)/ _)" 10)
 | 
| 135 |   "@INTER1"     :: "pttrns => 'b set => 'b set"           ("(3\<Inter>(00\<^bsub>_\<^esub>)/ _)" 10)
 | |
| 136 |   "@UNION"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Union>(00\<^bsub>_\<in>_\<^esub>)/ _)" 10)
 | |
| 137 |   "@INTER"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Inter>(00\<^bsub>_\<in>_\<^esub>)/ _)" 10)
 | |
| 15120 | 138 | *) | 
| 139 | syntax (latex output) | |
| 140 |   "@UNION1"     :: "pttrns => 'b set => 'b set"           ("(3\<Union>(00\<^bsub>_\<^esub>)/ _)" 10)
 | |
| 141 |   "@INTER1"     :: "pttrns => 'b set => 'b set"           ("(3\<Inter>(00\<^bsub>_\<^esub>)/ _)" 10)
 | |
| 142 |   "@UNION"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Union>(00\<^bsub>_\<in>_\<^esub>)/ _)" 10)
 | |
| 143 |   "@INTER"      :: "pttrn => 'a set => 'b set => 'b set"  ("(3\<Inter>(00\<^bsub>_\<in>_\<^esub>)/ _)" 10)
 | |
| 144 | ||
| 145 | text{* Note the difference between ordinary xsymbol syntax of indexed
 | |
| 146 | unions and intersections (e.g.\ @{text"\<Union>a\<^isub>1\<in>A\<^isub>1. B"})
 | |
| 147 | and their \LaTeX\ rendition: @{term"\<Union>a\<^isub>1\<in>A\<^isub>1. B"}. The
 | |
| 148 | former does not make the index expression a subscript of the | |
| 149 | union/intersection symbol because this leads to problems with nested | |
| 150 | subscripts in Proof General. *} | |
| 2261 | 151 | |
| 14565 | 152 | |
| 2412 | 153 | translations | 
| 11979 | 154 | "op \<subseteq>" => "op <= :: _ set => _ set => bool" | 
| 155 | "op \<subset>" => "op < :: _ set => _ set => bool" | |
| 2261 | 156 | |
| 11979 | 157 | typed_print_translation {*
 | 
| 158 | let | |
| 159 |     fun le_tr' _ (Type ("fun", (Type ("set", _) :: _))) ts =
 | |
| 160 | list_comb (Syntax.const "_setle", ts) | |
| 161 | | le_tr' _ _ _ = raise Match; | |
| 162 | ||
| 163 |     fun less_tr' _ (Type ("fun", (Type ("set", _) :: _))) ts =
 | |
| 164 | list_comb (Syntax.const "_setless", ts) | |
| 165 | | less_tr' _ _ _ = raise Match; | |
| 166 |   in [("op <=", le_tr'), ("op <", less_tr')] end
 | |
| 167 | *} | |
| 2261 | 168 | |
| 14804 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 169 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 170 | subsubsection "Bounded quantifiers" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 171 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 172 | syntax | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 173 |   "_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 | 174 |   "_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 | 175 |   "_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 | 176 |   "_setleEx"    :: "[idt, 'a, bool] => bool"  ("(3EX _<=_./ _)" [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 177 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 178 | syntax (xsymbols) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 179 |   "_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 | 180 |   "_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 | 181 |   "_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 | 182 |   "_setleEx"    :: "[idt, 'a, bool] => bool"   ("(3\<exists>_\<subseteq>_./ _)" [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 183 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 184 | syntax (HOL) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 185 |   "_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 | 186 |   "_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 | 187 |   "_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 | 188 |   "_setleEx"    :: "[idt, 'a, bool] => bool"   ("(3? _<=_./ _)" [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 189 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 190 | syntax (HTML output) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 191 |   "_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 | 192 |   "_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 | 193 |   "_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 | 194 |   "_setleEx"    :: "[idt, 'a, bool] => bool"   ("(3\<exists>_\<subseteq>_./ _)" [0, 0, 10] 10)
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 195 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 196 | translations | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 197 | "\<forall>A\<subset>B. P" => "ALL A. A \<subset> B --> P" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 198 | "\<exists>A\<subset>B. P" => "EX A. A \<subset> B & P" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 199 | "\<forall>A\<subseteq>B. P" => "ALL A. A \<subseteq> B --> P" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 200 | "\<exists>A\<subseteq>B. P" => "EX A. A \<subseteq> B & P" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 201 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 202 | print_translation {*
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 203 | let | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 204 | fun | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 205 |     all_tr' [Const ("_bound",_) $ Free (v,Type(T,_)), 
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 206 |              Const("op -->",_) $ (Const ("op <",_) $ (Const ("_bound",_) $ Free (v',_)) $ n ) $ P] = 
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 207 | (if v=v' andalso T="set" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 208 | 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 | 209 | else raise Match) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 210 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 211 |   | all_tr' [Const ("_bound",_) $ Free (v,Type(T,_)), 
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 212 |              Const("op -->",_) $ (Const ("op <=",_) $ (Const ("_bound",_) $ Free (v',_)) $ n ) $ P] = 
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 213 | (if v=v' andalso T="set" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 214 | 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 | 215 | else raise Match); | 
| 
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 | fun | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 218 |     ex_tr' [Const ("_bound",_) $ Free (v,Type(T,_)), 
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 219 |             Const("op &",_) $ (Const ("op <",_) $ (Const ("_bound",_) $ Free (v',_)) $ n ) $ P] = 
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 220 | (if v=v' andalso T="set" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 221 | 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 | 222 | else raise Match) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 223 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 224 |   | ex_tr' [Const ("_bound",_) $ Free (v,Type(T,_)), 
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 225 |             Const("op &",_) $ (Const ("op <=",_) $ (Const ("_bound",_) $ Free (v',_)) $ n ) $ P] = 
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 226 | (if v=v' andalso T="set" | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 227 | 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 | 228 | else raise Match) | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 229 | in | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 230 | [("ALL ", all_tr'), ("EX ", ex_tr')]
 | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 231 | end | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 232 | *} | 
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 233 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 234 | |
| 
8de39d3e8eb6
Corrected printer bug for bounded quantifiers Q x<=y. P
 nipkow parents: 
14752diff
changeset | 235 | |
| 11979 | 236 | text {*
 | 
| 237 |   \medskip Translate between @{text "{e | x1...xn. P}"} and @{text
 | |
| 238 |   "{u. EX x1..xn. u = e & P}"}; @{text "{y. EX x1..xn. y = e & P}"} is
 | |
| 239 |   only translated if @{text "[0..n] subset bvs(e)"}.
 | |
| 240 | *} | |
| 241 | ||
| 242 | parse_translation {*
 | |
| 243 | let | |
| 244 |     val ex_tr = snd (mk_binder_tr ("EX ", "Ex"));
 | |
| 3947 | 245 | |
| 11979 | 246 |     fun nvars (Const ("_idts", _) $ _ $ idts) = nvars idts + 1
 | 
| 247 | | nvars _ = 1; | |
| 248 | ||
| 249 | fun setcompr_tr [e, idts, b] = | |
| 250 | let | |
| 251 | val eq = Syntax.const "op =" $ Bound (nvars idts) $ e; | |
| 252 | val P = Syntax.const "op &" $ eq $ b; | |
| 253 | val exP = ex_tr [idts, P]; | |
| 254 |       in Syntax.const "Collect" $ Abs ("", dummyT, exP) end;
 | |
| 255 | ||
| 256 |   in [("@SetCompr", setcompr_tr)] end;
 | |
| 257 | *} | |
| 923 | 258 | |
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 259 | (* To avoid eta-contraction of body: *) | 
| 11979 | 260 | print_translation {*
 | 
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 261 | let | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 262 | fun btr' syn [A,Abs abs] = | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 263 | let val (x,t) = atomic_abs_tr' abs | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 264 | in Syntax.const syn $ x $ A $ t end | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 265 | in | 
| 13858 | 266 | [("Ball", btr' "_Ball"),("Bex", btr' "_Bex"),
 | 
| 267 |  ("UNION", btr' "@UNION"),("INTER", btr' "@INTER")]
 | |
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 268 | end | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 269 | *} | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 270 | |
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 271 | print_translation {*
 | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 272 | let | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 273 |   val ex_tr' = snd (mk_binder_tr' ("Ex", "DUMMY"));
 | 
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 274 | |
| 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 275 | fun setcompr_tr' [Abs (abs as (_, _, P))] = | 
| 
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 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 | 278 |         | 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 | 279 | 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 | 280 | ((0 upto (n - 1)) subset add_loose_bnos (e, 0, [])) | 
| 13764 | 281 | | check _ = false | 
| 923 | 282 | |
| 11979 | 283 | fun tr' (_ $ abs) = | 
| 284 | let val _ $ idts $ (_ $ (_ $ _ $ e) $ Q) = ex_tr' [abs] | |
| 285 | in Syntax.const "@SetCompr" $ e $ idts $ Q end; | |
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 286 | in if check (P, 0) then tr' P | 
| 15535 | 287 | else let val (x as _ $ Free(xN,_), t) = atomic_abs_tr' abs | 
| 288 | val M = Syntax.const "@Coll" $ x $ t | |
| 289 | in case t of | |
| 290 |                  Const("op &",_)
 | |
| 291 |                    $ (Const("op :",_) $ (Const("_bound",_) $ Free(yN,_)) $ A)
 | |
| 292 | $ P => | |
| 293 | if xN=yN then Syntax.const "@Collect" $ x $ A $ P else M | |
| 294 | | _ => M | |
| 295 | end | |
| 13763 
f94b569cd610
added print translations tha avoid eta contraction for important binders.
 nipkow parents: 
13653diff
changeset | 296 | end; | 
| 11979 | 297 |   in [("Collect", setcompr_tr')] end;
 | 
| 298 | *} | |
| 299 | ||
| 300 | ||
| 301 | subsection {* Rules and definitions *}
 | |
| 302 | ||
| 303 | text {* Isomorphisms between predicates and sets. *}
 | |
| 923 | 304 | |
| 11979 | 305 | axioms | 
| 306 |   mem_Collect_eq [iff]: "(a : {x. P(x)}) = P(a)"
 | |
| 307 |   Collect_mem_eq [simp]: "{x. x:A} = A"
 | |
| 308 | ||
| 309 | defs | |
| 310 | Ball_def: "Ball A P == ALL x. x:A --> P(x)" | |
| 311 | Bex_def: "Bex A P == EX x. x:A & P(x)" | |
| 312 | ||
| 313 | defs (overloaded) | |
| 314 | subset_def: "A <= B == ALL x:A. x:B" | |
| 315 | psubset_def: "A < B == (A::'a set) <= B & ~ A=B" | |
| 316 |   Compl_def:    "- A            == {x. ~x:A}"
 | |
| 12257 | 317 |   set_diff_def: "A - B          == {x. x:A & ~x:B}"
 | 
| 923 | 318 | |
| 319 | defs | |
| 11979 | 320 |   Un_def:       "A Un B         == {x. x:A | x:B}"
 | 
| 321 |   Int_def:      "A Int B        == {x. x:A & x:B}"
 | |
| 322 |   INTER_def:    "INTER A B      == {y. ALL x:A. y: B(x)}"
 | |
| 323 |   UNION_def:    "UNION A B      == {y. EX x:A. y: B(x)}"
 | |
| 324 | Inter_def: "Inter S == (INT x:S. x)" | |
| 325 | Union_def: "Union S == (UN x:S. x)" | |
| 326 |   Pow_def:      "Pow A          == {B. B <= A}"
 | |
| 327 |   empty_def:    "{}             == {x. False}"
 | |
| 328 |   UNIV_def:     "UNIV           == {x. True}"
 | |
| 329 |   insert_def:   "insert a B     == {x. x=a} Un B"
 | |
| 330 |   image_def:    "f`A            == {y. EX x:A. y = f(x)}"
 | |
| 331 | ||
| 332 | ||
| 333 | subsection {* Lemmas and proof tool setup *}
 | |
| 334 | ||
| 335 | subsubsection {* Relating predicates and sets *}
 | |
| 336 | ||
| 12257 | 337 | lemma CollectI: "P(a) ==> a : {x. P(x)}"
 | 
| 11979 | 338 | by simp | 
| 339 | ||
| 340 | lemma CollectD: "a : {x. P(x)} ==> P(a)"
 | |
| 341 | by simp | |
| 342 | ||
| 343 | lemma Collect_cong: "(!!x. P x = Q x) ==> {x. P(x)} = {x. Q(x)}"
 | |
| 344 | by simp | |
| 345 | ||
| 12257 | 346 | lemmas CollectE = CollectD [elim_format] | 
| 11979 | 347 | |
| 348 | ||
| 349 | subsubsection {* Bounded quantifiers *}
 | |
| 350 | ||
| 351 | lemma ballI [intro!]: "(!!x. x:A ==> P x) ==> ALL x:A. P x" | |
| 352 | by (simp add: Ball_def) | |
| 353 | ||
| 354 | lemmas strip = impI allI ballI | |
| 355 | ||
| 356 | lemma bspec [dest?]: "ALL x:A. P x ==> x:A ==> P x" | |
| 357 | by (simp add: Ball_def) | |
| 358 | ||
| 359 | lemma ballE [elim]: "ALL x:A. P x ==> (P x ==> Q) ==> (x ~: A ==> Q) ==> Q" | |
| 360 | by (unfold Ball_def) blast | |
| 14098 | 361 | ML {* bind_thm("rev_ballE",permute_prems 1 1 (thm "ballE")) *}
 | 
| 11979 | 362 | |
| 363 | text {*
 | |
| 364 |   \medskip This tactic takes assumptions @{prop "ALL x:A. P x"} and
 | |
| 365 |   @{prop "a:A"}; creates assumption @{prop "P a"}.
 | |
| 366 | *} | |
| 367 | ||
| 368 | ML {*
 | |
| 369 | local val ballE = thm "ballE" | |
| 370 | in fun ball_tac i = etac ballE i THEN contr_tac (i + 1) end; | |
| 371 | *} | |
| 372 | ||
| 373 | text {*
 | |
| 374 | Gives better instantiation for bound: | |
| 375 | *} | |
| 376 | ||
| 377 | ML_setup {*
 | |
| 378 |   claset_ref() := claset() addbefore ("bspec", datac (thm "bspec") 1);
 | |
| 379 | *} | |
| 380 | ||
| 381 | lemma bexI [intro]: "P x ==> x:A ==> EX x:A. P x" | |
| 382 |   -- {* Normally the best argument order: @{prop "P x"} constrains the
 | |
| 383 |     choice of @{prop "x:A"}. *}
 | |
| 384 | by (unfold Bex_def) blast | |
| 385 | ||
| 13113 | 386 | lemma rev_bexI [intro?]: "x:A ==> P x ==> EX x:A. P x" | 
| 11979 | 387 |   -- {* The best argument order when there is only one @{prop "x:A"}. *}
 | 
| 388 | by (unfold Bex_def) blast | |
| 389 | ||
| 390 | lemma bexCI: "(ALL x:A. ~P x ==> P a) ==> a:A ==> EX x:A. P x" | |
| 391 | by (unfold Bex_def) blast | |
| 392 | ||
| 393 | lemma bexE [elim!]: "EX x:A. P x ==> (!!x. x:A ==> P x ==> Q) ==> Q" | |
| 394 | by (unfold Bex_def) blast | |
| 395 | ||
| 396 | lemma ball_triv [simp]: "(ALL x:A. P) = ((EX x. x:A) --> P)" | |
| 397 |   -- {* Trival rewrite rule. *}
 | |
| 398 | by (simp add: Ball_def) | |
| 399 | ||
| 400 | lemma bex_triv [simp]: "(EX x:A. P) = ((EX x. x:A) & P)" | |
| 401 |   -- {* Dual form for existentials. *}
 | |
| 402 | by (simp add: Bex_def) | |
| 403 | ||
| 404 | lemma bex_triv_one_point1 [simp]: "(EX x:A. x = a) = (a:A)" | |
| 405 | by blast | |
| 406 | ||
| 407 | lemma bex_triv_one_point2 [simp]: "(EX x:A. a = x) = (a:A)" | |
| 408 | by blast | |
| 409 | ||
| 410 | lemma bex_one_point1 [simp]: "(EX x:A. x = a & P x) = (a:A & P a)" | |
| 411 | by blast | |
| 412 | ||
| 413 | lemma bex_one_point2 [simp]: "(EX x:A. a = x & P x) = (a:A & P a)" | |
| 414 | by blast | |
| 415 | ||
| 416 | lemma ball_one_point1 [simp]: "(ALL x:A. x = a --> P x) = (a:A --> P a)" | |
| 417 | by blast | |
| 418 | ||
| 419 | lemma ball_one_point2 [simp]: "(ALL x:A. a = x --> P x) = (a:A --> P a)" | |
| 420 | by blast | |
| 421 | ||
| 422 | ML_setup {*
 | |
| 13462 | 423 | local | 
| 11979 | 424 | val Ball_def = thm "Ball_def"; | 
| 425 | val Bex_def = thm "Bex_def"; | |
| 426 | ||
| 427 | val prove_bex_tac = | |
| 428 | rewrite_goals_tac [Bex_def] THEN Quantifier1.prove_one_point_ex_tac; | |
| 429 | val rearrange_bex = Quantifier1.rearrange_bex prove_bex_tac; | |
| 430 | ||
| 431 | val prove_ball_tac = | |
| 432 | rewrite_goals_tac [Ball_def] THEN Quantifier1.prove_one_point_all_tac; | |
| 433 | val rearrange_ball = Quantifier1.rearrange_ball prove_ball_tac; | |
| 434 | in | |
| 13462 | 435 | val defBEX_regroup = Simplifier.simproc (Theory.sign_of (the_context ())) | 
| 436 | "defined BEX" ["EX x:A. P x & Q x"] rearrange_bex; | |
| 437 | val defBALL_regroup = Simplifier.simproc (Theory.sign_of (the_context ())) | |
| 438 | "defined BALL" ["ALL x:A. P x --> Q x"] rearrange_ball; | |
| 11979 | 439 | end; | 
| 13462 | 440 | |
| 441 | Addsimprocs [defBALL_regroup, defBEX_regroup]; | |
| 11979 | 442 | *} | 
| 443 | ||
| 444 | ||
| 445 | subsubsection {* Congruence rules *}
 | |
| 446 | ||
| 16636 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 447 | lemma ball_cong: | 
| 11979 | 448 | "A = B ==> (!!x. x:B ==> P x = Q x) ==> | 
| 449 | (ALL x:A. P x) = (ALL x:B. Q x)" | |
| 450 | by (simp add: Ball_def) | |
| 451 | ||
| 16636 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 452 | lemma strong_ball_cong [cong]: | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 453 | "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 | 454 | (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 | 455 | 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 | 456 | |
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 457 | lemma bex_cong: | 
| 11979 | 458 | "A = B ==> (!!x. x:B ==> P x = Q x) ==> | 
| 459 | (EX x:A. P x) = (EX x:B. Q x)" | |
| 460 | by (simp add: Bex_def cong: conj_cong) | |
| 1273 | 461 | |
| 16636 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 462 | lemma strong_bex_cong [cong]: | 
| 
1ed737a98198
Added strong_ball_cong and strong_bex_cong (these are now the standard
 berghofe parents: 
15950diff
changeset | 463 | "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 | 464 | (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 | 465 | 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 | 466 | |
| 7238 
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
 wenzelm parents: 
5931diff
changeset | 467 | |
| 11979 | 468 | subsubsection {* Subsets *}
 | 
| 469 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 470 | lemma subsetI [intro!]: "(!!x. x:A ==> x:B) ==> A \<subseteq> B" | 
| 11979 | 471 | by (simp add: subset_def) | 
| 472 | ||
| 473 | text {*
 | |
| 474 |   \medskip Map the type @{text "'a set => anything"} to just @{typ
 | |
| 475 |   'a}; for overloading constants whose first argument has type @{typ
 | |
| 476 | "'a set"}. | |
| 477 | *} | |
| 478 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 479 | lemma subsetD [elim]: "A \<subseteq> B ==> c \<in> A ==> c \<in> B" | 
| 11979 | 480 |   -- {* Rule in Modus Ponens style. *}
 | 
| 481 | by (unfold subset_def) blast | |
| 482 | ||
| 483 | declare subsetD [intro?] -- FIXME | |
| 484 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 485 | lemma rev_subsetD: "c \<in> A ==> A \<subseteq> B ==> c \<in> B" | 
| 11979 | 486 |   -- {* The same, with reversed premises for use with @{text erule} --
 | 
| 487 |       cf @{text rev_mp}. *}
 | |
| 488 | by (rule subsetD) | |
| 489 | ||
| 490 | declare rev_subsetD [intro?] -- FIXME | |
| 491 | ||
| 492 | text {*
 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 493 |   \medskip Converts @{prop "A \<subseteq> B"} to @{prop "x \<in> A ==> x \<in> B"}.
 | 
| 11979 | 494 | *} | 
| 495 | ||
| 496 | ML {*
 | |
| 497 | local val rev_subsetD = thm "rev_subsetD" | |
| 498 | in fun impOfSubs th = th RSN (2, rev_subsetD) end; | |
| 499 | *} | |
| 500 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 501 | lemma subsetCE [elim]: "A \<subseteq> B ==> (c \<notin> A ==> P) ==> (c \<in> B ==> P) ==> P" | 
| 11979 | 502 |   -- {* Classical elimination rule. *}
 | 
| 503 | by (unfold subset_def) blast | |
| 504 | ||
| 505 | text {*
 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 506 |   \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 | 507 |   creates the assumption @{prop "c \<in> B"}.
 | 
| 11979 | 508 | *} | 
| 509 | ||
| 510 | ML {*
 | |
| 511 | local val subsetCE = thm "subsetCE" | |
| 512 | in fun set_mp_tac i = etac subsetCE i THEN mp_tac i end; | |
| 513 | *} | |
| 514 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 515 | lemma contra_subsetD: "A \<subseteq> B ==> c \<notin> B ==> c \<notin> A" | 
| 11979 | 516 | by blast | 
| 517 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 518 | lemma subset_refl: "A \<subseteq> A" | 
| 11979 | 519 | by fast | 
| 520 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 521 | lemma subset_trans: "A \<subseteq> B ==> B \<subseteq> C ==> A \<subseteq> C" | 
| 11979 | 522 | by blast | 
| 923 | 523 | |
| 2261 | 524 | |
| 11979 | 525 | subsubsection {* Equality *}
 | 
| 526 | ||
| 13865 | 527 | lemma set_ext: assumes prem: "(!!x. (x:A) = (x:B))" shows "A = B" | 
| 528 | apply (rule prem [THEN ext, THEN arg_cong, THEN box_equals]) | |
| 529 | apply (rule Collect_mem_eq) | |
| 530 | apply (rule Collect_mem_eq) | |
| 531 | done | |
| 532 | ||
| 15554 | 533 | (* Due to Brian Huffman *) | 
| 534 | lemma expand_set_eq: "(A = B) = (ALL x. (x:A) = (x:B))" | |
| 535 | by(auto intro:set_ext) | |
| 536 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 537 | lemma subset_antisym [intro!]: "A \<subseteq> B ==> B \<subseteq> A ==> A = B" | 
| 11979 | 538 |   -- {* Anti-symmetry of the subset relation. *}
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 539 | by (rules intro: set_ext subsetD) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 540 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 541 | lemmas equalityI [intro!] = subset_antisym | 
| 11979 | 542 | |
| 543 | text {*
 | |
| 544 | \medskip Equality rules from ZF set theory -- are they appropriate | |
| 545 | here? | |
| 546 | *} | |
| 547 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 548 | lemma equalityD1: "A = B ==> A \<subseteq> B" | 
| 11979 | 549 | by (simp add: subset_refl) | 
| 550 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 551 | lemma equalityD2: "A = B ==> B \<subseteq> A" | 
| 11979 | 552 | by (simp add: subset_refl) | 
| 553 | ||
| 554 | text {*
 | |
| 555 |   \medskip Be careful when adding this to the claset as @{text
 | |
| 556 |   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 | 557 |   \<subseteq> A"} and @{prop "A \<subseteq> {}"} and then back to @{prop "A = {}"}!
 | 
| 11979 | 558 | *} | 
| 559 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 560 | lemma equalityE: "A = B ==> (A \<subseteq> B ==> B \<subseteq> A ==> P) ==> P" | 
| 11979 | 561 | by (simp add: subset_refl) | 
| 923 | 562 | |
| 11979 | 563 | lemma equalityCE [elim]: | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 564 | "A = B ==> (c \<in> A ==> c \<in> B ==> P) ==> (c \<notin> A ==> c \<notin> B ==> P) ==> P" | 
| 11979 | 565 | by blast | 
| 566 | ||
| 567 | text {*
 | |
| 568 | \medskip Lemma for creating induction formulae -- for "pattern | |
| 569 |   matching" on @{text p}.  To make the induction hypotheses usable,
 | |
| 570 |   apply @{text spec} or @{text bspec} to put universal quantifiers over the free
 | |
| 571 |   variables in @{text p}.
 | |
| 572 | *} | |
| 573 | ||
| 574 | lemma setup_induction: "p:A ==> (!!z. z:A ==> p = z --> R) ==> R" | |
| 575 | by simp | |
| 923 | 576 | |
| 11979 | 577 | lemma eqset_imp_iff: "A = B ==> (x : A) = (x : B)" | 
| 578 | by simp | |
| 579 | ||
| 13865 | 580 | lemma eqelem_imp_iff: "x = y ==> (x : A) = (y : A)" | 
| 581 | by simp | |
| 582 | ||
| 11979 | 583 | |
| 584 | subsubsection {* The universal set -- UNIV *}
 | |
| 585 | ||
| 586 | lemma UNIV_I [simp]: "x : UNIV" | |
| 587 | by (simp add: UNIV_def) | |
| 588 | ||
| 589 | declare UNIV_I [intro]  -- {* unsafe makes it less likely to cause problems *}
 | |
| 590 | ||
| 591 | lemma UNIV_witness [intro?]: "EX x. x : UNIV" | |
| 592 | by simp | |
| 593 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 594 | lemma subset_UNIV: "A \<subseteq> UNIV" | 
| 11979 | 595 | by (rule subsetI) (rule UNIV_I) | 
| 2388 | 596 | |
| 11979 | 597 | text {*
 | 
| 598 |   \medskip Eta-contracting these two rules (to remove @{text P})
 | |
| 599 | causes them to be ignored because of their interaction with | |
| 600 | congruence rules. | |
| 601 | *} | |
| 602 | ||
| 603 | lemma ball_UNIV [simp]: "Ball UNIV P = All P" | |
| 604 | by (simp add: Ball_def) | |
| 605 | ||
| 606 | lemma bex_UNIV [simp]: "Bex UNIV P = Ex P" | |
| 607 | by (simp add: Bex_def) | |
| 608 | ||
| 609 | ||
| 610 | subsubsection {* The empty set *}
 | |
| 611 | ||
| 612 | lemma empty_iff [simp]: "(c : {}) = False"
 | |
| 613 | by (simp add: empty_def) | |
| 614 | ||
| 615 | lemma emptyE [elim!]: "a : {} ==> P"
 | |
| 616 | by simp | |
| 617 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 618 | lemma empty_subsetI [iff]: "{} \<subseteq> A"
 | 
| 11979 | 619 |     -- {* One effect is to delete the ASSUMPTION @{prop "{} <= A"} *}
 | 
| 620 | by blast | |
| 621 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 622 | lemma equals0I: "(!!y. y \<in> A ==> False) ==> A = {}"
 | 
| 11979 | 623 | by blast | 
| 2388 | 624 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 625 | lemma equals0D: "A = {} ==> a \<notin> A"
 | 
| 11979 | 626 |     -- {* Use for reasoning about disjointness: @{prop "A Int B = {}"} *}
 | 
| 627 | by blast | |
| 628 | ||
| 629 | lemma ball_empty [simp]: "Ball {} P = True"
 | |
| 630 | by (simp add: Ball_def) | |
| 631 | ||
| 632 | lemma bex_empty [simp]: "Bex {} P = False"
 | |
| 633 | by (simp add: Bex_def) | |
| 634 | ||
| 635 | lemma UNIV_not_empty [iff]: "UNIV ~= {}"
 | |
| 636 | by (blast elim: equalityE) | |
| 637 | ||
| 638 | ||
| 12023 | 639 | subsubsection {* The Powerset operator -- Pow *}
 | 
| 11979 | 640 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 641 | lemma Pow_iff [iff]: "(A \<in> Pow B) = (A \<subseteq> B)" | 
| 11979 | 642 | by (simp add: Pow_def) | 
| 643 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 644 | lemma PowI: "A \<subseteq> B ==> A \<in> Pow B" | 
| 11979 | 645 | by (simp add: Pow_def) | 
| 646 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 647 | lemma PowD: "A \<in> Pow B ==> A \<subseteq> B" | 
| 11979 | 648 | by (simp add: Pow_def) | 
| 649 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 650 | lemma Pow_bottom: "{} \<in> Pow B"
 | 
| 11979 | 651 | by simp | 
| 652 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 653 | lemma Pow_top: "A \<in> Pow A" | 
| 11979 | 654 | by (simp add: subset_refl) | 
| 2684 | 655 | |
| 2388 | 656 | |
| 11979 | 657 | subsubsection {* Set complement *}
 | 
| 658 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 659 | lemma Compl_iff [simp]: "(c \<in> -A) = (c \<notin> A)" | 
| 11979 | 660 | by (unfold Compl_def) blast | 
| 661 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 662 | lemma ComplI [intro!]: "(c \<in> A ==> False) ==> c \<in> -A" | 
| 11979 | 663 | by (unfold Compl_def) blast | 
| 664 | ||
| 665 | text {*
 | |
| 666 | \medskip This form, with negated conclusion, works well with the | |
| 667 | Classical prover. Negated assumptions behave like formulae on the | |
| 668 | right side of the notional turnstile ... *} | |
| 669 | ||
| 670 | lemma ComplD: "c : -A ==> c~:A" | |
| 671 | by (unfold Compl_def) blast | |
| 672 | ||
| 673 | lemmas ComplE [elim!] = ComplD [elim_format] | |
| 674 | ||
| 675 | ||
| 676 | subsubsection {* Binary union -- Un *}
 | |
| 923 | 677 | |
| 11979 | 678 | lemma Un_iff [simp]: "(c : A Un B) = (c:A | c:B)" | 
| 679 | by (unfold Un_def) blast | |
| 680 | ||
| 681 | lemma UnI1 [elim?]: "c:A ==> c : A Un B" | |
| 682 | by simp | |
| 683 | ||
| 684 | lemma UnI2 [elim?]: "c:B ==> c : A Un B" | |
| 685 | by simp | |
| 923 | 686 | |
| 11979 | 687 | text {*
 | 
| 688 |   \medskip Classical introduction rule: no commitment to @{prop A} vs
 | |
| 689 |   @{prop B}.
 | |
| 690 | *} | |
| 691 | ||
| 692 | lemma UnCI [intro!]: "(c~:B ==> c:A) ==> c : A Un B" | |
| 693 | by auto | |
| 694 | ||
| 695 | lemma UnE [elim!]: "c : A Un B ==> (c:A ==> P) ==> (c:B ==> P) ==> P" | |
| 696 | by (unfold Un_def) blast | |
| 697 | ||
| 698 | ||
| 12023 | 699 | subsubsection {* Binary intersection -- Int *}
 | 
| 923 | 700 | |
| 11979 | 701 | lemma Int_iff [simp]: "(c : A Int B) = (c:A & c:B)" | 
| 702 | by (unfold Int_def) blast | |
| 703 | ||
| 704 | lemma IntI [intro!]: "c:A ==> c:B ==> c : A Int B" | |
| 705 | by simp | |
| 706 | ||
| 707 | lemma IntD1: "c : A Int B ==> c:A" | |
| 708 | by simp | |
| 709 | ||
| 710 | lemma IntD2: "c : A Int B ==> c:B" | |
| 711 | by simp | |
| 712 | ||
| 713 | lemma IntE [elim!]: "c : A Int B ==> (c:A ==> c:B ==> P) ==> P" | |
| 714 | by simp | |
| 715 | ||
| 716 | ||
| 12023 | 717 | subsubsection {* Set difference *}
 | 
| 11979 | 718 | |
| 719 | lemma Diff_iff [simp]: "(c : A - B) = (c:A & c~:B)" | |
| 720 | by (unfold set_diff_def) blast | |
| 923 | 721 | |
| 11979 | 722 | lemma DiffI [intro!]: "c : A ==> c ~: B ==> c : A - B" | 
| 723 | by simp | |
| 724 | ||
| 725 | lemma DiffD1: "c : A - B ==> c : A" | |
| 726 | by simp | |
| 727 | ||
| 728 | lemma DiffD2: "c : A - B ==> c : B ==> P" | |
| 729 | by simp | |
| 730 | ||
| 731 | lemma DiffE [elim!]: "c : A - B ==> (c:A ==> c~:B ==> P) ==> P" | |
| 732 | by simp | |
| 733 | ||
| 734 | ||
| 735 | subsubsection {* Augmenting a set -- insert *}
 | |
| 736 | ||
| 737 | lemma insert_iff [simp]: "(a : insert b A) = (a = b | a:A)" | |
| 738 | by (unfold insert_def) blast | |
| 739 | ||
| 740 | lemma insertI1: "a : insert a B" | |
| 741 | by simp | |
| 742 | ||
| 743 | lemma insertI2: "a : B ==> a : insert b B" | |
| 744 | by simp | |
| 923 | 745 | |
| 11979 | 746 | lemma insertE [elim!]: "a : insert b A ==> (a = b ==> P) ==> (a:A ==> P) ==> P" | 
| 747 | by (unfold insert_def) blast | |
| 748 | ||
| 749 | lemma insertCI [intro!]: "(a~:B ==> a = b) ==> a: insert b B" | |
| 750 |   -- {* Classical introduction rule. *}
 | |
| 751 | by auto | |
| 752 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 753 | lemma subset_insert_iff: "(A \<subseteq> insert x B) = (if x:A then A - {x} \<subseteq> B else A \<subseteq> B)"
 | 
| 11979 | 754 | by auto | 
| 755 | ||
| 756 | ||
| 757 | subsubsection {* Singletons, using insert *}
 | |
| 758 | ||
| 759 | lemma singletonI [intro!]: "a : {a}"
 | |
| 760 |     -- {* Redundant? But unlike @{text insertCI}, it proves the subgoal immediately! *}
 | |
| 761 | by (rule insertI1) | |
| 762 | ||
| 763 | lemma singletonD: "b : {a} ==> b = a"
 | |
| 764 | by blast | |
| 765 | ||
| 766 | lemmas singletonE [elim!] = singletonD [elim_format] | |
| 767 | ||
| 768 | lemma singleton_iff: "(b : {a}) = (b = a)"
 | |
| 769 | by blast | |
| 770 | ||
| 771 | lemma singleton_inject [dest!]: "{a} = {b} ==> a = b"
 | |
| 772 | by blast | |
| 773 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 774 | lemma singleton_insert_inj_eq [iff]: "({b} = insert a A) = (a = b & A \<subseteq> {b})"
 | 
| 11979 | 775 | by blast | 
| 776 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 777 | lemma singleton_insert_inj_eq' [iff]: "(insert a A = {b}) = (a = b & A \<subseteq> {b})"
 | 
| 11979 | 778 | by blast | 
| 779 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 780 | lemma subset_singletonD: "A \<subseteq> {x} ==> A = {} | A = {x}"
 | 
| 11979 | 781 | by fast | 
| 782 | ||
| 783 | lemma singleton_conv [simp]: "{x. x = a} = {a}"
 | |
| 784 | by blast | |
| 785 | ||
| 786 | lemma singleton_conv2 [simp]: "{x. a = x} = {a}"
 | |
| 787 | by blast | |
| 923 | 788 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 789 | lemma diff_single_insert: "A - {x} \<subseteq> B ==> x \<in> A ==> A \<subseteq> insert x B"
 | 
| 11979 | 790 | by blast | 
| 791 | ||
| 792 | ||
| 793 | subsubsection {* Unions of families *}
 | |
| 794 | ||
| 795 | text {*
 | |
| 796 |   @{term [source] "UN x:A. B x"} is @{term "Union (B`A)"}.
 | |
| 797 | *} | |
| 798 | ||
| 799 | lemma UN_iff [simp]: "(b: (UN x:A. B x)) = (EX x:A. b: B x)" | |
| 800 | by (unfold UNION_def) blast | |
| 801 | ||
| 802 | lemma UN_I [intro]: "a:A ==> b: B a ==> b: (UN x:A. B x)" | |
| 803 |   -- {* The order of the premises presupposes that @{term A} is rigid;
 | |
| 804 |     @{term b} may be flexible. *}
 | |
| 805 | by auto | |
| 806 | ||
| 807 | lemma UN_E [elim!]: "b : (UN x:A. B x) ==> (!!x. x:A ==> b: B x ==> R) ==> R" | |
| 808 | by (unfold UNION_def) blast | |
| 923 | 809 | |
| 11979 | 810 | lemma UN_cong [cong]: | 
| 811 | "A = B ==> (!!x. x:B ==> C x = D x) ==> (UN x:A. C x) = (UN x:B. D x)" | |
| 812 | by (simp add: UNION_def) | |
| 813 | ||
| 814 | ||
| 815 | subsubsection {* Intersections of families *}
 | |
| 816 | ||
| 817 | text {* @{term [source] "INT x:A. B x"} is @{term "Inter (B`A)"}. *}
 | |
| 818 | ||
| 819 | lemma INT_iff [simp]: "(b: (INT x:A. B x)) = (ALL x:A. b: B x)" | |
| 820 | by (unfold INTER_def) blast | |
| 923 | 821 | |
| 11979 | 822 | lemma INT_I [intro!]: "(!!x. x:A ==> b: B x) ==> b : (INT x:A. B x)" | 
| 823 | by (unfold INTER_def) blast | |
| 824 | ||
| 825 | lemma INT_D [elim]: "b : (INT x:A. B x) ==> a:A ==> b: B a" | |
| 826 | by auto | |
| 827 | ||
| 828 | lemma INT_E [elim]: "b : (INT x:A. B x) ==> (b: B a ==> R) ==> (a~:A ==> R) ==> R" | |
| 829 |   -- {* "Classical" elimination -- by the Excluded Middle on @{prop "a:A"}. *}
 | |
| 830 | by (unfold INTER_def) blast | |
| 831 | ||
| 832 | lemma INT_cong [cong]: | |
| 833 | "A = B ==> (!!x. x:B ==> C x = D x) ==> (INT x:A. C x) = (INT x:B. D x)" | |
| 834 | by (simp add: INTER_def) | |
| 7238 
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
 wenzelm parents: 
5931diff
changeset | 835 | |
| 923 | 836 | |
| 11979 | 837 | subsubsection {* Union *}
 | 
| 838 | ||
| 839 | lemma Union_iff [simp]: "(A : Union C) = (EX X:C. A:X)" | |
| 840 | by (unfold Union_def) blast | |
| 841 | ||
| 842 | lemma UnionI [intro]: "X:C ==> A:X ==> A : Union C" | |
| 843 |   -- {* The order of the premises presupposes that @{term C} is rigid;
 | |
| 844 |     @{term A} may be flexible. *}
 | |
| 845 | by auto | |
| 846 | ||
| 847 | lemma UnionE [elim!]: "A : Union C ==> (!!X. A:X ==> X:C ==> R) ==> R" | |
| 848 | by (unfold Union_def) blast | |
| 849 | ||
| 850 | ||
| 851 | subsubsection {* Inter *}
 | |
| 852 | ||
| 853 | lemma Inter_iff [simp]: "(A : Inter C) = (ALL X:C. A:X)" | |
| 854 | by (unfold Inter_def) blast | |
| 855 | ||
| 856 | lemma InterI [intro!]: "(!!X. X:C ==> A:X) ==> A : Inter C" | |
| 857 | by (simp add: Inter_def) | |
| 858 | ||
| 859 | text {*
 | |
| 860 |   \medskip A ``destruct'' rule -- every @{term X} in @{term C}
 | |
| 861 |   contains @{term A} as an element, but @{prop "A:X"} can hold when
 | |
| 862 |   @{prop "X:C"} does not!  This rule is analogous to @{text spec}.
 | |
| 863 | *} | |
| 864 | ||
| 865 | lemma InterD [elim]: "A : Inter C ==> X:C ==> A:X" | |
| 866 | by auto | |
| 867 | ||
| 868 | lemma InterE [elim]: "A : Inter C ==> (X~:C ==> R) ==> (A:X ==> R) ==> R" | |
| 869 |   -- {* ``Classical'' elimination rule -- does not require proving
 | |
| 870 |     @{prop "X:C"}. *}
 | |
| 871 | by (unfold Inter_def) blast | |
| 872 | ||
| 873 | text {*
 | |
| 874 |   \medskip Image of a set under a function.  Frequently @{term b} does
 | |
| 875 |   not have the syntactic form of @{term "f x"}.
 | |
| 876 | *} | |
| 877 | ||
| 878 | lemma image_eqI [simp, intro]: "b = f x ==> x:A ==> b : f`A" | |
| 879 | by (unfold image_def) blast | |
| 880 | ||
| 881 | lemma imageI: "x : A ==> f x : f ` A" | |
| 882 | by (rule image_eqI) (rule refl) | |
| 883 | ||
| 884 | lemma rev_image_eqI: "x:A ==> b = f x ==> b : f`A" | |
| 885 |   -- {* This version's more effective when we already have the
 | |
| 886 |     required @{term x}. *}
 | |
| 887 | by (unfold image_def) blast | |
| 888 | ||
| 889 | lemma imageE [elim!]: | |
| 890 | "b : (%x. f x)`A ==> (!!x. b = f x ==> x:A ==> P) ==> P" | |
| 891 |   -- {* The eta-expansion gives variable-name preservation. *}
 | |
| 892 | by (unfold image_def) blast | |
| 893 | ||
| 894 | lemma image_Un: "f`(A Un B) = f`A Un f`B" | |
| 895 | by blast | |
| 896 | ||
| 897 | lemma image_iff: "(z : f`A) = (EX x:A. z = f x)" | |
| 898 | by blast | |
| 899 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 900 | lemma image_subset_iff: "(f`A \<subseteq> B) = (\<forall>x\<in>A. f x \<in> B)" | 
| 11979 | 901 |   -- {* This rewrite rule would confuse users if made default. *}
 | 
| 902 | by blast | |
| 903 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 904 | lemma subset_image_iff: "(B \<subseteq> f`A) = (EX AA. AA \<subseteq> A & B = f`AA)" | 
| 11979 | 905 | apply safe | 
| 906 | prefer 2 apply fast | |
| 14208 | 907 |   apply (rule_tac x = "{a. a : A & f a : B}" in exI, fast)
 | 
| 11979 | 908 | done | 
| 909 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 910 | lemma image_subsetI: "(!!x. x \<in> A ==> f x \<in> B) ==> f`A \<subseteq> B" | 
| 11979 | 911 |   -- {* Replaces the three steps @{text subsetI}, @{text imageE},
 | 
| 912 |     @{text hypsubst}, but breaks too many existing proofs. *}
 | |
| 913 | by blast | |
| 914 | ||
| 915 | text {*
 | |
| 916 | \medskip Range of a function -- just a translation for image! | |
| 917 | *} | |
| 918 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 919 | lemma range_eqI: "b = f x ==> b \<in> range f" | 
| 11979 | 920 | by simp | 
| 921 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 922 | lemma rangeI: "f x \<in> range f" | 
| 11979 | 923 | by simp | 
| 924 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 925 | lemma rangeE [elim?]: "b \<in> range (\<lambda>x. f x) ==> (!!x. b = f x ==> P) ==> P" | 
| 11979 | 926 | by blast | 
| 927 | ||
| 928 | ||
| 929 | subsubsection {* Set reasoning tools *}
 | |
| 930 | ||
| 931 | text {*
 | |
| 932 |   Rewrite rules for boolean case-splitting: faster than @{text
 | |
| 933 | "split_if [split]"}. | |
| 934 | *} | |
| 935 | ||
| 936 | lemma split_if_eq1: "((if Q then x else y) = b) = ((Q --> x = b) & (~ Q --> y = b))" | |
| 937 | by (rule split_if) | |
| 938 | ||
| 939 | lemma split_if_eq2: "(a = (if Q then x else y)) = ((Q --> a = x) & (~ Q --> a = y))" | |
| 940 | by (rule split_if) | |
| 941 | ||
| 942 | text {*
 | |
| 943 |   Split ifs on either side of the membership relation.  Not for @{text
 | |
| 944 | "[simp]"} -- can cause goals to blow up! | |
| 945 | *} | |
| 946 | ||
| 947 | lemma split_if_mem1: "((if Q then x else y) : b) = ((Q --> x : b) & (~ Q --> y : b))" | |
| 948 | by (rule split_if) | |
| 949 | ||
| 950 | lemma split_if_mem2: "(a : (if Q then x else y)) = ((Q --> a : x) & (~ Q --> a : y))" | |
| 951 | by (rule split_if) | |
| 952 | ||
| 953 | lemmas split_ifs = if_bool_eq_conj split_if_eq1 split_if_eq2 split_if_mem1 split_if_mem2 | |
| 954 | ||
| 955 | lemmas mem_simps = | |
| 956 | insert_iff empty_iff Un_iff Int_iff Compl_iff Diff_iff | |
| 957 | mem_Collect_eq UN_iff Union_iff INT_iff Inter_iff | |
| 958 |   -- {* Each of these has ALREADY been added @{text "[simp]"} above. *}
 | |
| 959 | ||
| 960 | (*Would like to add these, but the existing code only searches for the | |
| 961 | outer-level constant, which in this case is just "op :"; we instead need | |
| 962 | to use term-nets to associate patterns with rules. Also, if a rule fails to | |
| 963 | apply, then the formula should be kept. | |
| 964 |   [("uminus", Compl_iff RS iffD1), ("op -", [Diff_iff RS iffD1]),
 | |
| 965 |    ("op Int", [IntD1,IntD2]),
 | |
| 966 |    ("Collect", [CollectD]), ("Inter", [InterD]), ("INTER", [INT_D])]
 | |
| 967 | *) | |
| 968 | ||
| 969 | ML_setup {*
 | |
| 970 |   val mksimps_pairs = [("Ball", [thm "bspec"])] @ mksimps_pairs;
 | |
| 971 | simpset_ref() := simpset() setmksimps (mksimps mksimps_pairs); | |
| 972 | *} | |
| 973 | ||
| 974 | declare subset_UNIV [simp] subset_refl [simp] | |
| 975 | ||
| 976 | ||
| 977 | subsubsection {* The ``proper subset'' relation *}
 | |
| 978 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 979 | lemma psubsetI [intro!]: "A \<subseteq> B ==> A \<noteq> B ==> A \<subset> B" | 
| 11979 | 980 | by (unfold psubset_def) blast | 
| 981 | ||
| 13624 | 982 | lemma psubsetE [elim!]: | 
| 983 | "[|A \<subset> B; [|A \<subseteq> B; ~ (B\<subseteq>A)|] ==> R|] ==> R" | |
| 984 | by (unfold psubset_def) blast | |
| 985 | ||
| 11979 | 986 | lemma psubset_insert_iff: | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 987 |   "(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 | 988 | 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 | 989 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 990 | lemma psubset_eq: "(A \<subset> B) = (A \<subseteq> B & A \<noteq> B)" | 
| 11979 | 991 | by (simp only: psubset_def) | 
| 992 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 993 | lemma psubset_imp_subset: "A \<subset> B ==> A \<subseteq> B" | 
| 11979 | 994 | by (simp add: psubset_eq) | 
| 995 | ||
| 14335 | 996 | lemma psubset_trans: "[| A \<subset> B; B \<subset> C |] ==> A \<subset> C" | 
| 997 | apply (unfold psubset_def) | |
| 998 | apply (auto dest: subset_antisym) | |
| 999 | done | |
| 1000 | ||
| 1001 | lemma psubsetD: "[| A \<subset> B; c \<in> A |] ==> c \<in> B" | |
| 1002 | apply (unfold psubset_def) | |
| 1003 | apply (auto dest: subsetD) | |
| 1004 | done | |
| 1005 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1006 | lemma psubset_subset_trans: "A \<subset> B ==> B \<subseteq> C ==> A \<subset> C" | 
| 11979 | 1007 | by (auto simp add: psubset_eq) | 
| 1008 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1009 | lemma subset_psubset_trans: "A \<subseteq> B ==> B \<subset> C ==> A \<subset> C" | 
| 11979 | 1010 | by (auto simp add: psubset_eq) | 
| 1011 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1012 | lemma psubset_imp_ex_mem: "A \<subset> B ==> \<exists>b. b \<in> (B - A)" | 
| 11979 | 1013 | by (unfold psubset_def) blast | 
| 1014 | ||
| 1015 | lemma atomize_ball: | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1016 | "(!!x. x \<in> A ==> P x) == Trueprop (\<forall>x\<in>A. P x)" | 
| 11979 | 1017 | by (simp only: Ball_def atomize_all atomize_imp) | 
| 1018 | ||
| 1019 | declare atomize_ball [symmetric, rulify] | |
| 1020 | ||
| 1021 | ||
| 1022 | subsection {* Further set-theory lemmas *}
 | |
| 1023 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1024 | subsubsection {* Derived rules involving subsets. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1025 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1026 | text {* @{text insert}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1027 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1028 | lemma subset_insertI: "B \<subseteq> insert a B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1029 | apply (rule subsetI) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1030 | apply (erule insertI2) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1031 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1032 | |
| 14302 | 1033 | lemma subset_insertI2: "A \<subseteq> B \<Longrightarrow> A \<subseteq> insert b B" | 
| 1034 | by blast | |
| 1035 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1036 | 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 | 1037 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1038 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1039 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1040 | 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 | 1041 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1042 | lemma Union_upper: "B \<in> A ==> B \<subseteq> Union A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1043 | by (rules intro: subsetI UnionI) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1044 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1045 | lemma Union_least: "(!!X. X \<in> A ==> X \<subseteq> C) ==> Union A \<subseteq> C" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1046 | by (rules intro: subsetI elim: UnionE dest: subsetD) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1047 | |
| 
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 | text {* \medskip General union. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1050 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1051 | 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 | 1052 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1053 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1054 | lemma UN_least: "(!!x. x \<in> A ==> B x \<subseteq> C) ==> (\<Union>x\<in>A. B x) \<subseteq> C" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1055 | by (rules intro: subsetI elim: UN_E dest: subsetD) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1056 | |
| 
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 | 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 | 1059 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1060 | 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 | 1061 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1062 | |
| 14551 | 1063 | lemma Inter_subset: | 
| 1064 |   "[| !!X. X \<in> A ==> X \<subseteq> B; A ~= {} |] ==> \<Inter>A \<subseteq> B"
 | |
| 1065 | by blast | |
| 1066 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1067 | lemma Inter_greatest: "(!!X. X \<in> A ==> C \<subseteq> X) ==> C \<subseteq> Inter A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1068 | by (rules intro: InterI subsetI dest: subsetD) | 
| 
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 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 | 1071 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1072 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1073 | lemma INT_greatest: "(!!x. x \<in> A ==> C \<subseteq> B x) ==> C \<subseteq> (\<Inter>x\<in>A. B x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1074 | by (rules intro: INT_I subsetI dest: subsetD) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1075 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1076 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1077 | 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 | 1078 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1079 | lemma Un_upper1: "A \<subseteq> A \<union> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1080 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1081 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1082 | lemma Un_upper2: "B \<subseteq> A \<union> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1083 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1084 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1085 | 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 | 1086 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1087 | |
| 
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 | 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 | 1090 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1091 | lemma Int_lower1: "A \<inter> B \<subseteq> A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1092 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1093 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1094 | lemma Int_lower2: "A \<inter> B \<subseteq> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1095 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1096 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1097 | 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 | 1098 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1099 | |
| 
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 | text {* \medskip Set difference. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1102 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1103 | lemma Diff_subset: "A - B \<subseteq> A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1104 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1105 | |
| 14302 | 1106 | lemma Diff_subset_conv: "(A - B \<subseteq> C) = (A \<subseteq> B \<union> C)" | 
| 1107 | by blast | |
| 1108 | ||
| 12897 
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 | text {* \medskip Monotonicity. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1111 | |
| 15206 
09d78ec709c7
Modified locales: improved implementation of "includes".
 ballarin parents: 
15140diff
changeset | 1112 | lemma mono_Un: "mono f ==> f A \<union> f B \<subseteq> f (A \<union> B)" | 
| 
09d78ec709c7
Modified locales: improved implementation of "includes".
 ballarin parents: 
15140diff
changeset | 1113 | by (blast dest: monoD) | 
| 
09d78ec709c7
Modified locales: improved implementation of "includes".
 ballarin parents: 
15140diff
changeset | 1114 | |
| 
09d78ec709c7
Modified locales: improved implementation of "includes".
 ballarin parents: 
15140diff
changeset | 1115 | lemma mono_Int: "mono f ==> f (A \<inter> B) \<subseteq> f A \<inter> f B" | 
| 
09d78ec709c7
Modified locales: improved implementation of "includes".
 ballarin parents: 
15140diff
changeset | 1116 | by (blast dest: monoD) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1117 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1118 | subsubsection {* Equalities involving union, intersection, inclusion, etc. *}
 | 
| 
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 {* @{text "{}"}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1121 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1122 | 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 | 1123 |   -- {* supersedes @{text "Collect_False_empty"} *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1124 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1125 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1126 | lemma subset_empty [simp]: "(A \<subseteq> {}) = (A = {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1127 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1128 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1129 | lemma not_psubset_empty [iff]: "\<not> (A < {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1130 | by (unfold psubset_def) blast | 
| 
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_empty_eq [simp]: "(Collect P = {}) = (\<forall>x. \<not> P x)"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1133 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1134 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1135 | 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 | 1136 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1137 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1138 | 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 | 1139 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1140 | |
| 14812 | 1141 | lemma Collect_imp_eq: "{x. P x --> Q x} = -{x. P x} \<union> {x. Q x}"
 | 
| 1142 | by blast | |
| 1143 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1144 | 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 | 1145 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1146 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1147 | 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 | 1148 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1149 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1150 | 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 | 1151 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1152 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1153 | 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 | 1154 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1155 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1156 | 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 | 1157 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1158 | |
| 
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 | text {* \medskip @{text insert}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1161 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1162 | 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 | 1163 |   -- {* 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 | 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 insert_not_empty [simp]: "insert a A \<noteq> {}"
 | 
| 
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 | lemmas empty_not_insert [simp] = insert_not_empty [symmetric, standard] | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1170 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1171 | 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 | 1172 |   -- {* @{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 | 1173 |   -- {* with \emph{quadratic} running time *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1174 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1175 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1176 | 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 | 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_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 | 1180 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1181 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1182 | 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 | 1183 | by blast | 
| 
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 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 | 1186 |   -- {* use new @{text B} rather than @{text "A - {a}"} to avoid infinite unfolding *}
 | 
| 14208 | 1187 |   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 | 1188 | done | 
| 
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_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 | 1191 | by auto | 
| 
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 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 | 1194 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1195 | |
| 14302 | 1196 | lemma insert_inter_insert[simp]: "insert a A \<inter> insert a B = insert a (A \<inter> B)" | 
| 14742 | 1197 | by blast | 
| 14302 | 1198 | |
| 13103 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1199 | lemma insert_disjoint[simp]: | 
| 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1200 |  "(insert a A \<inter> B = {}) = (a \<notin> B \<and> A \<inter> B = {})"
 | 
| 14742 | 1201 |  "({} = insert a A \<inter> B) = (a \<notin> B \<and> {} = A \<inter> B)"
 | 
| 1202 | by auto | |
| 13103 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1203 | |
| 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1204 | lemma disjoint_insert[simp]: | 
| 
66659a4b16f6
Added insert_disjoint and disjoint_insert [simp], and simplified proofs
 nipkow parents: 
12937diff
changeset | 1205 |  "(B \<inter> insert a A = {}) = (a \<notin> B \<and> B \<inter> A = {})"
 | 
| 14742 | 1206 |  "({} = A \<inter> insert b B) = (b \<notin> A \<and> {} = A \<inter> B)"
 | 
| 1207 | by auto | |
| 1208 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1209 | text {* \medskip @{text image}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1210 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1211 | lemma image_empty [simp]: "f`{} = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1212 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1213 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1214 | 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 | 1215 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1216 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1217 | lemma image_constant: "x \<in> A ==> (\<lambda>x. c) ` A = {c}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1218 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1219 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1220 | 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 | 1221 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1222 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1223 | 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 | 1224 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1225 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1226 | lemma image_is_empty [iff]: "(f`A = {}) = (A = {})"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1227 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1228 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1229 | lemma image_Collect: "f ` {x. P x} = {f x | x. P x}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1230 |   -- {* NOT suitable as a default simprule: the RHS isn't simpler than the LHS, *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1231 |   -- {* with its implicit quantifier and conjunction.  Also image enjoys better *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1232 |   -- {* equational properties than does the RHS. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1233 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1234 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1235 | lemma if_image_distrib [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1236 | "(\<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 | 1237 |     = (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 | 1238 | by (auto simp add: image_def) | 
| 
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_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 | 1241 | by (simp add: image_def) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1242 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1243 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1244 | text {* \medskip @{text range}. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1245 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1246 | 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 | 1247 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1248 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1249 | lemma range_composition [simp]: "range (\<lambda>x. f (g x)) = f`range g" | 
| 14208 | 1250 | by (subst image_image, simp) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1251 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1252 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1253 | text {* \medskip @{text Int} *}
 | 
| 
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 Int_absorb [simp]: "A \<inter> A = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1256 | by blast | 
| 
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 | 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 | 1259 | by blast | 
| 
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 Int_commute: "A \<inter> B = B \<inter> A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1262 | by blast | 
| 
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 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 | 1265 | by blast | 
| 
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 | 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 | 1268 | by blast | 
| 
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 | 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 | 1271 |   -- {* Intersection is an AC-operator *}
 | 
| 
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_absorb1: "B \<subseteq> A ==> A \<inter> B = 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_absorb2: "A \<subseteq> B ==> A \<inter> B = 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_empty_left [simp]: "{} \<inter> B = {}"
 | 
| 
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_empty_right [simp]: "A \<inter> {} = {}"
 | 
| 
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 | 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 | 1286 | by blast | 
| 
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 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 | 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_UNIV_left [simp]: "UNIV \<inter> B = B" | 
| 
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_UNIV_right [simp]: "A \<inter> UNIV = A" | 
| 
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_eq_Inter: "A \<inter> B = \<Inter>{A, B}"
 | 
| 
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 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 | 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 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 | 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 [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 | 1307 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1308 | |
| 15102 | 1309 | 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 | 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_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 | 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 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1316 | text {* \medskip @{text Un}. *}
 | 
| 
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 Un_absorb [simp]: "A \<union> A = 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 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 | 1322 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1323 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1324 | 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 | 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 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 | 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 | 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 | 1331 | by blast | 
| 
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 | 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 | 1334 |   -- {* Union is an AC-operator *}
 | 
| 
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_absorb1: "A \<subseteq> B ==> A \<union> B = 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_absorb2: "B \<subseteq> A ==> A \<union> B = 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_empty_left [simp]: "{} \<union> B = B"
 | 
| 
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_empty_right [simp]: "A \<union> {} = A"
 | 
| 
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 | 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 | 1349 | by blast | 
| 
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_UNIV_right [simp]: "A \<union> UNIV = UNIV" | 
| 
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_eq_Union: "A \<union> B = \<Union>{A, B}"
 | 
| 
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_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 | 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_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 | 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 Int_insert_left: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1364 | "(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 | 1365 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1366 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1367 | lemma Int_insert_right: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1368 | "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 | 1369 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1370 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1371 | 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 | 1372 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1373 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1374 | 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 | 1375 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1376 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1377 | lemma Un_Int_crazy: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1378 | "(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 | 1379 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1380 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1381 | 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 | 1382 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1383 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1384 | 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 | 1385 | by blast | 
| 15102 | 1386 | |
| 1387 | 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 | 1388 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1389 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1390 | 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 | 1391 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1392 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1393 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1394 | text {* \medskip Set complement *}
 | 
| 
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 Compl_disjoint [simp]: "A \<inter> -A = {}"
 | 
| 
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 Compl_disjoint2 [simp]: "-A \<inter> A = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1400 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1401 | |
| 13818 | 1402 | lemma Compl_partition: "A \<union> -A = UNIV" | 
| 1403 | by blast | |
| 1404 | ||
| 1405 | lemma Compl_partition2: "-A \<union> A = UNIV" | |
| 12897 
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 | lemma double_complement [simp]: "- (-A) = (A::'a set)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1409 | by blast | 
| 
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_Un [simp]: "-(A \<union> B) = (-A) \<inter> (-B)" | 
| 
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_Int [simp]: "-(A \<inter> B) = (-A) \<union> (-B)" | 
| 
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 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1417 | 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 | 1418 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1419 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1420 | 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 | 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 subset_Compl_self_eq: "(A \<subseteq> -A) = (A = {})"
 | 
| 
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 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 | 1427 |   -- {* Halmos, Naive Set Theory, page 16. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1428 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1429 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1430 | lemma Compl_UNIV_eq [simp]: "-UNIV = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1431 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1432 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1433 | lemma Compl_empty_eq [simp]: "-{} = UNIV"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1434 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1435 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1436 | 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 | 1437 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1438 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1439 | 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 | 1440 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1441 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1442 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1443 | text {* \medskip @{text Union}. *}
 | 
| 
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 Union_empty [simp]: "Union({}) = {}"
 | 
| 
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 Union_UNIV [simp]: "Union UNIV = 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 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 | 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 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 | 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 | 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 | 1458 | by blast | 
| 
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_conv [iff]: "(\<Union>A = {}) = (\<forall>x\<in>A. x = {})"
 | 
| 13653 | 1461 | by blast | 
| 1462 | ||
| 1463 | lemma empty_Union_conv [iff]: "({} = \<Union>A) = (\<forall>x\<in>A. x = {})"
 | |
| 1464 | by blast | |
| 12897 
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_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 | 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 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1470 | text {* \medskip @{text Inter}. *}
 | 
| 
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 Inter_empty [simp]: "\<Inter>{} = UNIV"
 | 
| 
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 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1475 | lemma Inter_UNIV [simp]: "\<Inter>UNIV = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1476 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1477 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1478 | 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 | 1479 | by blast | 
| 
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 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 | 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 | 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 | 1485 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1486 | |
| 13653 | 1487 | lemma Inter_UNIV_conv [iff]: | 
| 1488 | "(\<Inter>A = UNIV) = (\<forall>x\<in>A. x = UNIV)" | |
| 1489 | "(UNIV = \<Inter>A) = (\<forall>x\<in>A. x = UNIV)" | |
| 14208 | 1490 | by blast+ | 
| 13653 | 1491 | |
| 12897 
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 | text {*
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1494 |   \medskip @{text UN} and @{text INT}.
 | 
| 
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 | Basic identities: *} | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1497 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1498 | 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 | 1499 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1500 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1501 | lemma UN_empty2 [simp]: "(\<Union>x\<in>A. {}) = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1502 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1503 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1504 | 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 | 1505 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1506 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1507 | lemma UN_absorb: "k \<in> I ==> A k \<union> (\<Union>i\<in>I. A i) = (\<Union>i\<in>I. A i)" | 
| 15102 | 1508 | by auto | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1509 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1510 | 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 | 1511 | by blast | 
| 
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 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 | 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_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 | 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_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 | 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_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 | 1523 | by blast | 
| 
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 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 | 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_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 | 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 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 | 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 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 | 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 INT_insert_distrib: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1538 | "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 | 1539 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1540 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1541 | 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 | 1542 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1543 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1544 | 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 | 1545 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1546 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1547 | 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 | 1548 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1549 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1550 | 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 | 1551 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1552 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1553 | 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 | 1554 | by auto | 
| 
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 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 | 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 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 | 1560 |   -- {* Look: it has an \emph{existential} quantifier *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1561 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1562 | |
| 13653 | 1563 | lemma UNION_empty_conv[iff]: | 
| 1564 |   "({} = (UN x:A. B x)) = (\<forall>x\<in>A. B x = {})"
 | |
| 1565 |   "((UN x:A. B x) = {}) = (\<forall>x\<in>A. B x = {})"
 | |
| 1566 | by blast+ | |
| 1567 | ||
| 1568 | lemma INTER_UNIV_conv[iff]: | |
| 1569 | "(UNIV = (INT x:A. B x)) = (\<forall>x\<in>A. B x = UNIV)" | |
| 1570 | "((INT x:A. B x) = UNIV) = (\<forall>x\<in>A. B x = UNIV)" | |
| 1571 | by blast+ | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1572 | |
| 
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 | text {* \medskip Distributive laws: *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1575 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1576 | 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 | 1577 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1578 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1579 | 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 | 1580 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1581 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1582 | 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 | 1583 |   -- {* 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 | 1584 |   -- {* Union of a family of unions *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1585 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1586 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1587 | 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 | 1588 |   -- {* Equivalent version *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1589 | by blast | 
| 
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 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 | 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_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 | 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 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 | 1598 |   -- {* Equivalent version *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1599 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1600 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1601 | 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 | 1602 |   -- {* Halmos, Naive Set Theory, page 35. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1603 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1604 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1605 | 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 | 1606 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1607 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1608 | 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 | 1609 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1610 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1611 | 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 | 1612 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1613 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1614 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1615 | text {* \medskip Bounded quantifiers.
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1616 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1617 | 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 | 1618 |   (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 | 1619 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1620 | 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 | 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 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 | 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 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 | 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 | 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 | 1630 | by blast | 
| 
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 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1633 | text {* \medskip Set difference. *}
 | 
| 
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 Diff_eq: "A - B = A \<inter> (-B)" | 
| 
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 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 | 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 Diff_cancel [simp]: "A - A = {}"
 | 
| 
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 | |
| 14302 | 1644 | lemma Diff_idemp [simp]: "(A - B) - B = A - (B::'a set)" | 
| 1645 | by blast | |
| 1646 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1647 | 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 | 1648 | by (blast elim: equalityE) | 
| 
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 empty_Diff [simp]: "{} - A = {}"
 | 
| 
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_empty [simp]: "A - {} = A"
 | 
| 
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_UNIV [simp]: "A - UNIV = {}"
 | 
| 
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 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1659 | 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 | 1660 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1661 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1662 | 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 | 1663 |   -- {* 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 | 1664 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1665 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1666 | 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 | 1667 |   -- {* 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 | 1668 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1669 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1670 | 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 | 1671 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1672 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1673 | 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 | 1674 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1675 | |
| 14302 | 1676 | lemma insert_Diff_single[simp]: "insert a (A - {a}) = insert a A"
 | 
| 1677 | by blast | |
| 1678 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1679 | 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 | 1680 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1681 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1682 | 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 | 1683 | by auto | 
| 
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 Diff_disjoint [simp]: "A \<inter> (B - A) = {}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1686 | by blast | 
| 
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 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 | 1689 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1690 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1691 | 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 | 1692 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1693 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1694 | 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 | 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 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 | 1698 | by blast | 
| 
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_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 | 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_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 | 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 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 | 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 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 | 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 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 | 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_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 | 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_Compl [simp]: "A - (- B) = A \<inter> B" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1719 | by auto | 
| 
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 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 | 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 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1725 | text {* \medskip Quantification over type @{typ bool}. *}
 | 
| 
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 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 | 1728 | apply auto | 
| 14208 | 1729 |   apply (tactic {* case_tac "b" 1 *}, auto)
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1730 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1731 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1732 | 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 | 1733 | 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 | 1734 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1735 | 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 | 1736 | apply auto | 
| 14208 | 1737 |   apply (tactic {* case_tac "b" 1 *}, auto)
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1738 | done | 
| 
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 | 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 | 1741 | by (auto simp add: split_if_mem2) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1742 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1743 | 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 | 1744 | apply auto | 
| 14208 | 1745 |   apply (tactic {* case_tac "b" 1 *}, auto)
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1746 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1747 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1748 | 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 | 1749 | apply auto | 
| 14208 | 1750 |   apply (tactic {* case_tac "b" 1 *}, auto)
 | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1751 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1752 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1753 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1754 | text {* \medskip @{text Pow} *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1755 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1756 | lemma Pow_empty [simp]: "Pow {} = {{}}"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1757 | by (auto simp add: Pow_def) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1758 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1759 | 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 | 1760 |   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 | 1761 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1762 | 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 | 1763 | by (blast intro: exI [where ?x = "- u", standard]) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1764 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1765 | lemma Pow_UNIV [simp]: "Pow UNIV = UNIV" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1766 | by blast | 
| 
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 | 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 | 1769 | by blast | 
| 
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 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 | 1772 | by blast | 
| 
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 subset_Pow_Union: "A \<subseteq> Pow (\<Union>A)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1775 | by blast | 
| 
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 Union_Pow_eq [simp]: "\<Union>(Pow A) = A" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1778 | by blast | 
| 
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_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 | 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 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 | 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 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1787 | text {* \medskip Miscellany. *}
 | 
| 
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 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 | 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 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 | 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 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 | 1796 | by (unfold psubset_def) 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 all_not_in_conv [iff]: "(\<forall>x. x \<notin> A) = (A = {})"
 | 
| 
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 | |
| 13831 | 1801 | lemma ex_in_conv: "(\<exists>x. x \<in> A) = (A \<noteq> {})"
 | 
| 1802 | by blast | |
| 1803 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1804 | lemma distinct_lemma: "f x \<noteq> f y ==> x \<noteq> y" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1805 | by rules | 
| 
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 | |
| 13860 | 1808 | text {* \medskip Miniscoping: pushing in quantifiers and big Unions
 | 
| 1809 | and Intersections. *} | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1810 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1811 | lemma UN_simps [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1812 |   "!!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 | 1813 |   "!!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 | 1814 |   "!!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 | 1815 | "!!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 | 1816 | "!!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 | 1817 | "!!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 | 1818 | "!!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 | 1819 | "!!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 | 1820 | "!!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 | 1821 | "!!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 | 1822 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1823 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1824 | lemma INT_simps [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1825 |   "!!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 | 1826 |   "!!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 | 1827 |   "!!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 | 1828 |   "!!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 | 1829 | "!!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 | 1830 | "!!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 | 1831 | "!!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 | 1832 | "!!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 | 1833 | "!!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 | 1834 | "!!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 | 1835 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1836 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1837 | lemma ball_simps [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1838 | "!!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 | 1839 | "!!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 | 1840 | "!!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 | 1841 | "!!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 | 1842 |   "!!P. (ALL x:{}. P x) = True"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1843 | "!!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 | 1844 | "!!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 | 1845 | "!!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 | 1846 | "!!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 | 1847 | "!!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 | 1848 | "!!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 | 1849 | "!!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 | 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 bex_simps [simp]: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1853 | "!!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 | 1854 | "!!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 | 1855 |   "!!P. (EX x:{}. P x) = False"
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1856 | "!!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 | 1857 | "!!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 | 1858 | "!!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 | 1859 | "!!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 | 1860 | "!!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 | 1861 | "!!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 | 1862 | "!!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 | 1863 | by auto | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1864 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1865 | lemma ball_conj_distrib: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1866 | "(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 | 1867 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1868 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1869 | lemma bex_disj_distrib: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1870 | "(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 | 1871 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1872 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1873 | |
| 13860 | 1874 | text {* \medskip Maxiscoping: pulling out big Unions and Intersections. *}
 | 
| 1875 | ||
| 1876 | lemma UN_extend_simps: | |
| 1877 |   "!!a B C. insert a (UN x:C. B x) = (if C={} then {a} else (UN x:C. insert a (B x)))"
 | |
| 1878 |   "!!A B C. (UN x:C. A x) Un B    = (if C={} then B else (UN x:C. A x Un B))"
 | |
| 1879 |   "!!A B C. A Un (UN x:C. B x)   = (if C={} then A else (UN x:C. A Un B x))"
 | |
| 1880 | "!!A B C. ((UN x:C. A x) Int B) = (UN x:C. A x Int B)" | |
| 1881 | "!!A B C. (A Int (UN x:C. B x)) = (UN x:C. A Int B x)" | |
| 1882 | "!!A B C. ((UN x:C. A x) - B) = (UN x:C. A x - B)" | |
| 1883 | "!!A B C. (A - (INT x:C. B x)) = (UN x:C. A - B x)" | |
| 1884 | "!!A B. (UN y:A. UN x:y. B x) = (UN x: Union A. B x)" | |
| 1885 | "!!A B C. (UN x:A. UN z: B(x). C z) = (UN z: UNION A B. C z)" | |
| 1886 | "!!A B f. (UN a:A. B (f a)) = (UN x:f`A. B x)" | |
| 1887 | by auto | |
| 1888 | ||
| 1889 | lemma INT_extend_simps: | |
| 1890 |   "!!A B C. (INT x:C. A x) Int B = (if C={} then B else (INT x:C. A x Int B))"
 | |
| 1891 |   "!!A B C. A Int (INT x:C. B x) = (if C={} then A else (INT x:C. A Int B x))"
 | |
| 1892 |   "!!A B C. (INT x:C. A x) - B   = (if C={} then UNIV-B else (INT x:C. A x - B))"
 | |
| 1893 |   "!!A B C. A - (UN x:C. B x)   = (if C={} then A else (INT x:C. A - B x))"
 | |
| 1894 | "!!a B C. insert a (INT x:C. B x) = (INT x:C. insert a (B x))" | |
| 1895 | "!!A B C. ((INT x:C. A x) Un B) = (INT x:C. A x Un B)" | |
| 1896 | "!!A B C. A Un (INT x:C. B x) = (INT x:C. A Un B x)" | |
| 1897 | "!!A B. (INT y:A. INT x:y. B x) = (INT x: Union A. B x)" | |
| 1898 | "!!A B C. (INT x:A. INT z: B(x). C z) = (INT z: UNION A B. C z)" | |
| 1899 | "!!A B f. (INT a:A. B (f a)) = (INT x:f`A. B x)" | |
| 1900 | by auto | |
| 1901 | ||
| 1902 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1903 | subsubsection {* Monotonicity of various operations *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1904 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1905 | 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 | 1906 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1907 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1908 | 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 | 1909 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1910 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1911 | 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 | 1912 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1913 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1914 | 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 | 1915 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1916 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1917 | lemma UN_mono: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1918 | "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 | 1919 | (\<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 | 1920 | by (blast dest: subsetD) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1921 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1922 | lemma INT_anti_mono: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1923 | "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 | 1924 | (\<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 | 1925 |   -- {* The last inclusion is POSITIVE! *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1926 | by (blast dest: subsetD) | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1927 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1928 | 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 | 1929 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1930 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1931 | 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 | 1932 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1933 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1934 | 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 | 1935 | by blast | 
| 
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 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 | 1938 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1939 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1940 | 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 | 1941 | by blast | 
| 
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 | text {* \medskip Monotonicity of implications. *}
 | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1944 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1945 | 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 | 1946 | apply (rule impI) | 
| 14208 | 1947 | apply (erule subsetD, assumption) | 
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1948 | done | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1949 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1950 | lemma conj_mono: "P1 --> Q1 ==> P2 --> Q2 ==> (P1 & P2) --> (Q1 & Q2)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1951 | by rules | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1952 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1953 | lemma disj_mono: "P1 --> Q1 ==> P2 --> Q2 ==> (P1 | P2) --> (Q1 | Q2)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1954 | by rules | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1955 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1956 | lemma imp_mono: "Q1 --> P1 ==> P2 --> Q2 ==> (P1 --> P2) --> (Q1 --> Q2)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1957 | by rules | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1958 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1959 | lemma imp_refl: "P --> P" .. | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1960 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1961 | lemma ex_mono: "(!!x. P x --> Q x) ==> (EX x. P x) --> (EX x. Q x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1962 | by rules | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1963 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1964 | lemma all_mono: "(!!x. P x --> Q x) ==> (ALL x. P x) --> (ALL x. Q x)" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1965 | by rules | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1966 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1967 | 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 | 1968 | by blast | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1969 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1970 | lemma Int_Collect_mono: | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1971 | "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 | 1972 | by blast | 
| 
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 | lemmas basic_monos = | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1975 | subset_refl imp_refl disj_mono conj_mono | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1976 | ex_mono Collect_mono in_mono | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1977 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1978 | lemma eq_to_mono: "a = b ==> c = d ==> b --> d ==> a --> c" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1979 | by rules | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1980 | |
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1981 | lemma eq_to_mono2: "a = b ==> c = d ==> ~ b --> ~ d ==> ~ a --> ~ c" | 
| 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 1982 | by rules | 
| 11979 | 1983 | |
| 11982 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 1984 | lemma Least_mono: | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 1985 | "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 | 1986 | ==> (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 | 1987 |     -- {* Courtesy of Stephan Merz *}
 | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 1988 | apply clarify | 
| 15950 | 1989 | apply (erule_tac P = "%x. x : S" in LeastI2_order, fast) | 
| 1990 | apply (rule LeastI2_order) | |
| 11982 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 1991 | apply (auto elim: monoD intro!: order_antisym) | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 1992 | done | 
| 
65e2822d83dd
lemma Least_mono moved from Typedef.thy to Set.thy;
 wenzelm parents: 
11979diff
changeset | 1993 | |
| 12020 | 1994 | |
| 12257 | 1995 | subsection {* Inverse image of a function *}
 | 
| 1996 | ||
| 1997 | constdefs | |
| 1998 |   vimage :: "('a => 'b) => 'b set => 'a set"    (infixr "-`" 90)
 | |
| 1999 |   "f -` B == {x. f x : B}"
 | |
| 2000 | ||
| 2001 | ||
| 2002 | subsubsection {* Basic rules *}
 | |
| 2003 | ||
| 2004 | lemma vimage_eq [simp]: "(a : f -` B) = (f a : B)" | |
| 2005 | by (unfold vimage_def) blast | |
| 2006 | ||
| 2007 | lemma vimage_singleton_eq: "(a : f -` {b}) = (f a = b)"
 | |
| 2008 | by simp | |
| 2009 | ||
| 2010 | lemma vimageI [intro]: "f a = b ==> b:B ==> a : f -` B" | |
| 2011 | by (unfold vimage_def) blast | |
| 2012 | ||
| 2013 | lemma vimageI2: "f a : A ==> a : f -` A" | |
| 2014 | by (unfold vimage_def) fast | |
| 2015 | ||
| 2016 | lemma vimageE [elim!]: "a: f -` B ==> (!!x. f a = x ==> x:B ==> P) ==> P" | |
| 2017 | by (unfold vimage_def) blast | |
| 2018 | ||
| 2019 | lemma vimageD: "a : f -` A ==> f a : A" | |
| 2020 | by (unfold vimage_def) fast | |
| 2021 | ||
| 2022 | ||
| 2023 | subsubsection {* Equations *}
 | |
| 2024 | ||
| 2025 | lemma vimage_empty [simp]: "f -` {} = {}"
 | |
| 2026 | by blast | |
| 2027 | ||
| 2028 | lemma vimage_Compl: "f -` (-A) = -(f -` A)" | |
| 2029 | by blast | |
| 2030 | ||
| 2031 | lemma vimage_Un [simp]: "f -` (A Un B) = (f -` A) Un (f -` B)" | |
| 2032 | by blast | |
| 2033 | ||
| 2034 | lemma vimage_Int [simp]: "f -` (A Int B) = (f -` A) Int (f -` B)" | |
| 2035 | by fast | |
| 2036 | ||
| 2037 | lemma vimage_Union: "f -` (Union A) = (UN X:A. f -` X)" | |
| 2038 | by blast | |
| 2039 | ||
| 2040 | lemma vimage_UN: "f-`(UN x:A. B x) = (UN x:A. f -` B x)" | |
| 2041 | by blast | |
| 2042 | ||
| 2043 | lemma vimage_INT: "f-`(INT x:A. B x) = (INT x:A. f -` B x)" | |
| 2044 | by blast | |
| 2045 | ||
| 2046 | lemma vimage_Collect_eq [simp]: "f -` Collect P = {y. P (f y)}"
 | |
| 2047 | by blast | |
| 2048 | ||
| 2049 | lemma vimage_Collect: "(!!x. P (f x) = Q x) ==> f -` (Collect P) = Collect Q" | |
| 2050 | by blast | |
| 2051 | ||
| 2052 | lemma vimage_insert: "f-`(insert a B) = (f-`{a}) Un (f-`B)"
 | |
| 2053 |   -- {* NOT suitable for rewriting because of the recurrence of @{term "{a}"}. *}
 | |
| 2054 | by blast | |
| 2055 | ||
| 2056 | lemma vimage_Diff: "f -` (A - B) = (f -` A) - (f -` B)" | |
| 2057 | by blast | |
| 2058 | ||
| 2059 | lemma vimage_UNIV [simp]: "f -` UNIV = UNIV" | |
| 2060 | by blast | |
| 2061 | ||
| 2062 | lemma vimage_eq_UN: "f-`B = (UN y: B. f-`{y})"
 | |
| 2063 |   -- {* NOT suitable for rewriting *}
 | |
| 2064 | by blast | |
| 2065 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 2066 | lemma vimage_mono: "A \<subseteq> B ==> f -` A \<subseteq> f -` B" | 
| 12257 | 2067 |   -- {* monotonicity *}
 | 
| 2068 | by blast | |
| 2069 | ||
| 2070 | ||
| 14479 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2071 | subsection {* Getting the Contents of a Singleton Set *}
 | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2072 | |
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2073 | constdefs | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2074 | contents :: "'a set => 'a" | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2075 |    "contents X == THE x. X = {x}"
 | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2076 | |
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2077 | lemma contents_eq [simp]: "contents {x} = x"
 | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2078 | by (simp add: contents_def) | 
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2079 | |
| 
0eca4aabf371
streamlined treatment of quotients for the integers
 paulson parents: 
14398diff
changeset | 2080 | |
| 12023 | 2081 | subsection {* Transitivity rules for calculational reasoning *}
 | 
| 12020 | 2082 | |
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 2083 | lemma set_rev_mp: "x:A ==> A \<subseteq> B ==> x:B" | 
| 12020 | 2084 | by (rule subsetD) | 
| 2085 | ||
| 12897 
f4d10ad0ea7b
converted/deleted equalities.ML, mono.ML, subset.ML (see Set.thy);
 wenzelm parents: 
12633diff
changeset | 2086 | lemma set_mp: "A \<subseteq> B ==> x:A ==> x:B" | 
| 12020 | 2087 | by (rule subsetD) | 
| 2088 | ||
| 2089 | lemma ord_le_eq_trans: "a <= b ==> b = c ==> a <= c" | |
| 2090 | by (rule subst) | |
| 2091 | ||
| 2092 | lemma ord_eq_le_trans: "a = b ==> b <= c ==> a <= c" | |
| 2093 | by (rule ssubst) | |
| 2094 | ||
| 2095 | lemma ord_less_eq_trans: "a < b ==> b = c ==> a < c" | |
| 2096 | by (rule subst) | |
| 2097 | ||
| 2098 | lemma ord_eq_less_trans: "a = b ==> b < c ==> a < c" | |
| 2099 | by (rule ssubst) | |
| 2100 | ||
| 2101 | lemma order_less_subst2: "(a::'a::order) < b ==> f b < (c::'c::order) ==> | |
| 2102 | (!!x y. x < y ==> f x < f y) ==> f a < c" | |
| 2103 | proof - | |
| 2104 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2105 | assume "a < b" hence "f a < f b" by (rule r) | |
| 2106 | also assume "f b < c" | |
| 2107 | finally (order_less_trans) show ?thesis . | |
| 2108 | qed | |
| 2109 | ||
| 2110 | lemma order_less_subst1: "(a::'a::order) < f b ==> (b::'b::order) < c ==> | |
| 2111 | (!!x y. x < y ==> f x < f y) ==> a < f c" | |
| 2112 | proof - | |
| 2113 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2114 | assume "a < f b" | |
| 2115 | also assume "b < c" hence "f b < f c" by (rule r) | |
| 2116 | finally (order_less_trans) show ?thesis . | |
| 2117 | qed | |
| 2118 | ||
| 2119 | lemma order_le_less_subst2: "(a::'a::order) <= b ==> f b < (c::'c::order) ==> | |
| 2120 | (!!x y. x <= y ==> f x <= f y) ==> f a < c" | |
| 2121 | proof - | |
| 2122 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2123 | assume "a <= b" hence "f a <= f b" by (rule r) | |
| 2124 | also assume "f b < c" | |
| 2125 | finally (order_le_less_trans) show ?thesis . | |
| 2126 | qed | |
| 2127 | ||
| 2128 | lemma order_le_less_subst1: "(a::'a::order) <= f b ==> (b::'b::order) < c ==> | |
| 2129 | (!!x y. x < y ==> f x < f y) ==> a < f c" | |
| 2130 | proof - | |
| 2131 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2132 | assume "a <= f b" | |
| 2133 | also assume "b < c" hence "f b < f c" by (rule r) | |
| 2134 | finally (order_le_less_trans) show ?thesis . | |
| 2135 | qed | |
| 2136 | ||
| 2137 | lemma order_less_le_subst2: "(a::'a::order) < b ==> f b <= (c::'c::order) ==> | |
| 2138 | (!!x y. x < y ==> f x < f y) ==> f a < c" | |
| 2139 | proof - | |
| 2140 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2141 | assume "a < b" hence "f a < f b" by (rule r) | |
| 2142 | also assume "f b <= c" | |
| 2143 | finally (order_less_le_trans) show ?thesis . | |
| 2144 | qed | |
| 2145 | ||
| 2146 | lemma order_less_le_subst1: "(a::'a::order) < f b ==> (b::'b::order) <= c ==> | |
| 2147 | (!!x y. x <= y ==> f x <= f y) ==> a < f c" | |
| 2148 | proof - | |
| 2149 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2150 | assume "a < f b" | |
| 2151 | also assume "b <= c" hence "f b <= f c" by (rule r) | |
| 2152 | finally (order_less_le_trans) show ?thesis . | |
| 2153 | qed | |
| 2154 | ||
| 2155 | lemma order_subst1: "(a::'a::order) <= f b ==> (b::'b::order) <= c ==> | |
| 2156 | (!!x y. x <= y ==> f x <= f y) ==> a <= f c" | |
| 2157 | proof - | |
| 2158 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2159 | assume "a <= f b" | |
| 2160 | also assume "b <= c" hence "f b <= f c" by (rule r) | |
| 2161 | finally (order_trans) show ?thesis . | |
| 2162 | qed | |
| 2163 | ||
| 2164 | lemma order_subst2: "(a::'a::order) <= b ==> f b <= (c::'c::order) ==> | |
| 2165 | (!!x y. x <= y ==> f x <= f y) ==> f a <= c" | |
| 2166 | proof - | |
| 2167 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2168 | assume "a <= b" hence "f a <= f b" by (rule r) | |
| 2169 | also assume "f b <= c" | |
| 2170 | finally (order_trans) show ?thesis . | |
| 2171 | qed | |
| 2172 | ||
| 2173 | lemma ord_le_eq_subst: "a <= b ==> f b = c ==> | |
| 2174 | (!!x y. x <= y ==> f x <= f y) ==> f a <= c" | |
| 2175 | proof - | |
| 2176 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2177 | assume "a <= b" hence "f a <= f b" by (rule r) | |
| 2178 | also assume "f b = c" | |
| 2179 | finally (ord_le_eq_trans) show ?thesis . | |
| 2180 | qed | |
| 2181 | ||
| 2182 | lemma ord_eq_le_subst: "a = f b ==> b <= c ==> | |
| 2183 | (!!x y. x <= y ==> f x <= f y) ==> a <= f c" | |
| 2184 | proof - | |
| 2185 | assume r: "!!x y. x <= y ==> f x <= f y" | |
| 2186 | assume "a = f b" | |
| 2187 | also assume "b <= c" hence "f b <= f c" by (rule r) | |
| 2188 | finally (ord_eq_le_trans) show ?thesis . | |
| 2189 | qed | |
| 2190 | ||
| 2191 | lemma ord_less_eq_subst: "a < b ==> f b = c ==> | |
| 2192 | (!!x y. x < y ==> f x < f y) ==> f a < c" | |
| 2193 | proof - | |
| 2194 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2195 | assume "a < b" hence "f a < f b" by (rule r) | |
| 2196 | also assume "f b = c" | |
| 2197 | finally (ord_less_eq_trans) show ?thesis . | |
| 2198 | qed | |
| 2199 | ||
| 2200 | lemma ord_eq_less_subst: "a = f b ==> b < c ==> | |
| 2201 | (!!x y. x < y ==> f x < f y) ==> a < f c" | |
| 2202 | proof - | |
| 2203 | assume r: "!!x y. x < y ==> f x < f y" | |
| 2204 | assume "a = f b" | |
| 2205 | also assume "b < c" hence "f b < f c" by (rule r) | |
| 2206 | finally (ord_eq_less_trans) show ?thesis . | |
| 2207 | qed | |
| 2208 | ||
| 2209 | text {*
 | |
| 2210 | Note that this list of rules is in reverse order of priorities. | |
| 2211 | *} | |
| 2212 | ||
| 2213 | lemmas basic_trans_rules [trans] = | |
| 2214 | order_less_subst2 | |
| 2215 | order_less_subst1 | |
| 2216 | order_le_less_subst2 | |
| 2217 | order_le_less_subst1 | |
| 2218 | order_less_le_subst2 | |
| 2219 | order_less_le_subst1 | |
| 2220 | order_subst2 | |
| 2221 | order_subst1 | |
| 2222 | ord_le_eq_subst | |
| 2223 | ord_eq_le_subst | |
| 2224 | ord_less_eq_subst | |
| 2225 | ord_eq_less_subst | |
| 2226 | forw_subst | |
| 2227 | back_subst | |
| 2228 | rev_mp | |
| 2229 | mp | |
| 2230 | set_rev_mp | |
| 2231 | set_mp | |
| 2232 | order_neq_le_trans | |
| 2233 | order_le_neq_trans | |
| 2234 | order_less_trans | |
| 2235 | order_less_asym' | |
| 2236 | order_le_less_trans | |
| 2237 | order_less_le_trans | |
| 2238 | order_trans | |
| 2239 | order_antisym | |
| 2240 | ord_le_eq_trans | |
| 2241 | ord_eq_le_trans | |
| 2242 | ord_less_eq_trans | |
| 2243 | ord_eq_less_trans | |
| 2244 | trans | |
| 2245 | ||
| 11979 | 2246 | end |