tuned proofs;
authorwenzelm
Sat, 20 Jun 2015 22:20:27 +0200
changeset 60539 f909f1a5cb22
parent 60538 b9add7665d7a
child 60540 b7b71952c194
tuned proofs;
src/HOL/Decision_Procs/Dense_Linear_Order.thy
--- a/src/HOL/Decision_Procs/Dense_Linear_Order.thy	Sat Jun 20 20:55:31 2015 +0200
+++ b/src/HOL/Decision_Procs/Dense_Linear_Order.thy	Sat Jun 20 22:20:27 2015 +0200
@@ -18,7 +18,7 @@
 lemma less_not_permute[no_atp]: "\<not> (x < y \<and> y < x)"
   by (simp add: not_less linear)
 
-lemma gather_simps[no_atp]: 
+lemma gather_simps[no_atp]:
   "(\<exists>x. (\<forall>y \<in> L. y < x) \<and> (\<forall>y \<in> U. x < y) \<and> x < u \<and> P x) \<longleftrightarrow>
     (\<exists>x. (\<forall>y \<in> L. y < x) \<and> (\<forall>y \<in> (insert u U). x < y) \<and> P x)"
   "(\<exists>x. (\<forall>y \<in> L. y < x) \<and> (\<forall>y \<in> U. x < y) \<and> l < x \<and> P x) \<longleftrightarrow>
@@ -29,7 +29,7 @@
     (\<exists>x. (\<forall>y \<in> (insert l L). y < x) \<and> (\<forall>y \<in> U. x < y))"
   by auto
 
-lemma gather_start [no_atp]: "(\<exists>x. P x) \<equiv> (\<exists>x. (\<forall>y \<in> {}. y < x) \<and> (\<forall>y\<in> {}. x < y) \<and> P x)" 
+lemma gather_start [no_atp]: "(\<exists>x. P x) \<equiv> (\<exists>x. (\<forall>y \<in> {}. y < x) \<and> (\<forall>y\<in> {}. x < y) \<and> P x)"
   by simp
 
 text\<open>Theorems for @{text "\<exists>z. \<forall>x. x < z \<longrightarrow> (P x \<longleftrightarrow> P\<^sub>-\<^sub>\<infinity>)"}\<close>
@@ -56,184 +56,248 @@
 lemma pinf_neq[no_atp]: "\<exists>z. \<forall>x. z < x \<longrightarrow> (x \<noteq> t \<longleftrightarrow> True)" by auto
 lemma pinf_P[no_atp]: "\<exists>z. \<forall>x. z < x \<longrightarrow> (P \<longleftrightarrow> P)" by blast
 
-lemma nmi_lt[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> x < t \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)" by auto
-lemma nmi_gt[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and> t < x \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)"
+lemma nmi_lt[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> x < t \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)" by auto
+lemma nmi_gt[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and> t < x \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)"
   by (auto simp add: le_less)
-lemma  nmi_le[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> x\<le> t \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)" by auto
-lemma  nmi_ge[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and> t\<le> x \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)" by auto
-lemma  nmi_eq[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and>  x = t \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)" by auto
-lemma  nmi_neq[no_atp]: "t \<in> U \<Longrightarrow>\<forall>x. \<not>True \<and> x \<noteq> t \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)" by auto
-lemma  nmi_P[no_atp]: "\<forall> x. ~P \<and> P \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)" by auto
-lemma  nmi_conj[no_atp]: "\<lbrakk>\<forall>x. \<not>P1' \<and> P1 x \<longrightarrow>  (\<exists> u\<in> U. u \<le> x) ;
-  \<forall>x. \<not>P2' \<and> P2 x \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)\<rbrakk> \<Longrightarrow>
-  \<forall>x. \<not>(P1' \<and> P2') \<and> (P1 x \<and> P2 x) \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)" by auto
-lemma  nmi_disj[no_atp]: "\<lbrakk>\<forall>x. \<not>P1' \<and> P1 x \<longrightarrow>  (\<exists> u\<in> U. u \<le> x) ;
-  \<forall>x. \<not>P2' \<and> P2 x \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)\<rbrakk> \<Longrightarrow>
-  \<forall>x. \<not>(P1' \<or> P2') \<and> (P1 x \<or> P2 x) \<longrightarrow>  (\<exists> u\<in> U. u \<le> x)" by auto
+lemma  nmi_le[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> x\<le> t \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)" by auto
+lemma  nmi_ge[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and> t\<le> x \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)" by auto
+lemma  nmi_eq[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and>  x = t \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)" by auto
+lemma  nmi_neq[no_atp]: "t \<in> U \<Longrightarrow>\<forall>x. \<not>True \<and> x \<noteq> t \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)" by auto
+lemma  nmi_P[no_atp]: "\<forall>x. ~P \<and> P \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)" by auto
+lemma  nmi_conj[no_atp]: "\<lbrakk>\<forall>x. \<not>P1' \<and> P1 x \<longrightarrow>  (\<exists>u\<in> U. u \<le> x) ;
+  \<forall>x. \<not>P2' \<and> P2 x \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)\<rbrakk> \<Longrightarrow>
+  \<forall>x. \<not>(P1' \<and> P2') \<and> (P1 x \<and> P2 x) \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)" by auto
+lemma  nmi_disj[no_atp]: "\<lbrakk>\<forall>x. \<not>P1' \<and> P1 x \<longrightarrow>  (\<exists>u\<in> U. u \<le> x) ;
+  \<forall>x. \<not>P2' \<and> P2 x \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)\<rbrakk> \<Longrightarrow>
+  \<forall>x. \<not>(P1' \<or> P2') \<and> (P1 x \<or> P2 x) \<longrightarrow>  (\<exists>u\<in> U. u \<le> x)" by auto
 
-lemma  npi_lt[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and>  x < t \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)" by (auto simp add: le_less)
-lemma  npi_gt[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> t < x \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)" by auto
-lemma  npi_le[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and>  x \<le> t \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)" by auto
-lemma  npi_ge[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> t \<le> x \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)" by auto
-lemma  npi_eq[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and>  x = t \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)" by auto
-lemma  npi_neq[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> x \<noteq> t \<longrightarrow>  (\<exists> u\<in> U. x \<le> u )" by auto
-lemma  npi_P[no_atp]: "\<forall> x. ~P \<and> P \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)" by auto
-lemma  npi_conj[no_atp]: "\<lbrakk>\<forall>x. \<not>P1' \<and> P1 x \<longrightarrow>  (\<exists> u\<in> U. x \<le> u) ;  \<forall>x. \<not>P2' \<and> P2 x \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)\<rbrakk>
-  \<Longrightarrow>  \<forall>x. \<not>(P1' \<and> P2') \<and> (P1 x \<and> P2 x) \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)" by auto
-lemma  npi_disj[no_atp]: "\<lbrakk>\<forall>x. \<not>P1' \<and> P1 x \<longrightarrow>  (\<exists> u\<in> U. x \<le> u) ; \<forall>x. \<not>P2' \<and> P2 x \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)\<rbrakk>
-  \<Longrightarrow> \<forall>x. \<not>(P1' \<or> P2') \<and> (P1 x \<or> P2 x) \<longrightarrow>  (\<exists> u\<in> U. x \<le> u)" by auto
+lemma  npi_lt[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and>  x < t \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)" by (auto simp add: le_less)
+lemma  npi_gt[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> t < x \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)" by auto
+lemma  npi_le[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and>  x \<le> t \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)" by auto
+lemma  npi_ge[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> t \<le> x \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)" by auto
+lemma  npi_eq[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>False \<and>  x = t \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)" by auto
+lemma  npi_neq[no_atp]: "t \<in> U \<Longrightarrow> \<forall>x. \<not>True \<and> x \<noteq> t \<longrightarrow>  (\<exists>u\<in> U. x \<le> u )" by auto
+lemma  npi_P[no_atp]: "\<forall>x. ~P \<and> P \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)" by auto
+lemma  npi_conj[no_atp]: "\<lbrakk>\<forall>x. \<not>P1' \<and> P1 x \<longrightarrow>  (\<exists>u\<in> U. x \<le> u) ;  \<forall>x. \<not>P2' \<and> P2 x \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)\<rbrakk>
+  \<Longrightarrow>  \<forall>x. \<not>(P1' \<and> P2') \<and> (P1 x \<and> P2 x) \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)" by auto
+lemma  npi_disj[no_atp]: "\<lbrakk>\<forall>x. \<not>P1' \<and> P1 x \<longrightarrow>  (\<exists>u\<in> U. x \<le> u) ; \<forall>x. \<not>P2' \<and> P2 x \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)\<rbrakk>
+  \<Longrightarrow> \<forall>x. \<not>(P1' \<or> P2') \<and> (P1 x \<or> P2 x) \<longrightarrow>  (\<exists>u\<in> U. x \<le> u)" by auto
 
 lemma lin_dense_lt[no_atp]:
   "t \<in> U \<Longrightarrow>
-    \<forall>x l u. (\<forall> t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> x < t \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> y < t)"
-proof(clarsimp)
+    \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> x < t \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> y < t)"
+proof clarsimp
   fix x l u y
-  assume tU: "t \<in> U" and noU: "\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U" and lx: "l < x"
-    and xu: "x<u"  and px: "x < t" and ly: "l<y" and yu:"y < u"
-  from tU noU ly yu have tny: "t\<noteq>y" by auto
-  { assume H: "t < y"
-    from less_trans[OF lx px] less_trans[OF H yu]
-    have "l < t \<and> t < u" by simp
-    with tU noU have "False" by auto }
-  then have "\<not> t < y" by auto
-  then have "y \<le> t" by (simp add: not_less)
-  then show "y < t" using tny by (simp add: less_le)
+  assume tU: "t \<in> U"
+    and noU: "\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U"
+    and lx: "l < x"
+    and xu: "x < u"
+    and px: "x < t"
+    and ly: "l < y"
+    and yu: "y < u"
+  from tU noU ly yu have tny: "t \<noteq> y" by auto
+  have False if H: "t < y"
+  proof -
+    from less_trans[OF lx px] less_trans[OF H yu] have "l < t \<and> t < u"
+      by simp
+    with tU noU show ?thesis
+      by auto
+  qed
+  then have "\<not> t < y"
+    by auto
+  then have "y \<le> t"
+    by (simp add: not_less)
+  then show "y < t"
+    using tny by (simp add: less_le)
 qed
 
 lemma lin_dense_gt[no_atp]:
   "t \<in> U \<Longrightarrow>
-    \<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> t < x \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> t < y)"
-proof(clarsimp)
+    \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> t < x \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> t < y)"
+proof clarsimp
   fix x l u y
-  assume tU: "t \<in> U" and noU: "\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U" and lx: "l < x" and xu: "x<u"
-    and px: "t < x" and ly: "l<y" and yu:"y < u"
-  from tU noU ly yu have tny: "t\<noteq>y" by auto
-  { assume H: "y< t"
-    from less_trans[OF ly H] less_trans[OF px xu] have "l < t \<and> t < u" by simp
-    with tU noU have "False" by auto }
-  then have "\<not> y<t" by auto
-  then have "t \<le> y" by (auto simp add: not_less)
-  then show "t < y" using tny by (simp add: less_le)
+  assume tU: "t \<in> U"
+    and noU: "\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U"
+    and lx: "l < x"
+    and xu: "x < u"
+    and px: "t < x"
+    and ly: "l < y"
+    and yu: "y < u"
+  from tU noU ly yu have tny: "t \<noteq> y" by auto
+  have False if H: "y < t"
+  proof -
+    from less_trans[OF ly H] less_trans[OF px xu] have "l < t \<and> t < u"
+      by simp
+    with tU noU show ?thesis
+      by auto
+  qed
+  then have "\<not> y < t"
+    by auto
+  then have "t \<le> y"
+    by (auto simp add: not_less)
+  then show "t < y"
+    using tny by (simp add: less_le)
 qed
 
 lemma lin_dense_le[no_atp]:
   "t \<in> U \<Longrightarrow>
-    \<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> x \<le> t \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> y\<le> t)"
-proof(clarsimp)
+    \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> x \<le> t \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> y \<le> t)"
+proof clarsimp
   fix x l u y
-  assume tU: "t \<in> U" and noU: "\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U" and lx: "l < x" and xu: "x<u"
-    and px: "x \<le> t" and ly: "l<y" and yu:"y < u"
-  from tU noU ly yu have tny: "t\<noteq>y" by auto
-  { assume H: "t < y"
+  assume tU: "t \<in> U"
+    and noU: "\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U"
+    and lx: "l < x"
+    and xu: "x < u"
+    and px: "x \<le> t"
+    and ly: "l < y"
+    and yu: "y < u"
+  from tU noU ly yu have tny: "t \<noteq> y" by auto
+  have False if H: "t < y"
+  proof -
     from less_le_trans[OF lx px] less_trans[OF H yu]
     have "l < t \<and> t < u" by simp
-    with tU noU have "False" by auto }
+    with tU noU show ?thesis by auto
+  qed
   then have "\<not> t < y" by auto
   then show "y \<le> t" by (simp add: not_less)
 qed
 
 lemma lin_dense_ge[no_atp]:
   "t \<in> U \<Longrightarrow>
-    \<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> t \<le> x \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> t \<le> y)"
-proof(clarsimp)
+    \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> t \<le> x \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> t \<le> y)"
+proof clarsimp
   fix x l u y
-  assume tU: "t \<in> U" and noU: "\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U" and lx: "l < x" and xu: "x<u"
-    and px: "t \<le> x" and ly: "l<y" and yu:"y < u"
-  from tU noU ly yu have tny: "t\<noteq>y" by auto
-  { assume H: "y< t"
+  assume tU: "t \<in> U"
+    and noU: "\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U"
+    and lx: "l < x"
+    and xu: "x < u"
+    and px: "t \<le> x"
+    and ly: "l < y"
+    and yu: "y < u"
+  from tU noU ly yu have tny: "t \<noteq> y" by auto
+  have False if H: "y < t"
+  proof -
     from less_trans[OF ly H] le_less_trans[OF px xu]
     have "l < t \<and> t < u" by simp
-    with tU noU have "False" by auto }
-  then have "\<not> y<t" by auto
+    with tU noU show ?thesis by auto
+  qed
+  then have "\<not> y < t" by auto
   then show "t \<le> y" by (simp add: not_less)
 qed
 
 lemma lin_dense_eq[no_atp]:
   "t \<in> U \<Longrightarrow>
-    \<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> x = t   \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> y= t)"
+    \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> x = t \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> y = t)"
   by auto
 
 lemma lin_dense_neq[no_atp]:
   "t \<in> U \<Longrightarrow>
-    \<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> x \<noteq> t   \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> y\<noteq> t)"
+    \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> x \<noteq> t \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> y \<noteq> t)"
   by auto
 
 lemma lin_dense_P[no_atp]:
-  "\<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> P   \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> P)"
+  "\<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> P \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> P)"
   by auto
 
 lemma lin_dense_conj[no_atp]:
-  "\<lbrakk>\<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> P1 x
-  \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> P1 y) ;
-  \<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> P2 x
-  \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> P2 y)\<rbrakk> \<Longrightarrow>
-  \<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> (P1 x \<and> P2 x)
-  \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> (P1 y \<and> P2 y))"
+  "\<lbrakk>\<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> P1 x
+  \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> P1 y) ;
+  \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> P2 x
+  \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> P2 y)\<rbrakk> \<Longrightarrow>
+  \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> (P1 x \<and> P2 x)
+  \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> (P1 y \<and> P2 y))"
   by blast
 lemma lin_dense_disj[no_atp]:
-  "\<lbrakk>\<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> P1 x
-  \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> P1 y) ;
-  \<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> P2 x
-  \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> P2 y)\<rbrakk> \<Longrightarrow>
-  \<forall>x l u. (\<forall> t. l < t \<and> t< u \<longrightarrow> t \<notin> U) \<and> l< x \<and> x < u \<and> (P1 x \<or> P2 x)
-  \<longrightarrow> (\<forall> y. l < y \<and> y < u \<longrightarrow> (P1 y \<or> P2 y))"
+  "\<lbrakk>\<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> P1 x
+  \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> P1 y) ;
+  \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> P2 x
+  \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> P2 y)\<rbrakk> \<Longrightarrow>
+  \<forall>x l u. (\<forall>t. l < t \<and> t < u \<longrightarrow> t \<notin> U) \<and> l < x \<and> x < u \<and> (P1 x \<or> P2 x)
+  \<longrightarrow> (\<forall>y. l < y \<and> y < u \<longrightarrow> (P1 y \<or> P2 y))"
   by blast
 
-lemma npmibnd[no_atp]: "\<lbrakk>\<forall>x. \<not> MP \<and> P x \<longrightarrow> (\<exists> u\<in> U. u \<le> x); \<forall>x. \<not>PP \<and> P x \<longrightarrow> (\<exists> u\<in> U. x \<le> u)\<rbrakk>
-  \<Longrightarrow> \<forall>x. \<not> MP \<and> \<not>PP \<and> P x \<longrightarrow> (\<exists> u\<in> U. \<exists> u' \<in> U. u \<le> x \<and> x \<le> u')"
+lemma npmibnd[no_atp]: "\<lbrakk>\<forall>x. \<not> MP \<and> P x \<longrightarrow> (\<exists>u\<in> U. u \<le> x); \<forall>x. \<not>PP \<and> P x \<longrightarrow> (\<exists>u\<in> U. x \<le> u)\<rbrakk>
+  \<Longrightarrow> \<forall>x. \<not> MP \<and> \<not>PP \<and> P x \<longrightarrow> (\<exists>u\<in> U. \<exists>u' \<in> U. u \<le> x \<and> x \<le> u')"
   by auto
 
 lemma finite_set_intervals[no_atp]:
-  assumes px: "P x" and lx: "l \<le> x" and xu: "x \<le> u" and linS: "l\<in> S"
-    and uinS: "u \<in> S" and fS:"finite S" and lS: "\<forall> x\<in> S. l \<le> x" and Su: "\<forall> x\<in> S. x \<le> u"
-  shows "\<exists> a \<in> S. \<exists> b \<in> S. (\<forall> y. a < y \<and> y < b \<longrightarrow> y \<notin> S) \<and> a \<le> x \<and> x \<le> b \<and> P x"
+  assumes px: "P x"
+    and lx: "l \<le> x"
+    and xu: "x \<le> u"
+    and linS: "l\<in> S"
+    and uinS: "u \<in> S"
+    and fS:"finite S"
+    and lS: "\<forall>x\<in> S. l \<le> x"
+    and Su: "\<forall>x\<in> S. x \<le> u"
+  shows "\<exists>a \<in> S. \<exists>b \<in> S. (\<forall>y. a < y \<and> y < b \<longrightarrow> y \<notin> S) \<and> a \<le> x \<and> x \<le> b \<and> P x"
 proof -
   let ?Mx = "{y. y\<in> S \<and> y \<le> x}"
   let ?xM = "{y. y\<in> S \<and> x \<le> y}"
   let ?a = "Max ?Mx"
   let ?b = "Min ?xM"
-  have MxS: "?Mx \<subseteq> S" by blast
-  hence fMx: "finite ?Mx" using fS finite_subset by auto
-  from lx linS have linMx: "l \<in> ?Mx" by blast
-  hence Mxne: "?Mx \<noteq> {}" by blast
-  have xMS: "?xM \<subseteq> S" by blast
-  hence fxM: "finite ?xM" using fS finite_subset by auto
-  from xu uinS have linxM: "u \<in> ?xM" by blast
-  hence xMne: "?xM \<noteq> {}" by blast
-  have ax:"?a \<le> x" using Mxne fMx by auto
-  have xb:"x \<le> ?b" using xMne fxM by auto
-  have "?a \<in> ?Mx" using Max_in[OF fMx Mxne] by simp hence ainS: "?a \<in> S" using MxS by blast
-  have "?b \<in> ?xM" using Min_in[OF fxM xMne] by simp hence binS: "?b \<in> S" using xMS by blast
-  have noy:"\<forall> y. ?a < y \<and> y < ?b \<longrightarrow> y \<notin> S"
-  proof(clarsimp)
+  have MxS: "?Mx \<subseteq> S"
+    by blast
+  then have fMx: "finite ?Mx"
+    using fS finite_subset by auto
+  from lx linS have linMx: "l \<in> ?Mx"
+    by blast
+  then have Mxne: "?Mx \<noteq> {}"
+    by blast
+  have xMS: "?xM \<subseteq> S"
+    by blast
+  then have fxM: "finite ?xM"
+    using fS finite_subset by auto
+  from xu uinS have linxM: "u \<in> ?xM"
+    by blast
+  then have xMne: "?xM \<noteq> {}"
+    by blast
+  have ax: "?a \<le> x"
+    using Mxne fMx by auto
+  have xb: "x \<le> ?b"
+    using xMne fxM by auto
+  have "?a \<in> ?Mx"
+    using Max_in[OF fMx Mxne] by simp then have ainS: "?a \<in> S" using MxS by blast
+  have "?b \<in> ?xM"
+    using Min_in[OF fxM xMne] by simp then have binS: "?b \<in> S" using xMS by blast
+  have noy: "\<forall>y. ?a < y \<and> y < ?b \<longrightarrow> y \<notin> S"
+  proof clarsimp
     fix y
     assume ay: "?a < y" and yb: "y < ?b" and yS: "y \<in> S"
-    from yS have "y\<in> ?Mx \<or> y\<in> ?xM" by (auto simp add: linear)
-    moreover {
+    from yS have "y \<in> ?Mx \<or> y \<in> ?xM" by (auto simp add: linear)
+    then show False
+    proof
       assume "y \<in> ?Mx"
-      hence "y \<le> ?a" using Mxne fMx by auto
-      with ay have "False" by (simp add: not_le[symmetric])
-    }
-    moreover {
+      then have "y \<le> ?a" using Mxne fMx by auto
+      with ay show ?thesis by (simp add: not_le[symmetric])
+    next
       assume "y \<in> ?xM"
-      hence "?b \<le> y" using xMne fxM by auto
-      with yb have "False" by (simp add: not_le[symmetric])
-    }
-    ultimately show False by blast
+      then have "?b \<le> y" using xMne fxM by auto
+      with yb show ?thesis by (simp add: not_le[symmetric])
+    qed
   qed
   from ainS binS noy ax xb px show ?thesis by blast
 qed
 
 lemma finite_set_intervals2[no_atp]:
-  assumes px: "P x" and lx: "l \<le> x" and xu: "x \<le> u" and linS: "l\<in> S"
-    and uinS: "u \<in> S" and fS:"finite S" and lS: "\<forall> x\<in> S. l \<le> x" and Su: "\<forall> x\<in> S. x \<le> u"
-  shows "(\<exists> s\<in> S. P s) \<or> (\<exists> a \<in> S. \<exists> b \<in> S. (\<forall> y. a < y \<and> y < b \<longrightarrow> y \<notin> S) \<and> a < x \<and> x < b \<and> P x)"
-proof-
+  assumes px: "P x"
+    and lx: "l \<le> x"
+    and xu: "x \<le> u"
+    and linS: "l\<in> S"
+    and uinS: "u \<in> S"
+    and fS: "finite S"
+    and lS: "\<forall>x\<in> S. l \<le> x"
+    and Su: "\<forall>x\<in> S. x \<le> u"
+  shows "(\<exists>s\<in> S. P s) \<or> (\<exists>a \<in> S. \<exists>b \<in> S. (\<forall>y. a < y \<and> y < b \<longrightarrow> y \<notin> S) \<and> a < x \<and> x < b \<and> P x)"
+proof -
   from finite_set_intervals[where P="P", OF px lx xu linS uinS fS lS Su]
-  obtain a and b where as: "a\<in> S" and bs: "b\<in> S" and noS:"\<forall>y. a < y \<and> y < b \<longrightarrow> y \<notin> S"
-    and axb: "a \<le> x \<and> x \<le> b \<and> P x" by auto
-  from axb have "x= a \<or> x= b \<or> (a < x \<and> x < b)" by (auto simp add: le_less)
-  thus ?thesis using px as bs noS by blast
+  obtain a and b where as: "a \<in> S" and bs: "b \<in> S"
+    and noS: "\<forall>y. a < y \<and> y < b \<longrightarrow> y \<notin> S"
+    and axb: "a \<le> x \<and> x \<le> b \<and> P x"
+    by auto
+  from axb have "x = a \<or> x = b \<or> (a < x \<and> x < b)"
+    by (auto simp add: le_less)
+  then show ?thesis
+    using px as bs noS by blast
 qed
 
 end
@@ -247,21 +311,26 @@
 lemma interval_empty_iff: "{y. x < y \<and> y < z} = {} \<longleftrightarrow> \<not> x < z"
   by (auto dest: dense)
 
-lemma dlo_qe_bnds[no_atp]: 
-  assumes ne: "L \<noteq> {}" and neU: "U \<noteq> {}" and fL: "finite L" and fU: "finite U"
-  shows "(\<exists>x. (\<forall>y \<in> L. y < x) \<and> (\<forall>y \<in> U. x < y)) \<equiv> (\<forall> l \<in> L. \<forall>u \<in> U. l < u)"
+lemma dlo_qe_bnds[no_atp]:
+  assumes ne: "L \<noteq> {}"
+    and neU: "U \<noteq> {}"
+    and fL: "finite L"
+    and fU: "finite U"
+  shows "(\<exists>x. (\<forall>y \<in> L. y < x) \<and> (\<forall>y \<in> U. x < y)) \<equiv> (\<forall>l \<in> L. \<forall>u \<in> U. l < u)"
 proof (simp only: atomize_eq, rule iffI)
   assume H: "\<exists>x. (\<forall>y\<in>L. y < x) \<and> (\<forall>y\<in>U. x < y)"
   then obtain x where xL: "\<forall>y\<in>L. y < x" and xU: "\<forall>y\<in>U. x < y" by blast
-  { fix l u assume l: "l \<in> L" and u: "u \<in> U"
+  have "l < u" if l: "l \<in> L" and u: "u \<in> U" for l u
+  proof -
     have "l < x" using xL l by blast
     also have "x < u" using xU u by blast
-    finally (less_trans) have "l < u" . }
+    finally show ?thesis .
+  qed
   then show "\<forall>l\<in>L. \<forall>u\<in>U. l < u" by blast
 next
   assume H: "\<forall>l\<in>L. \<forall>u\<in>U. l < u"
   let ?ML = "Max L"
-  let ?MU = "Min U"  
+  let ?MU = "Min U"
   from fL ne have th1: "?ML \<in> L" and th1': "\<forall>l\<in>L. l \<le> ?ML" by auto
   from fU neU have th2: "?MU \<in> U" and th2': "\<forall>u\<in>U. ?MU \<le> u" by auto
   from th1 th2 H have "?ML < ?MU" by auto
@@ -271,30 +340,32 @@
   ultimately show "\<exists>x. (\<forall>y\<in>L. y < x) \<and> (\<forall>y\<in>U. x < y)" by auto
 qed
 
-lemma dlo_qe_noub[no_atp]: 
-  assumes ne: "L \<noteq> {}" and fL: "finite L"
+lemma dlo_qe_noub[no_atp]:
+  assumes ne: "L \<noteq> {}"
+    and fL: "finite L"
   shows "(\<exists>x. (\<forall>y \<in> L. y < x) \<and> (\<forall>y \<in> {}. x < y)) \<equiv> True"
-proof(simp add: atomize_eq)
+proof (simp add: atomize_eq)
   from gt_ex[of "Max L"] obtain M where M: "Max L < M" by blast
   from ne fL have "\<forall>x \<in> L. x \<le> Max L" by simp
   with M have "\<forall>x\<in>L. x < M" by (auto intro: le_less_trans)
-  thus "\<exists>x. \<forall>y\<in>L. y < x" by blast
+  then show "\<exists>x. \<forall>y\<in>L. y < x" by blast
 qed
 
-lemma dlo_qe_nolb[no_atp]: 
-  assumes ne: "U \<noteq> {}" and fU: "finite U"
+lemma dlo_qe_nolb[no_atp]:
+  assumes ne: "U \<noteq> {}"
+    and fU: "finite U"
   shows "(\<exists>x. (\<forall>y \<in> {}. y < x) \<and> (\<forall>y \<in> U. x < y)) \<equiv> True"
-proof(simp add: atomize_eq)
+proof (simp add: atomize_eq)
   from lt_ex[of "Min U"] obtain M where M: "M < Min U" by blast
   from ne fU have "\<forall>x \<in> U. Min U \<le> x" by simp
   with M have "\<forall>x\<in>U. M < x" by (auto intro: less_le_trans)
-  thus "\<exists>x. \<forall>y\<in>U. x < y" by blast
+  then show "\<exists>x. \<forall>y\<in>U. x < y" by blast
 qed
 
-lemma exists_neq[no_atp]: "\<exists>(x::'a). x \<noteq> t" "\<exists>(x::'a). t \<noteq> x" 
+lemma exists_neq[no_atp]: "\<exists>(x::'a). x \<noteq> t" "\<exists>(x::'a). t \<noteq> x"
   using gt_ex[of t] by auto
 
-lemmas dlo_simps[no_atp] = order_refl less_irrefl not_less not_le exists_neq 
+lemmas dlo_simps[no_atp] = order_refl less_irrefl not_less not_le exists_neq
   le_less neq_iff linear less_not_permute
 
 lemma axiom[no_atp]: "class.unbounded_dense_linorder (op \<le>) (op <)"
@@ -315,8 +386,11 @@
 lemmas weak_dnf_simps[no_atp] = simp_thms dnf
 
 lemma nnf_simps[no_atp]:
-    "(\<not>(P \<and> Q)) = (\<not>P \<or> \<not>Q)" "(\<not>(P \<or> Q)) = (\<not>P \<and> \<not>Q)" "(P \<longrightarrow> Q) = (\<not>P \<or> Q)"
-    "(P = Q) = ((P \<and> Q) \<or> (\<not>P \<and> \<not> Q))" "(\<not> \<not>(P)) = P"
+  "(\<not>(P \<and> Q)) = (\<not>P \<or> \<not>Q)"
+  "(\<not>(P \<or> Q)) = (\<not>P \<and> \<not>Q)"
+  "(P \<longrightarrow> Q) = (\<not>P \<or> Q)"
+  "(P = Q) = ((P \<and> Q) \<or> (\<not>P \<and> \<not> Q))"
+  "(\<not> \<not>(P)) = P"
   by blast+
 
 lemma ex_distrib[no_atp]: "(\<exists>x. P x \<or> Q x) \<longleftrightarrow> ((\<exists>x. P x) \<or> (\<exists>x. Q x))" by blast
@@ -348,23 +422,23 @@
   assumes gt_ex: "\<exists>y. less x y"
 begin
 
-lemma ge_ex[no_atp]: "\<exists>y. x \<sqsubseteq> y" using gt_ex by auto
+lemma ge_ex[no_atp]: "\<exists>y. x \<sqsubseteq> y"
+  using gt_ex by auto
 
 text \<open>Theorems for @{text "\<exists>z. \<forall>x. z \<sqsubset> x \<longrightarrow> (P x \<longleftrightarrow> P\<^sub>+\<^sub>\<infinity>)"}\<close>
 lemma pinf_conj[no_atp]:
   assumes ex1: "\<exists>z1. \<forall>x. z1 \<sqsubset> x \<longrightarrow> (P1 x \<longleftrightarrow> P1')"
-  and ex2: "\<exists>z2. \<forall>x. z2 \<sqsubset> x \<longrightarrow> (P2 x \<longleftrightarrow> P2')"
+    and ex2: "\<exists>z2. \<forall>x. z2 \<sqsubset> x \<longrightarrow> (P2 x \<longleftrightarrow> P2')"
   shows "\<exists>z. \<forall>x. z \<sqsubset>  x \<longrightarrow> ((P1 x \<and> P2 x) \<longleftrightarrow> (P1' \<and> P2'))"
-proof-
+proof -
   from ex1 ex2 obtain z1 and z2 where z1: "\<forall>x. z1 \<sqsubset> x \<longrightarrow> (P1 x \<longleftrightarrow> P1')"
-     and z2: "\<forall>x. z2 \<sqsubset> x \<longrightarrow> (P2 x \<longleftrightarrow> P2')" by blast
+     and z2: "\<forall>x. z2 \<sqsubset> x \<longrightarrow> (P2 x \<longleftrightarrow> P2')"
+     by blast
   from gt_ex obtain z where z:"ord.max less_eq z1 z2 \<sqsubset> z" by blast
   from z have zz1: "z1 \<sqsubset> z" and zz2: "z2 \<sqsubset> z" by simp_all
-  { fix x assume H: "z \<sqsubset> x"
-    from less_trans[OF zz1 H] less_trans[OF zz2 H]
-    have "(P1 x \<and> P2 x) \<longleftrightarrow> (P1' \<and> P2')"  using z1 zz1 z2 zz2 by auto
-  }
-  thus ?thesis by blast
+  have "(P1 x \<and> P2 x) \<longleftrightarrow> (P1' \<and> P2')" if H: "z \<sqsubset> x" for x
+    using less_trans[OF zz1 H] less_trans[OF zz2 H] z1 zz1 z2 zz2 by auto
+  then show ?thesis by blast
 qed
 
 lemma pinf_disj[no_atp]:
@@ -376,14 +450,15 @@
      and z2: "\<forall>x. z2 \<sqsubset> x \<longrightarrow> (P2 x \<longleftrightarrow> P2')" by blast
   from gt_ex obtain z where z:"ord.max less_eq z1 z2 \<sqsubset> z" by blast
   from z have zz1: "z1 \<sqsubset> z" and zz2: "z2 \<sqsubset> z" by simp_all
-  { fix x assume H: "z \<sqsubset> x"
-    from less_trans[OF zz1 H] less_trans[OF zz2 H]
-    have "(P1 x \<or> P2 x) \<longleftrightarrow> (P1' \<or> P2')"  using z1 zz1 z2 zz2 by auto
-  }
-  thus ?thesis by blast
+  have "(P1 x \<or> P2 x) \<longleftrightarrow> (P1' \<or> P2')" if H: "z \<sqsubset> x" for x
+    using less_trans[OF zz1 H] less_trans[OF zz2 H] z1 zz1 z2 zz2 by auto
+  then show ?thesis by blast
 qed
 
-lemma pinf_ex[no_atp]: assumes ex:"\<exists>z. \<forall>x. z \<sqsubset> x \<longrightarrow> (P x \<longleftrightarrow> P1)" and p1: P1 shows "\<exists> x. P x"
+lemma pinf_ex[no_atp]:
+  assumes ex: "\<exists>z. \<forall>x. z \<sqsubset> x \<longrightarrow> (P x \<longleftrightarrow> P1)"
+    and p1: P1
+  shows "\<exists>x. P x"
 proof -
   from ex obtain z where z: "\<forall>x. z \<sqsubset> x \<longrightarrow> (P x \<longleftrightarrow> P1)" by blast
   from gt_ex obtain x where x: "z \<sqsubset> x" by blast
@@ -406,15 +481,15 @@
   assumes ex1: "\<exists>z1. \<forall>x. x \<sqsubset> z1 \<longrightarrow> (P1 x \<longleftrightarrow> P1')"
     and ex2: "\<exists>z2. \<forall>x. x \<sqsubset> z2 \<longrightarrow> (P2 x \<longleftrightarrow> P2')"
   shows "\<exists>z. \<forall>x. x \<sqsubset>  z \<longrightarrow> ((P1 x \<and> P2 x) \<longleftrightarrow> (P1' \<and> P2'))"
-proof-
-  from ex1 ex2 obtain z1 and z2 where z1: "\<forall>x. x \<sqsubset> z1 \<longrightarrow> (P1 x \<longleftrightarrow> P1')"and z2: "\<forall>x. x \<sqsubset> z2 \<longrightarrow> (P2 x \<longleftrightarrow> P2')" by blast
+proof -
+  from ex1 ex2 obtain z1 and z2 where z1: "\<forall>x. x \<sqsubset> z1 \<longrightarrow> (P1 x \<longleftrightarrow> P1')"
+    and z2: "\<forall>x. x \<sqsubset> z2 \<longrightarrow> (P2 x \<longleftrightarrow> P2')"
+    by blast
   from lt_ex obtain z where z:"z \<sqsubset> ord.min less_eq z1 z2" by blast
   from z have zz1: "z \<sqsubset> z1" and zz2: "z \<sqsubset> z2" by simp_all
-  { fix x assume H: "x \<sqsubset> z"
-    from less_trans[OF H zz1] less_trans[OF H zz2]
-    have "(P1 x \<and> P2 x) \<longleftrightarrow> (P1' \<and> P2')"  using z1 zz1 z2 zz2 by auto
-  }
-  thus ?thesis by blast
+  have "(P1 x \<and> P2 x) \<longleftrightarrow> (P1' \<and> P2')" if H: "x \<sqsubset> z" for x
+    using less_trans[OF H zz1] less_trans[OF H zz2] z1 zz1 z2 zz2 by auto
+  then show ?thesis by blast
 qed
 
 lemma minf_disj[no_atp]:
@@ -426,17 +501,15 @@
     and z2: "\<forall>x. x \<sqsubset> z2 \<longrightarrow> (P2 x \<longleftrightarrow> P2')" by blast
   from lt_ex obtain z where z:"z \<sqsubset> ord.min less_eq z1 z2" by blast
   from z have zz1: "z \<sqsubset> z1" and zz2: "z \<sqsubset> z2" by simp_all
-  { fix x assume H: "x \<sqsubset> z"
-    from less_trans[OF H zz1] less_trans[OF H zz2]
-    have "(P1 x \<or> P2 x) \<longleftrightarrow> (P1' \<or> P2')"  using z1 zz1 z2 zz2 by auto
-  }
-  thus ?thesis by blast
+  have "(P1 x \<or> P2 x) \<longleftrightarrow> (P1' \<or> P2')" if H: "x \<sqsubset> z" for x
+    using less_trans[OF H zz1] less_trans[OF H zz2] z1 zz1 z2 zz2 by auto
+  then show ?thesis by blast
 qed
 
 lemma minf_ex[no_atp]:
   assumes ex: "\<exists>z. \<forall>x. x \<sqsubset> z \<longrightarrow> (P x \<longleftrightarrow> P1)"
     and p1: P1
-  shows "\<exists> x. P x"
+  shows "\<exists>x. P x"
 proof -
   from ex obtain z where z: "\<forall>x. x \<sqsubset> z \<longrightarrow> (P x \<longleftrightarrow> P1)" by blast
   from lt_ex obtain x where x: "x \<sqsubset> z" by blast
@@ -452,7 +525,7 @@
     and between_same: "between x x = x"
 begin
 
-sublocale dlo: unbounded_dense_linorder 
+sublocale dlo: unbounded_dense_linorder
   apply unfold_locales
   using gt_ex lt_ex between_less
   apply auto
@@ -462,74 +535,104 @@
 
 lemma rinf_U[no_atp]:
   assumes fU: "finite U"
-    and lin_dense: "\<forall>x l u. (\<forall> t. l \<sqsubset> t \<and> t\<sqsubset> u \<longrightarrow> t \<notin> U) \<and> l\<sqsubset> x \<and> x \<sqsubset> u \<and> P x
-      \<longrightarrow> (\<forall> y. l \<sqsubset> y \<and> y \<sqsubset> u \<longrightarrow> P y )"
-    and nmpiU: "\<forall>x. \<not> MP \<and> \<not>PP \<and> P x \<longrightarrow> (\<exists> u\<in> U. \<exists> u' \<in> U. u \<sqsubseteq> x \<and> x \<sqsubseteq> u')"
-    and nmi: "\<not> MP"  and npi: "\<not> PP"  and ex: "\<exists> x.  P x"
-  shows "\<exists> u\<in> U. \<exists> u' \<in> U. P (between u u')"
+    and lin_dense: "\<forall>x l u. (\<forall>t. l \<sqsubset> t \<and> t\<sqsubset> u \<longrightarrow> t \<notin> U) \<and> l\<sqsubset> x \<and> x \<sqsubset> u \<and> P x
+      \<longrightarrow> (\<forall>y. l \<sqsubset> y \<and> y \<sqsubset> u \<longrightarrow> P y )"
+    and nmpiU: "\<forall>x. \<not> MP \<and> \<not>PP \<and> P x \<longrightarrow> (\<exists>u\<in> U. \<exists>u' \<in> U. u \<sqsubseteq> x \<and> x \<sqsubseteq> u')"
+    and nmi: "\<not> MP"  and npi: "\<not> PP"  and ex: "\<exists>x.  P x"
+  shows "\<exists>u\<in> U. \<exists>u' \<in> U. P (between u u')"
 proof -
-  from ex obtain x where px: "P x" by blast
-  from px nmi npi nmpiU have "\<exists> u\<in> U. \<exists> u' \<in> U. u \<sqsubseteq> x \<and> x \<sqsubseteq> u'" by auto
-  then obtain u and u' where uU:"u\<in> U" and uU': "u' \<in> U" and ux:"u \<sqsubseteq> x" and xu':"x \<sqsubseteq> u'" by auto
-  from uU have Une: "U \<noteq> {}" by auto
+  from ex obtain x where px: "P x"
+    by blast
+  from px nmi npi nmpiU have "\<exists>u\<in> U. \<exists>u' \<in> U. u \<sqsubseteq> x \<and> x \<sqsubseteq> u'"
+    by auto
+  then obtain u and u' where uU: "u\<in> U" and uU': "u' \<in> U" and ux: "u \<sqsubseteq> x" and xu': "x \<sqsubseteq> u'"
+    by auto
+  from uU have Une: "U \<noteq> {}"
+    by auto
   let ?l = "linorder.Min less_eq U"
   let ?u = "linorder.Max less_eq U"
-  have linM: "?l \<in> U" using fU Une by simp
-  have uinM: "?u \<in> U" using fU Une by simp
-  have lM: "\<forall> t\<in> U. ?l \<sqsubseteq> t" using Une fU by auto
-  have Mu: "\<forall> t\<in> U. t \<sqsubseteq> ?u" using Une fU by auto
-  have th:"?l \<sqsubseteq> u" using uU Une lM by auto
+  have linM: "?l \<in> U"
+    using fU Une by simp
+  have uinM: "?u \<in> U"
+    using fU Une by simp
+  have lM: "\<forall>t\<in> U. ?l \<sqsubseteq> t"
+    using Une fU by auto
+  have Mu: "\<forall>t\<in> U. t \<sqsubseteq> ?u"
+    using Une fU by auto
+  have th: "?l \<sqsubseteq> u"
+    using uU Une lM by auto
   from order_trans[OF th ux] have lx: "?l \<sqsubseteq> x" .
-  have th: "u' \<sqsubseteq> ?u" using uU' Une Mu by simp
+  have th: "u' \<sqsubseteq> ?u"
+    using uU' Une Mu by simp
   from order_trans[OF xu' th] have xu: "x \<sqsubseteq> ?u" .
   from finite_set_intervals2[where P="P",OF px lx xu linM uinM fU lM Mu]
-  have "(\<exists> s\<in> U. P s) \<or>
-      (\<exists> t1\<in> U. \<exists> t2 \<in> U. (\<forall> y. t1 \<sqsubset> y \<and> y \<sqsubset> t2 \<longrightarrow> y \<notin> U) \<and> t1 \<sqsubset> x \<and> x \<sqsubset> t2 \<and> P x)" .
-  moreover {
-    fix u assume um: "u\<in>U" and pu: "P u"
+  consider u where "u \<in> U" "P u" |
+    t1 t2 where "t1 \<in> U" "t2 \<in> U" "\<forall>y. t1 \<sqsubset> y \<and> y \<sqsubset> t2 \<longrightarrow> y \<notin> U" "t1 \<sqsubset> x" "x \<sqsubset> t2" "P x"
+    by blast
+  then show ?thesis
+  proof cases
+    case 1
     have "between u u = u" by (simp add: between_same)
-    with um pu have "P (between u u)" by simp
-    with um have ?thesis by blast }
-  moreover {
-    assume "\<exists> t1\<in> U. \<exists> t2 \<in> U. (\<forall> y. t1 \<sqsubset> y \<and> y \<sqsubset> t2 \<longrightarrow> y \<notin> U) \<and> t1 \<sqsubset> x \<and> x \<sqsubset> t2 \<and> P x"
-    then obtain t1 and t2 where t1M: "t1 \<in> U" and t2M: "t2\<in> U"
-      and noM: "\<forall> y. t1 \<sqsubset> y \<and> y \<sqsubset> t2 \<longrightarrow> y \<notin> U"
-      and t1x: "t1 \<sqsubset> x" and xt2: "x \<sqsubset> t2" and px: "P x" by blast
+    with 1 have "P (between u u)" by simp
+    with 1 show ?thesis by blast
+  next
+    case 2
+    note t1M = \<open>t1 \<in> U\<close> and t2M = \<open>t2\<in> U\<close>
+      and noM = \<open>\<forall>y. t1 \<sqsubset> y \<and> y \<sqsubset> t2 \<longrightarrow> y \<notin> U\<close>
+      and t1x = \<open>t1 \<sqsubset> x\<close> and xt2 = \<open>x \<sqsubset> t2\<close>
+      and px = \<open>P x\<close>
     from less_trans[OF t1x xt2] have t1t2: "t1 \<sqsubset> t2" .
     let ?u = "between t1 t2"
     from between_less t1t2 have t1lu: "t1 \<sqsubset> ?u" and ut2: "?u \<sqsubset> t2" by auto
     from lin_dense noM t1x xt2 px t1lu ut2 have "P ?u" by blast
-    with t1M t2M have ?thesis by blast
-  }
-  ultimately show ?thesis by blast
+    with t1M t2M show ?thesis by blast
+  qed
 qed
 
 theorem fr_eq[no_atp]:
   assumes fU: "finite U"
-    and lin_dense: "\<forall>x l u. (\<forall> t. l \<sqsubset> t \<and> t\<sqsubset> u \<longrightarrow> t \<notin> U) \<and> l\<sqsubset> x \<and> x \<sqsubset> u \<and> P x
-     \<longrightarrow> (\<forall> y. l \<sqsubset> y \<and> y \<sqsubset> u \<longrightarrow> P y )"
-    and nmibnd: "\<forall>x. \<not> MP \<and> P x \<longrightarrow> (\<exists> u\<in> U. u \<sqsubseteq> x)"
-    and npibnd: "\<forall>x. \<not>PP \<and> P x \<longrightarrow> (\<exists> u\<in> U. x \<sqsubseteq> u)"
+    and lin_dense: "\<forall>x l u. (\<forall>t. l \<sqsubset> t \<and> t\<sqsubset> u \<longrightarrow> t \<notin> U) \<and> l\<sqsubset> x \<and> x \<sqsubset> u \<and> P x
+     \<longrightarrow> (\<forall>y. l \<sqsubset> y \<and> y \<sqsubset> u \<longrightarrow> P y )"
+    and nmibnd: "\<forall>x. \<not> MP \<and> P x \<longrightarrow> (\<exists>u\<in> U. u \<sqsubseteq> x)"
+    and npibnd: "\<forall>x. \<not>PP \<and> P x \<longrightarrow> (\<exists>u\<in> U. x \<sqsubseteq> u)"
     and mi: "\<exists>z. \<forall>x. x \<sqsubset> z \<longrightarrow> (P x = MP)"  and pi: "\<exists>z. \<forall>x. z \<sqsubset> x \<longrightarrow> (P x = PP)"
-  shows "(\<exists> x. P x) \<equiv> (MP \<or> PP \<or> (\<exists> u \<in> U. \<exists> u'\<in> U. P (between u u')))"
+  shows "(\<exists>x. P x) \<equiv> (MP \<or> PP \<or> (\<exists>u \<in> U. \<exists>u'\<in> U. P (between u u')))"
   (is "_ \<equiv> (_ \<or> _ \<or> ?F)" is "?E \<equiv> ?D")
 proof -
-  { assume px: "\<exists> x. P x"
-    have "MP \<or> PP \<or> (\<not> MP \<and> \<not> PP)" by blast
-    moreover { assume "MP \<or> PP" hence "?D" by blast }
-    moreover {
-      assume nmi: "\<not> MP" and npi: "\<not> PP"
-      from npmibnd[OF nmibnd npibnd]
-      have nmpiU: "\<forall>x. \<not> MP \<and> \<not>PP \<and> P x \<longrightarrow> (\<exists> u\<in> U. \<exists> u' \<in> U. u \<sqsubseteq> x \<and> x \<sqsubseteq> u')" .
-      from rinf_U[OF fU lin_dense nmpiU nmi npi px] have "?D" by blast }
-    ultimately have "?D" by blast }
-  moreover
-  { assume "?D"
-    moreover { assume m:"MP" from minf_ex[OF mi m] have "?E" . }
-    moreover { assume p: "PP" from pinf_ex[OF pi p] have "?E" . }
-    moreover { assume f:"?F" hence "?E" by blast }
-    ultimately have "?E" by blast }
-  ultimately have "?E = ?D" by blast thus "?E \<equiv> ?D" by simp
+  have "?E \<longleftrightarrow> ?D"
+  proof
+    show ?D if px: ?E
+    proof -
+      consider "MP \<or> PP" | "\<not> MP" "\<not> PP" by blast
+      then show ?thesis
+      proof cases
+        case 1
+        then show ?thesis by blast
+      next
+        case 2
+        from npmibnd[OF nmibnd npibnd]
+        have nmpiU: "\<forall>x. \<not> MP \<and> \<not>PP \<and> P x \<longrightarrow> (\<exists>u\<in> U. \<exists>u' \<in> U. u \<sqsubseteq> x \<and> x \<sqsubseteq> u')" .
+        from rinf_U[OF fU lin_dense nmpiU \<open>\<not> MP\<close> \<open>\<not> PP\<close> px] show ?thesis
+          by blast
+      qed
+    qed
+    show ?E if ?D
+    proof -
+      from that consider MP | PP | ?F by blast
+      then show ?thesis
+      proof cases
+        case 1
+        show ?thesis by (rule minf_ex[OF mi 1])
+      next
+        case 2
+        show ?thesis by (rule pinf_ex[OF pi 2])
+      next
+        case 3
+        then show ?thesis by blast
+      qed
+    qed
+  qed
+  then show "?E \<equiv> ?D" by simp
 qed
 
 lemmas minf_thms[no_atp] = minf_conj minf_disj minf_eq minf_neq minf_lt minf_le minf_gt minf_ge minf_P
@@ -595,114 +698,141 @@
 
 subsection \<open>Ferrante and Rackoff algorithm over ordered fields\<close>
 
-lemma neg_prod_lt:"(c\<Colon>'a\<Colon>linordered_field) < 0 \<Longrightarrow> ((c*x < 0) == (x > 0))"
+lemma neg_prod_lt:
+  fixes c :: "'a::linordered_field"
+  assumes "c < 0"
+  shows "c * x < 0 \<equiv> x > 0"
 proof -
-  assume H: "c < 0"
-  have "c*x < 0 = (0/c < x)"
-    by (simp only: neg_divide_less_eq[OF H] algebra_simps)
-  also have "\<dots> = (0 < x)" by simp
-  finally show  "(c*x < 0) == (x > 0)" by simp
+  have "c * x < 0 \<longleftrightarrow> 0 / c < x"
+    by (simp only: neg_divide_less_eq[OF \<open>c < 0\<close>] algebra_simps)
+  also have "\<dots> \<longleftrightarrow> 0 < x" by simp
+  finally show "PROP ?thesis" by simp
 qed
 
-lemma pos_prod_lt:"(c\<Colon>'a\<Colon>linordered_field) > 0 \<Longrightarrow> ((c*x < 0) == (x < 0))"
+lemma pos_prod_lt:
+  fixes c :: "'a::linordered_field"
+  assumes "c > 0"
+  shows "c * x < 0 \<equiv> x < 0"
 proof -
-  assume H: "c > 0"
-  then have "c*x < 0 = (0/c > x)"
-    by (simp only: pos_less_divide_eq[OF H] algebra_simps)
-  also have "\<dots> = (0 > x)" by simp
-  finally show  "(c*x < 0) == (x < 0)" by simp
+  have "c * x < 0 \<longleftrightarrow> 0 /c > x"
+    by (simp only: pos_less_divide_eq[OF \<open>c > 0\<close>] algebra_simps)
+  also have "\<dots> \<longleftrightarrow> 0 > x" by simp
+  finally show "PROP ?thesis" by simp
 qed
 
-lemma neg_prod_sum_lt: "(c\<Colon>'a\<Colon>linordered_field) < 0 \<Longrightarrow> ((c*x + t< 0) == (x > (- 1/c)*t))"
+lemma neg_prod_sum_lt:
+  fixes c :: "'a::linordered_field"
+  assumes "c < 0"
+  shows "c * x + t < 0 \<equiv> x > (- 1 / c) * t"
 proof -
-  assume H: "c < 0"
-  have "c*x + t< 0 = (c*x < -t)"
-    by (subst less_iff_diff_less_0 [of "c*x" "-t"], simp)
-  also have "\<dots> = (-t/c < x)"
-    by (simp only: neg_divide_less_eq[OF H] algebra_simps)
-  also have "\<dots> = ((- 1/c)*t < x)" by simp
-  finally show "(c*x + t < 0) == (x > (- 1/c)*t)" by simp
+  have "c * x + t < 0 \<longleftrightarrow> c * x < - t"
+    by (subst less_iff_diff_less_0 [of "c * x" "- t"]) simp
+  also have "\<dots> \<longleftrightarrow> - t / c < x"
+    by (simp only: neg_divide_less_eq[OF \<open>c < 0\<close>] algebra_simps)
+  also have "\<dots> \<longleftrightarrow> (- 1 / c) * t < x" by simp
+  finally show "PROP ?thesis" by simp
 qed
 
-lemma pos_prod_sum_lt:"(c\<Colon>'a\<Colon>linordered_field) > 0 \<Longrightarrow> ((c*x + t < 0) == (x < (- 1/c)*t))"
+lemma pos_prod_sum_lt:
+  fixes c :: "'a::linordered_field"
+  assumes "c > 0"
+  shows "c * x + t < 0 \<equiv> x < (- 1 / c) * t"
 proof -
-  assume H: "c > 0"
-  have "c*x + t< 0 = (c*x < -t)"
-    by (subst less_iff_diff_less_0 [of "c*x" "-t"], simp)
-  also have "\<dots> = (-t/c > x)"
-    by (simp only: pos_less_divide_eq[OF H] algebra_simps)
-  also have "\<dots> = ((- 1/c)*t > x)" by simp
-  finally show  "(c*x + t < 0) == (x < (- 1/c)*t)" by simp
+  have "c * x + t < 0 \<longleftrightarrow> c * x < - t"
+    by (subst less_iff_diff_less_0 [of "c * x" "- t"]) simp
+  also have "\<dots> \<longleftrightarrow> - t / c > x"
+    by (simp only: pos_less_divide_eq[OF \<open>c > 0\<close>] algebra_simps)
+  also have "\<dots> \<longleftrightarrow> (- 1 / c) * t > x" by simp
+  finally show "PROP ?thesis" by simp
 qed
 
-lemma sum_lt:"((x::'a::ordered_ab_group_add) + t < 0) == (x < - t)"
+lemma sum_lt:
+  fixes x :: "'a::ordered_ab_group_add"
+  shows "x + t < 0 \<equiv> x < - t"
   using less_diff_eq[where a= x and b=t and c=0] by simp
 
-lemma neg_prod_le:"(c\<Colon>'a\<Colon>linordered_field) < 0 \<Longrightarrow> ((c*x <= 0) == (x >= 0))"
+lemma neg_prod_le:
+  fixes c :: "'a::linordered_field"
+  assumes "c < 0"
+  shows "c * x \<le> 0 \<equiv> x \<ge> 0"
 proof -
-  assume H: "c < 0"
-  have "c*x <= 0 = (0/c <= x)"
-    by (simp only: neg_divide_le_eq[OF H] algebra_simps)
-  also have "\<dots> = (0 <= x)" by simp
-  finally show  "(c*x <= 0) == (x >= 0)" by simp
+  have "c * x \<le> 0 \<longleftrightarrow> 0 / c \<le> x"
+    by (simp only: neg_divide_le_eq[OF \<open>c < 0\<close>] algebra_simps)
+  also have "\<dots> \<longleftrightarrow> 0 \<le> x" by simp
+  finally show "PROP ?thesis" by simp
 qed
 
-lemma pos_prod_le:"(c\<Colon>'a\<Colon>linordered_field) > 0 \<Longrightarrow> ((c*x <= 0) == (x <= 0))"
+lemma pos_prod_le:
+  fixes c :: "'a::linordered_field"
+  assumes "c > 0"
+  shows "c * x \<le> 0 \<equiv> x \<le> 0"
 proof -
-  assume H: "c > 0"
-  hence "c*x <= 0 = (0/c >= x)"
-    by (simp only: pos_le_divide_eq[OF H] algebra_simps)
-  also have "\<dots> = (0 >= x)" by simp
-  finally show  "(c*x <= 0) == (x <= 0)" by simp
+  have "c * x \<le> 0 \<longleftrightarrow> 0 / c \<ge> x"
+    by (simp only: pos_le_divide_eq[OF \<open>c > 0\<close>] algebra_simps)
+  also have "\<dots> \<longleftrightarrow> 0 \<ge> x" by simp
+  finally show "PROP ?thesis" by simp
+qed
+
+lemma neg_prod_sum_le:
+  fixes c :: "'a::linordered_field"
+  assumes "c < 0"
+  shows "c * x + t \<le> 0 \<equiv> x \<ge> (- 1 / c) * t"
+proof -
+  have "c * x + t \<le> 0 \<longleftrightarrow> c * x \<le> -t"
+    by (subst le_iff_diff_le_0 [of "c*x" "-t"]) simp
+  also have "\<dots> \<longleftrightarrow> - t / c \<le> x"
+    by (simp only: neg_divide_le_eq[OF \<open>c < 0\<close>] algebra_simps)
+  also have "\<dots> \<longleftrightarrow> (- 1 / c) * t \<le> x" by simp
+  finally show "PROP ?thesis" by simp
 qed
 
-lemma neg_prod_sum_le: "(c\<Colon>'a\<Colon>linordered_field) < 0 \<Longrightarrow> ((c*x + t <= 0) == (x >= (- 1/c)*t))"
+lemma pos_prod_sum_le:
+  fixes c :: "'a::linordered_field"
+  assumes "c > 0"
+  shows "c * x + t \<le> 0 \<equiv> x \<le> (- 1 / c) * t"
 proof -
-  assume H: "c < 0"
-  have "c*x + t <= 0 = (c*x <= -t)"
-    by (subst le_iff_diff_le_0 [of "c*x" "-t"], simp)
-  also have "\<dots> = (-t/c <= x)"
-    by (simp only: neg_divide_le_eq[OF H] algebra_simps)
-  also have "\<dots> = ((- 1/c)*t <= x)" by simp
-  finally show "(c*x + t <= 0) == (x >= (- 1/c)*t)" by simp
+  have "c * x + t \<le> 0 \<longleftrightarrow> c * x \<le> - t"
+    by (subst le_iff_diff_le_0 [of "c*x" "-t"]) simp
+  also have "\<dots> \<longleftrightarrow> - t / c \<ge> x"
+    by (simp only: pos_le_divide_eq[OF \<open>c > 0\<close>] algebra_simps)
+  also have "\<dots> \<longleftrightarrow> (- 1 / c) * t \<ge> x" by simp
+  finally show "PROP ?thesis" by simp
 qed
 
-lemma pos_prod_sum_le:"(c\<Colon>'a\<Colon>linordered_field) > 0 \<Longrightarrow> ((c*x + t <= 0) == (x <= (- 1/c)*t))"
-proof -
-  assume H: "c > 0"
-  have "c*x + t <= 0 = (c*x <= -t)"
-    by (subst le_iff_diff_le_0 [of "c*x" "-t"], simp)
-  also have "\<dots> = (-t/c >= x)"
-    by (simp only: pos_le_divide_eq[OF H] algebra_simps)
-  also have "\<dots> = ((- 1/c)*t >= x)" by simp
-  finally show "(c*x + t <= 0) == (x <= (- 1/c)*t)" by simp
-qed
-
-lemma sum_le:"((x::'a::ordered_ab_group_add) + t <= 0) == (x <= - t)"
+lemma sum_le:
+  fixes x :: "'a::ordered_ab_group_add"
+  shows "x + t \<le> 0 \<equiv> x \<le> - t"
   using le_diff_eq[where a= x and b=t and c=0] by simp
 
-lemma nz_prod_eq:"(c\<Colon>'a\<Colon>linordered_field) \<noteq> 0 \<Longrightarrow> ((c*x = 0) == (x = 0))" by simp
+lemma nz_prod_eq:
+  fixes c :: "'a::linordered_field"
+  assumes "c \<noteq> 0"
+  shows "c * x = 0 \<equiv> x = 0"
+  using assms by simp
 
-lemma nz_prod_sum_eq: "(c\<Colon>'a\<Colon>linordered_field) \<noteq> 0 \<Longrightarrow> ((c*x + t = 0) == (x = (- 1/c)*t))"
+lemma nz_prod_sum_eq:
+  fixes c :: "'a::linordered_field"
+  assumes "c \<noteq> 0"
+  shows "c * x + t = 0 \<equiv> x = (- 1/c) * t"
 proof -
-  assume H: "c \<noteq> 0"
-  have "c*x + t = 0 = (c*x = -t)"
-    by (subst eq_iff_diff_eq_0 [of "c*x" "-t"], simp)
-  also have "\<dots> = (x = -t/c)"
-    by (simp only: nonzero_eq_divide_eq[OF H] algebra_simps)
-  finally show  "(c*x + t = 0) == (x = (- 1/c)*t)" by simp
+  have "c * x + t = 0 \<longleftrightarrow> c * x = - t"
+    by (subst eq_iff_diff_eq_0 [of "c*x" "-t"]) simp
+  also have "\<dots> \<longleftrightarrow> x = - t / c"
+    by (simp only: nonzero_eq_divide_eq[OF \<open>c \<noteq> 0\<close>] algebra_simps)
+  finally show "PROP ?thesis" by simp
 qed
 
-lemma sum_eq:"((x::'a::ordered_ab_group_add) + t = 0) == (x = - t)"
+lemma sum_eq:
+  fixes x :: "'a::ordered_ab_group_add"
+  shows "x + t = 0 \<equiv> x = - t"
   using eq_diff_eq[where a= x and b=t and c=0] by simp
 
 
 interpretation class_dense_linordered_field: constr_dense_linorder
- "op <=" "op <"
-   "\<lambda> x y. 1/2 * ((x::'a::{linordered_field}) + y)"
+  "op \<le>" "op <" "\<lambda>x y. 1/2 * ((x::'a::linordered_field) + y)"
   by unfold_locales (dlo, dlo, auto)
 
-declaration\<open>
+declaration \<open>
 let
   fun earlier [] x y = false
     | earlier (h::t) x y =
@@ -934,58 +1064,5 @@
   {isolate_conv = field_isolate_conv, whatis = classfield_whatis, simpset = class_field_ss}
 end
 \<close>
-(*
-lemma upper_bound_finite_set:
-  assumes fS: "finite S"
-  shows "\<exists>(a::'a::linorder). \<forall>x \<in> S. f x \<le> a"
-proof(induct rule: finite_induct[OF fS])
-  case 1 thus ?case by simp
-next
-  case (2 x F)
-  from "2.hyps" obtain a where a:"\<forall>x \<in>F. f x \<le> a" by blast
-  let ?a = "max a (f x)"
-  have m: "a \<le> ?a" "f x \<le> ?a" by simp_all
-  {fix y assume y: "y \<in> insert x F"
-    {assume "y = x" hence "f y \<le> ?a" using m by simp}
-    moreover
-    {assume yF: "y\<in> F" from a[rule_format, OF yF] m have "f y \<le> ?a" by (simp add: max_def)}
-    ultimately have "f y \<le> ?a" using y by blast}
-  then show ?case by blast
-qed
 
-lemma lower_bound_finite_set:
-  assumes fS: "finite S"
-  shows "\<exists>(a::'a::linorder). \<forall>x \<in> S. f x \<ge> a"
-proof(induct rule: finite_induct[OF fS])
-  case 1 thus ?case by simp
-next
-  case (2 x F)
-  from "2.hyps" obtain a where a:"\<forall>x \<in>F. f x \<ge> a" by blast
-  let ?a = "min a (f x)"
-  have m: "a \<ge> ?a" "f x \<ge> ?a" by simp_all
-  {fix y assume y: "y \<in> insert x F"
-    {assume "y = x" hence "f y \<ge> ?a" using m by simp}
-    moreover
-    {assume yF: "y\<in> F" from a[rule_format, OF yF] m have "f y \<ge> ?a" by (simp add: min_def)}
-    ultimately have "f y \<ge> ?a" using y by blast}
-  then show ?case by blast
-qed
-
-lemma bound_finite_set: assumes f: "finite S"
-  shows "\<exists>a. \<forall>x \<in>S. (f x:: 'a::linorder) \<le> a"
-proof-
-  let ?F = "f ` S"
-  from f have fF: "finite ?F" by simp
-  let ?a = "Max ?F"
-  {assume "S = {}" hence ?thesis by blast}
-  moreover
-  {assume Se: "S \<noteq> {}" hence Fe: "?F \<noteq> {}" by simp
-  {fix x assume x: "x \<in> S"
-    hence th0: "f x \<in> ?F" by simp
-    hence "f x \<le> ?a" using Max_ge[OF fF th0] ..}
-  hence ?thesis by blast}
-ultimately show ?thesis by blast
-qed
-*)
-
-end 
+end