src/HOL/Predicate.thy
changeset 32883 7cbd93dacef3
parent 32782 faf347097852
child 33104 560372b461e5
--- a/src/HOL/Predicate.thy	Tue Oct 06 15:51:34 2009 +0200
+++ b/src/HOL/Predicate.thy	Tue Oct 06 18:44:06 2009 +0200
@@ -60,29 +60,23 @@
 
 subsubsection {* Binary union *}
 
-lemma sup1_iff: "sup A B x \<longleftrightarrow> A x | B x"
+lemma sup1I1 [elim?]: "A x \<Longrightarrow> sup A B x"
   by (simp add: sup_fun_eq sup_bool_eq)
 
-lemma sup2_iff: "sup A B x y \<longleftrightarrow> A x y | B x y"
+lemma sup2I1 [elim?]: "A x y \<Longrightarrow> sup A B x y"
+  by (simp add: sup_fun_eq sup_bool_eq)
+
+lemma sup1I2 [elim?]: "B x \<Longrightarrow> sup A B x"
   by (simp add: sup_fun_eq sup_bool_eq)
 
-lemma sup_Un_eq: "sup (\<lambda>x. x \<in> R) (\<lambda>x. x \<in> S) = (\<lambda>x. x \<in> R \<union> S)"
-  by (simp add: sup1_iff expand_fun_eq)
-
-lemma sup_Un_eq2 [pred_set_conv]: "sup (\<lambda>x y. (x, y) \<in> R) (\<lambda>x y. (x, y) \<in> S) = (\<lambda>x y. (x, y) \<in> R \<union> S)"
-  by (simp add: sup2_iff expand_fun_eq)
-
-lemma sup1I1 [elim?]: "A x \<Longrightarrow> sup A B x"
-  by (simp add: sup1_iff)
+lemma sup2I2 [elim?]: "B x y \<Longrightarrow> sup A B x y"
+  by (simp add: sup_fun_eq sup_bool_eq)
 
-lemma sup2I1 [elim?]: "A x y \<Longrightarrow> sup A B x y"
-  by (simp add: sup2_iff)
+lemma sup1E [elim!]: "sup A B x ==> (A x ==> P) ==> (B x ==> P) ==> P"
+  by (simp add: sup_fun_eq sup_bool_eq) iprover
 
-lemma sup1I2 [elim?]: "B x \<Longrightarrow> sup A B x"
-  by (simp add: sup1_iff)
-
-lemma sup2I2 [elim?]: "B x y \<Longrightarrow> sup A B x y"
-  by (simp add: sup2_iff)
+lemma sup2E [elim!]: "sup A B x y ==> (A x y ==> P) ==> (B x y ==> P) ==> P"
+  by (simp add: sup_fun_eq sup_bool_eq) iprover
 
 text {*
   \medskip Classical introduction rule: no commitment to @{text A} vs
@@ -90,55 +84,49 @@
 *}
 
 lemma sup1CI [intro!]: "(~ B x ==> A x) ==> sup A B x"
-  by (auto simp add: sup1_iff)
+  by (auto simp add: sup_fun_eq sup_bool_eq)
 
 lemma sup2CI [intro!]: "(~ B x y ==> A x y) ==> sup A B x y"
-  by (auto simp add: sup2_iff)
+  by (auto simp add: sup_fun_eq sup_bool_eq)
 
-lemma sup1E [elim!]: "sup A B x ==> (A x ==> P) ==> (B x ==> P) ==> P"
-  by (simp add: sup1_iff) iprover
+lemma sup_Un_eq: "sup (\<lambda>x. x \<in> R) (\<lambda>x. x \<in> S) = (\<lambda>x. x \<in> R \<union> S)"
+  by (simp add: sup_fun_eq sup_bool_eq mem_def)
 
-lemma sup2E [elim!]: "sup A B x y ==> (A x y ==> P) ==> (B x y ==> P) ==> P"
-  by (simp add: sup2_iff) iprover
+lemma sup_Un_eq2 [pred_set_conv]: "sup (\<lambda>x y. (x, y) \<in> R) (\<lambda>x y. (x, y) \<in> S) = (\<lambda>x y. (x, y) \<in> R \<union> S)"
+  by (simp add: sup_fun_eq sup_bool_eq mem_def)
 
 
 subsubsection {* Binary intersection *}
 
-lemma inf1_iff: "inf A B x \<longleftrightarrow> A x \<and> B x"
+lemma inf1I [intro!]: "A x ==> B x ==> inf A B x"
+  by (simp add: inf_fun_eq inf_bool_eq)
+
+lemma inf2I [intro!]: "A x y ==> B x y ==> inf A B x y"
+  by (simp add: inf_fun_eq inf_bool_eq)
+
+lemma inf1E [elim!]: "inf A B x ==> (A x ==> B x ==> P) ==> P"
   by (simp add: inf_fun_eq inf_bool_eq)
 
-lemma inf2_iff: "inf A B x y \<longleftrightarrow> A x y \<and> B x y"
+lemma inf2E [elim!]: "inf A B x y ==> (A x y ==> B x y ==> P) ==> P"
+  by (simp add: inf_fun_eq inf_bool_eq)
+
+lemma inf1D1: "inf A B x ==> A x"
+  by (simp add: inf_fun_eq inf_bool_eq)
+
+lemma inf2D1: "inf A B x y ==> A x y"
+  by (simp add: inf_fun_eq inf_bool_eq)
+
+lemma inf1D2: "inf A B x ==> B x"
+  by (simp add: inf_fun_eq inf_bool_eq)
+
+lemma inf2D2: "inf A B x y ==> B x y"
   by (simp add: inf_fun_eq inf_bool_eq)
 
 lemma inf_Int_eq: "inf (\<lambda>x. x \<in> R) (\<lambda>x. x \<in> S) = (\<lambda>x. x \<in> R \<inter> S)"
-  by (simp add: inf1_iff expand_fun_eq)
+  by (simp add: inf_fun_eq inf_bool_eq mem_def)
 
 lemma inf_Int_eq2 [pred_set_conv]: "inf (\<lambda>x y. (x, y) \<in> R) (\<lambda>x y. (x, y) \<in> S) = (\<lambda>x y. (x, y) \<in> R \<inter> S)"
-  by (simp add: inf2_iff expand_fun_eq)
-
-lemma inf1I [intro!]: "A x ==> B x ==> inf A B x"
-  by (simp add: inf1_iff)
-
-lemma inf2I [intro!]: "A x y ==> B x y ==> inf A B x y"
-  by (simp add: inf2_iff)
-
-lemma inf1D1: "inf A B x ==> A x"
-  by (simp add: inf1_iff)
-
-lemma inf2D1: "inf A B x y ==> A x y"
-  by (simp add: inf2_iff)
-
-lemma inf1D2: "inf A B x ==> B x"
-  by (simp add: inf1_iff)
-
-lemma inf2D2: "inf A B x y ==> B x y"
-  by (simp add: inf2_iff)
-
-lemma inf1E [elim!]: "inf A B x ==> (A x ==> B x ==> P) ==> P"
-  by (simp add: inf1_iff)
-
-lemma inf2E [elim!]: "inf A B x y ==> (A x y ==> B x y ==> P) ==> P"
-  by (simp add: inf2_iff)
+  by (simp add: inf_fun_eq inf_bool_eq mem_def)
 
 
 subsubsection {* Unions of families *}
@@ -447,10 +435,10 @@
   unfolding bot_pred_def by auto
 
 lemma supI1: "eval A x \<Longrightarrow> eval (A \<squnion> B) x"
-  unfolding sup_pred_def by (simp add: sup1_iff)
+  unfolding sup_pred_def by (simp add: sup_fun_eq sup_bool_eq)
 
 lemma supI2: "eval B x \<Longrightarrow> eval (A \<squnion> B) x" 
-  unfolding sup_pred_def by (simp add: sup1_iff)
+  unfolding sup_pred_def by (simp add: sup_fun_eq sup_bool_eq)
 
 lemma supE: "eval (A \<squnion> B) x \<Longrightarrow> (eval A x \<Longrightarrow> P) \<Longrightarrow> (eval B x \<Longrightarrow> P) \<Longrightarrow> P"
   unfolding sup_pred_def by auto