merged
authorhaftmann
Tue, 06 Oct 2009 20:19:54 +0200
changeset 32884 a0737458da18
parent 32882 bfb3e24a4936 (current diff)
parent 32883 7cbd93dacef3 (diff)
child 32885 5cab25b2dcf9
merged
--- a/src/HOL/Predicate.thy	Tue Oct 06 20:00:08 2009 +0200
+++ b/src/HOL/Predicate.thy	Tue Oct 06 20:19:54 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
--- a/src/HOL/Transitive_Closure.thy	Tue Oct 06 20:00:08 2009 +0200
+++ b/src/HOL/Transitive_Closure.thy	Tue Oct 06 20:19:54 2009 +0200
@@ -76,8 +76,8 @@
 
 subsection {* Reflexive-transitive closure *}
 
-lemma reflcl_set_eq [pred_set_conv]: "(sup (\<lambda>x y. (x, y) \<in> r) op =) = (\<lambda>x y. (x, y) \<in> r Un Id)"
-  by (simp add: expand_fun_eq sup2_iff)
+lemma reflcl_set_eq [pred_set_conv]: "(sup (\<lambda>x y. (x, y) \<in> r) op =) = (\<lambda>x y. (x, y) \<in> r \<union> Id)"
+  by (simp add: mem_def pair_in_Id_conv [simplified mem_def] sup_fun_eq sup_bool_eq)
 
 lemma r_into_rtrancl [intro]: "!!p. p \<in> r ==> p \<in> r^*"
   -- {* @{text rtrancl} of @{text r} contains @{text r} *}