merged
authorpaulson
Tue, 30 Apr 2019 22:44:06 +0100
changeset 70223 13f8f89f5c41
parent 70220 089753519be0 (current diff)
parent 70222 bde8ccb73fd2 (diff)
child 70224 3706106c2e0f
merged
--- a/src/HOL/Nonstandard_Analysis/NSA.thy	Tue Apr 30 20:54:07 2019 +0200
+++ b/src/HOL/Nonstandard_Analysis/NSA.thy	Tue Apr 30 22:44:06 2019 +0100
@@ -6,7 +6,7 @@
 section \<open>Infinite Numbers, Infinitesimals, Infinitely Close Relation\<close>
 
 theory NSA
-  imports HyperDef "HOL-Library.Lub_Glb"
+  imports HyperDef "HOL-Library.Lub_Glb" 
 begin
 
 definition hnorm :: "'a::real_normed_vector star \<Rightarrow> real star"
@@ -162,37 +162,11 @@
   by (simp add: Reals_eq_Standard Standard_def)
 
 lemma inv_hypreal_of_real_image: "inv hypreal_of_real ` \<real> = UNIV"
-  apply (auto simp add: SReal_def)
-  apply (rule inj_star_of [THEN inv_f_f, THEN subst], blast)
-  done
-
-lemma SReal_hypreal_of_real_image: "\<exists>x. x \<in> P \<Longrightarrow> P \<subseteq> \<real> \<Longrightarrow> \<exists>Q. P = hypreal_of_real ` Q"
-  unfolding SReal_def image_def by blast
+  by (simp add: Reals_eq_Standard Standard_def inj_star_of)
 
 lemma SReal_dense: "x \<in> \<real> \<Longrightarrow> y \<in> \<real> \<Longrightarrow> x < y \<Longrightarrow> \<exists>r \<in> Reals. x < r \<and> r < y"
   for x y :: hypreal
-  apply (auto simp: SReal_def)
-  apply (drule dense)
-  apply auto
-  done
-
-
-text \<open>Completeness of Reals, but both lemmas are unused.\<close>
-
-lemma SReal_sup_lemma:
-  "P \<subseteq> \<real> \<Longrightarrow> (\<exists>x \<in> P. y < x) = (\<exists>X. hypreal_of_real X \<in> P \<and> y < hypreal_of_real X)"
-  by (blast dest!: SReal_iff [THEN iffD1])
-
-lemma SReal_sup_lemma2:
-  "P \<subseteq> \<real> \<Longrightarrow> \<exists>x. x \<in> P \<Longrightarrow> \<exists>y \<in> Reals. \<forall>x \<in> P. x < y \<Longrightarrow>
-    (\<exists>X. X \<in> {w. hypreal_of_real w \<in> P}) \<and>
-    (\<exists>Y. \<forall>X \<in> {w. hypreal_of_real w \<in> P}. X < Y)"
-  apply (rule conjI)
-   apply (fast dest!: SReal_iff [THEN iffD1])
-  apply (auto, frule subsetD, assumption)
-  apply (drule SReal_iff [THEN iffD1])
-  apply (auto, rule_tac x = ya in exI, auto)
-  done
+  using dense by (fastforce simp add: SReal_def)
 
 
 subsection \<open>Set of Finite Elements is a Subring of the Extended Reals\<close>
@@ -211,11 +185,7 @@
   by (simp add: HFinite_def)
 
 lemma HFinite_star_of [simp]: "star_of x \<in> HFinite"
-  apply (simp add: HFinite_def)
-  apply (rule_tac x="star_of (norm x) + 1" in bexI)
-   apply (transfer, simp)
-  apply (blast intro: Reals_add SReal_hypreal_of_real Reals_1)
-  done
+  by (simp add: HFinite_def) (metis SReal_hypreal_of_real gt_ex star_of_less star_of_norm)
 
 lemma SReal_subset_HFinite: "(\<real>::hypreal set) \<subseteq> HFinite"
   by (auto simp add: SReal_def)
@@ -244,16 +214,22 @@
 
 lemma hrealpow_HFinite: "x \<in> HFinite \<Longrightarrow> x ^ n \<in> HFinite"
   for x :: "'a::{real_normed_algebra,monoid_mult} star"
-  by (induct n) (auto simp add: power_Suc intro: HFinite_mult)
+  by (induct n) (auto intro: HFinite_mult)
 
-lemma HFinite_bounded: "x \<in> HFinite \<Longrightarrow> y \<le> x \<Longrightarrow> 0 \<le> y \<Longrightarrow> y \<in> HFinite"
-  for x y :: hypreal
-  apply (cases "x \<le> 0")
-   apply (drule_tac y = x in order_trans)
-    apply (drule_tac [2] order_antisym)
-     apply (auto simp add: linorder_not_le)
-  apply (auto intro: order_le_less_trans simp add: abs_if HFinite_def)
-  done
+lemma HFinite_bounded: 
+  fixes x y :: hypreal
+  assumes "x \<in> HFinite" and y: "y \<le> x" "0 \<le> y" shows "y \<in> HFinite"
+proof (cases "x \<le> 0")
+  case True
+  then have "y = 0"
+    using y by auto
+  then show ?thesis
+    by simp
+next
+  case False
+  then show ?thesis
+    using assms le_less_trans by (auto simp: HFinite_def)
+qed
 
 
 subsection \<open>Set of Infinitesimals is a Subring of the Hyperreals\<close>
@@ -273,12 +249,19 @@
 lemma Infinitesimal_zero [iff]: "0 \<in> Infinitesimal"
   by (simp add: Infinitesimal_def)
 
-lemma Infinitesimal_add: "x \<in> Infinitesimal \<Longrightarrow> y \<in> Infinitesimal \<Longrightarrow> x + y \<in> Infinitesimal"
-  apply (rule InfinitesimalI)
-  apply (rule field_sum_of_halves [THEN subst])
-  apply (drule half_gt_zero)
-  apply (blast intro: hnorm_add_less SReal_divide_numeral dest: InfinitesimalD)
-  done
+lemma Infinitesimal_add:
+  assumes "x \<in> Infinitesimal" "y \<in> Infinitesimal"
+  shows "x + y \<in> Infinitesimal"
+proof (rule InfinitesimalI)
+  show "hnorm (x + y) < r"
+    if "r \<in> \<real>" and "0 < r" for r :: "real star"
+  proof -
+    have "hnorm x < r/2" "hnorm y < r/2"
+      using InfinitesimalD SReal_divide_numeral assms half_gt_zero that by blast+
+    then show ?thesis
+      using hnorm_add_less by fastforce
+  qed
+qed
 
 lemma Infinitesimal_minus_iff [simp]: "- x \<in> Infinitesimal \<longleftrightarrow> x \<in> Infinitesimal"
   by (simp add: Infinitesimal_def)
@@ -297,83 +280,103 @@
 lemma Infinitesimal_diff: "x \<in> Infinitesimal \<Longrightarrow> y \<in> Infinitesimal \<Longrightarrow> x - y \<in> Infinitesimal"
   using Infinitesimal_add [of x "- y"] by simp
 
-lemma Infinitesimal_mult: "x \<in> Infinitesimal \<Longrightarrow> y \<in> Infinitesimal \<Longrightarrow> x * y \<in> Infinitesimal"
-  for x y :: "'a::real_normed_algebra star"
-  apply (rule InfinitesimalI)
-  apply (subgoal_tac "hnorm (x * y) < 1 * r")
-   apply (simp only: mult_1)
-  apply (rule hnorm_mult_less)
-   apply (simp_all add: InfinitesimalD)
-  done
+lemma Infinitesimal_mult: 
+  fixes x y :: "'a::real_normed_algebra star"
+  assumes "x \<in> Infinitesimal" "y \<in> Infinitesimal"
+  shows "x * y \<in> Infinitesimal"
+  proof (rule InfinitesimalI)
+  show "hnorm (x * y) < r"
+    if "r \<in> \<real>" and "0 < r" for r :: "real star"
+  proof -
+    have "hnorm x < 1" "hnorm y < r"
+      using assms that  by (auto simp add: InfinitesimalD)
+    then show ?thesis
+      using hnorm_mult_less by fastforce
+  qed
+qed
 
-lemma Infinitesimal_HFinite_mult: "x \<in> Infinitesimal \<Longrightarrow> y \<in> HFinite \<Longrightarrow> x * y \<in> Infinitesimal"
-  for x y :: "'a::real_normed_algebra star"
-  apply (rule InfinitesimalI)
-  apply (drule HFiniteD, clarify)
-  apply (subgoal_tac "0 < t")
-   apply (subgoal_tac "hnorm (x * y) < (r / t) * t", simp)
-   apply (subgoal_tac "0 < r / t")
-    apply (rule hnorm_mult_less)
-     apply (simp add: InfinitesimalD)
-    apply assumption
-   apply simp
-  apply (erule order_le_less_trans [OF hnorm_ge_zero])
-  done
+lemma Infinitesimal_HFinite_mult:
+  fixes x y :: "'a::real_normed_algebra star"
+  assumes "x \<in> Infinitesimal" "y \<in> HFinite"
+  shows "x * y \<in> Infinitesimal"
+proof (rule InfinitesimalI)
+  obtain t where "hnorm y < t" "t \<in> Reals"
+    using HFiniteD \<open>y \<in> HFinite\<close> by blast
+  then have "t > 0"
+    using hnorm_ge_zero le_less_trans by blast
+  show "hnorm (x * y) < r"
+    if "r \<in> \<real>" and "0 < r" for r :: "real star"
+  proof -
+    have "hnorm x < r/t"
+      by (meson InfinitesimalD Reals_divide \<open>hnorm y < t\<close> \<open>t \<in> \<real>\<close> assms(1) divide_pos_pos hnorm_ge_zero le_less_trans that) 
+    then have "hnorm (x * y) < (r / t) * t"
+      using \<open>hnorm y < t\<close> hnorm_mult_less by blast
+    then show ?thesis
+      using \<open>0 < t\<close> by auto
+  qed
+qed
 
 lemma Infinitesimal_HFinite_scaleHR:
-  "x \<in> Infinitesimal \<Longrightarrow> y \<in> HFinite \<Longrightarrow> scaleHR x y \<in> Infinitesimal"
-  apply (rule InfinitesimalI)
-  apply (drule HFiniteD, clarify)
-  apply (drule InfinitesimalD)
-  apply (simp add: hnorm_scaleHR)
-  apply (subgoal_tac "0 < t")
-   apply (subgoal_tac "\<bar>x\<bar> * hnorm y < (r / t) * t", simp)
-   apply (subgoal_tac "0 < r / t")
-    apply (rule mult_strict_mono', simp_all)
-  apply (erule order_le_less_trans [OF hnorm_ge_zero])
-  done
+  assumes "x \<in> Infinitesimal" "y \<in> HFinite"
+  shows "scaleHR x y \<in> Infinitesimal"
+proof (rule InfinitesimalI)
+  obtain t where "hnorm y < t" "t \<in> Reals"
+    using HFiniteD \<open>y \<in> HFinite\<close> by blast
+  then have "t > 0"
+    using hnorm_ge_zero le_less_trans by blast
+  show "hnorm (scaleHR x y) < r"
+    if "r \<in> \<real>" and "0 < r" for r :: "real star"
+  proof -
+    have "\<bar>x\<bar> * hnorm y < (r / t) * t"
+      by (metis InfinitesimalD Reals_divide \<open>0 < t\<close> \<open>hnorm y < t\<close> \<open>t \<in> \<real>\<close> assms(1) divide_pos_pos hnorm_ge_zero hypreal_hnorm_def mult_strict_mono' that)
+    then show ?thesis
+      by (simp add: \<open>0 < t\<close> hnorm_scaleHR less_imp_not_eq2)
+  qed
+qed
 
 lemma Infinitesimal_HFinite_mult2:
-  "x \<in> Infinitesimal \<Longrightarrow> y \<in> HFinite \<Longrightarrow> y * x \<in> Infinitesimal"
-  for x y :: "'a::real_normed_algebra star"
-  apply (rule InfinitesimalI)
-  apply (drule HFiniteD, clarify)
-  apply (subgoal_tac "0 < t")
-   apply (subgoal_tac "hnorm (y * x) < t * (r / t)", simp)
-   apply (subgoal_tac "0 < r / t")
-    apply (rule hnorm_mult_less)
-     apply assumption
-    apply (simp add: InfinitesimalD)
-   apply simp
-  apply (erule order_le_less_trans [OF hnorm_ge_zero])
-  done
+  fixes x y :: "'a::real_normed_algebra star"
+  assumes "x \<in> Infinitesimal" "y \<in> HFinite"
+  shows  "y * x \<in> Infinitesimal"
+proof (rule InfinitesimalI)
+  obtain t where "hnorm y < t" "t \<in> Reals"
+    using HFiniteD \<open>y \<in> HFinite\<close> by blast
+  then have "t > 0"
+    using hnorm_ge_zero le_less_trans by blast
+  show "hnorm (y * x) < r"
+    if "r \<in> \<real>" and "0 < r" for r :: "real star"
+  proof -
+    have "hnorm x < r/t"
+      by (meson InfinitesimalD Reals_divide \<open>hnorm y < t\<close> \<open>t \<in> \<real>\<close> assms(1) divide_pos_pos hnorm_ge_zero le_less_trans that) 
+    then have "hnorm (y * x) < t * (r / t)"
+      using \<open>hnorm y < t\<close> hnorm_mult_less by blast
+    then show ?thesis
+      using \<open>0 < t\<close> by auto
+  qed
+qed
 
-lemma Infinitesimal_scaleR2: "x \<in> Infinitesimal \<Longrightarrow> a *\<^sub>R x \<in> Infinitesimal"
-  apply (case_tac "a = 0", simp)
-  apply (rule InfinitesimalI)
-  apply (drule InfinitesimalD)
-  apply (drule_tac x="r / \<bar>star_of a\<bar>" in bspec)
-   apply (simp add: Reals_eq_Standard)
-  apply simp
-  apply (simp add: hnorm_scaleR pos_less_divide_eq mult.commute)
-  done
+lemma Infinitesimal_scaleR2: 
+  assumes "x \<in> Infinitesimal" shows "a *\<^sub>R x \<in> Infinitesimal"
+    by (metis HFinite_star_of Infinitesimal_HFinite_mult2 Infinitesimal_hnorm_iff assms hnorm_scaleR hypreal_hnorm_def star_of_norm)
 
 lemma Compl_HFinite: "- HFinite = HInfinite"
-  apply (auto simp add: HInfinite_def HFinite_def linorder_not_less)
-  apply (rule_tac y="r + 1" in order_less_le_trans, simp)
-  apply simp
-  done
+  proof -
+  have "r < hnorm x" if *: "\<And>s. s \<in> \<real> \<Longrightarrow> s \<le> hnorm x" and "r \<in> \<real>"
+    for x :: "'a star" and r :: hypreal
+    using * [of "r+1"] \<open>r \<in> \<real>\<close> by auto
+  then show ?thesis
+    by (auto simp add: HInfinite_def HFinite_def linorder_not_less)
+qed
 
-lemma HInfinite_inverse_Infinitesimal: "x \<in> HInfinite \<Longrightarrow> inverse x \<in> Infinitesimal"
+lemma HInfinite_inverse_Infinitesimal:
+  "x \<in> HInfinite \<Longrightarrow> inverse x \<in> Infinitesimal"
   for x :: "'a::real_normed_div_algebra star"
-  apply (rule InfinitesimalI)
-  apply (subgoal_tac "x \<noteq> 0")
-   apply (rule inverse_less_imp_less)
-    apply (simp add: nonzero_hnorm_inverse)
-    apply (simp add: HInfinite_def Reals_inverse)
-   apply assumption
-  apply (clarify, simp add: Compl_HFinite [symmetric])
-  done
+  by (simp add: HInfinite_def InfinitesimalI hnorm_inverse inverse_less_imp_less)
+
+lemma inverse_Infinitesimal_iff_HInfinite:
+  "x \<noteq> 0 \<Longrightarrow> inverse x \<in> Infinitesimal \<longleftrightarrow> x \<in> HInfinite"
+  for x :: "'a::real_normed_div_algebra star"
+  by (metis Compl_HFinite Compl_iff HInfinite_inverse_Infinitesimal InfinitesimalD Infinitesimal_HFinite_mult Reals_1 hnorm_one left_inverse less_irrefl zero_less_one)
 
 lemma HInfiniteI: "(\<And>r. r \<in> \<real> \<Longrightarrow> r < hnorm x) \<Longrightarrow> x \<in> HInfinite"
   by (simp add: HInfinite_def)
@@ -381,18 +384,26 @@
 lemma HInfiniteD: "x \<in> HInfinite \<Longrightarrow> r \<in> \<real> \<Longrightarrow> r < hnorm x"
   by (simp add: HInfinite_def)
 
-lemma HInfinite_mult: "x \<in> HInfinite \<Longrightarrow> y \<in> HInfinite \<Longrightarrow> x * y \<in> HInfinite"
-  for x y :: "'a::real_normed_div_algebra star"
-  apply (rule HInfiniteI, simp only: hnorm_mult)
-  apply (subgoal_tac "r * 1 < hnorm x * hnorm y", simp only: mult_1)
-  apply (case_tac "x = 0", simp add: HInfinite_def)
-  apply (rule mult_strict_mono)
-     apply (simp_all add: HInfiniteD)
-  done
+lemma HInfinite_mult: 
+  fixes x y :: "'a::real_normed_div_algebra star"
+  assumes "x \<in> HInfinite" "y \<in> HInfinite" shows "x * y \<in> HInfinite"
+proof (rule HInfiniteI, simp only: hnorm_mult)
+  have "x \<noteq> 0"
+    using Compl_HFinite HFinite_0 assms by blast
+  show "r < hnorm x * hnorm y"
+    if "r \<in> \<real>" for r :: "real star"
+  proof -
+    have "r = r * 1"
+      by simp
+    also have "\<dots> < hnorm x * hnorm y"
+      by (meson HInfiniteD Reals_1 \<open>x \<noteq> 0\<close> assms le_numeral_extra(1) mult_strict_mono that zero_less_hnorm_iff)
+    finally show ?thesis .
+  qed
+qed
 
 lemma hypreal_add_zero_less_le_mono: "r < x \<Longrightarrow> 0 \<le> y \<Longrightarrow> r < x + y"
   for r x y :: hypreal
-  by (auto dest: add_less_le_mono)
+  by simp
 
 lemma HInfinite_add_ge_zero: "x \<in> HInfinite \<Longrightarrow> 0 \<le> y \<Longrightarrow> 0 \<le> x \<Longrightarrow> x + y \<in> HInfinite"
   for x y :: hypreal
@@ -411,12 +422,7 @@
 
 lemma HInfinite_add_le_zero: "x \<in> HInfinite \<Longrightarrow> y \<le> 0 \<Longrightarrow> x \<le> 0 \<Longrightarrow> x + y \<in> HInfinite"
   for x y :: hypreal
-  apply (drule HInfinite_minus_iff [THEN iffD2])
-  apply (rule HInfinite_minus_iff [THEN iffD1])
-  apply (simp only: minus_add add.commute)
-  apply (rule HInfinite_add_ge_zero)
-    apply simp_all
-  done
+  by (metis (no_types, lifting) HInfinite_add_ge_zero2 HInfinite_minus_iff add.inverse_distrib_swap neg_0_le_iff_le)
 
 lemma HInfinite_add_lt_zero: "x \<in> HInfinite \<Longrightarrow> y < 0 \<Longrightarrow> x < 0 \<Longrightarrow> x + y \<in> HInfinite"
   for x y :: hypreal
@@ -465,17 +471,12 @@
 
 lemma lemma_Infinitesimal_hyperpow: "x \<in> Infinitesimal \<Longrightarrow> 0 < N \<Longrightarrow> \<bar>x pow N\<bar> \<le> \<bar>x\<bar>"
   for x :: hypreal
-  apply (unfold Infinitesimal_def)
-  apply (auto intro!: hyperpow_Suc_le_self2
-      simp: hyperpow_hrabs [symmetric] hypnat_gt_zero_iff2 abs_ge_zero)
-  done
+  apply (clarsimp simp: Infinitesimal_def)
+  by (metis Reals_1 abs_ge_zero hyperpow_Suc_le_self2 hyperpow_hrabs hypnat_gt_zero_iff2 zero_less_one)
 
 lemma Infinitesimal_hyperpow: "x \<in> Infinitesimal \<Longrightarrow> 0 < N \<Longrightarrow> x pow N \<in> Infinitesimal"
   for x :: hypreal
-  apply (rule hrabs_le_Infinitesimal)
-   apply (rule_tac [2] lemma_Infinitesimal_hyperpow)
-  apply auto
-  done
+  using hrabs_le_Infinitesimal lemma_Infinitesimal_hyperpow by blast
 
 lemma hrealpow_hyperpow_Infinitesimal_iff:
   "(x ^ n \<in> Infinitesimal) \<longleftrightarrow> x pow (hypnat_of_nat n) \<in> Infinitesimal"
@@ -488,21 +489,11 @@
 lemma not_Infinitesimal_mult:
   "x \<notin> Infinitesimal \<Longrightarrow> y \<notin> Infinitesimal \<Longrightarrow> x * y \<notin> Infinitesimal"
   for x y :: "'a::real_normed_div_algebra star"
-  apply (unfold Infinitesimal_def, clarify, rename_tac r s)
-  apply (simp only: linorder_not_less hnorm_mult)
-  apply (drule_tac x = "r * s" in bspec)
-   apply (fast intro: Reals_mult)
-  apply simp
-  apply (drule_tac c = s and d = "hnorm y" and a = r and b = "hnorm x" in mult_mono)
-     apply simp_all
-  done
+  by (metis (no_types, lifting) inverse_Infinitesimal_iff_HInfinite ComplI Compl_HFinite Infinitesimal_HFinite_mult divide_inverse eq_divide_imp inverse_inverse_eq mult_zero_right)
 
 lemma Infinitesimal_mult_disj: "x * y \<in> Infinitesimal \<Longrightarrow> x \<in> Infinitesimal \<or> y \<in> Infinitesimal"
   for x y :: "'a::real_normed_div_algebra star"
-  apply (rule ccontr)
-  apply (drule de_Morgan_disj [THEN iffD1])
-  apply (fast dest: not_Infinitesimal_mult)
-  done
+  using not_Infinitesimal_mult by blast
 
 lemma HFinite_Infinitesimal_not_zero: "x \<in> HFinite-Infinitesimal \<Longrightarrow> x \<noteq> 0"
   by blast
@@ -510,16 +501,10 @@
 lemma HFinite_Infinitesimal_diff_mult:
   "x \<in> HFinite - Infinitesimal \<Longrightarrow> y \<in> HFinite - Infinitesimal \<Longrightarrow> x * y \<in> HFinite - Infinitesimal"
   for x y :: "'a::real_normed_div_algebra star"
-  apply clarify
-  apply (blast dest: HFinite_mult not_Infinitesimal_mult)
-  done
+  by (simp add: HFinite_mult not_Infinitesimal_mult)
 
 lemma Infinitesimal_subset_HFinite: "Infinitesimal \<subseteq> HFinite"
-  apply (simp add: Infinitesimal_def HFinite_def)
-  apply auto
-  apply (rule_tac x = 1 in bexI)
-  apply auto
-  done
+  using HFinite_def InfinitesimalD Reals_1 zero_less_one by blast
 
 lemma Infinitesimal_star_of_mult: "x \<in> Infinitesimal \<Longrightarrow> x * star_of r \<in> Infinitesimal"
   for x :: "'a::real_normed_algebra star"
@@ -544,21 +529,19 @@
 lemma approx_refl [iff]: "x \<approx> x"
   by (simp add: approx_def Infinitesimal_def)
 
-lemma hypreal_minus_distrib1: "- (y + - x) = x + -y"
-  for x y :: "'a::ab_group_add"
-  by (simp add: add.commute)
+lemma approx_sym: "x \<approx> y \<Longrightarrow> y \<approx> x"
+  by (metis Infinitesimal_minus_iff approx_def minus_diff_eq)
 
-lemma approx_sym: "x \<approx> y \<Longrightarrow> y \<approx> x"
-  apply (simp add: approx_def)
-  apply (drule Infinitesimal_minus_iff [THEN iffD2])
-  apply simp
-  done
-
-lemma approx_trans: "x \<approx> y \<Longrightarrow> y \<approx> z \<Longrightarrow> x \<approx> z"
-  apply (simp add: approx_def)
-  apply (drule (1) Infinitesimal_add)
-  apply simp
-  done
+lemma approx_trans:
+  assumes "x \<approx> y" "y \<approx> z" shows "x \<approx> z"
+proof -
+  have "x - y \<in> Infinitesimal" "z - y \<in> Infinitesimal"
+    using assms approx_def approx_sym by auto
+  then have "x - z \<in> Infinitesimal"
+    using Infinitesimal_diff by force
+  then show ?thesis
+    by (simp add: approx_def)
+qed
 
 lemma approx_trans2: "r \<approx> x \<Longrightarrow> s \<approx> x \<Longrightarrow> r \<approx> s"
   by (blast intro: approx_sym approx_trans)
@@ -587,12 +570,11 @@
   by (simp add: approx_minus_iff [symmetric] mem_infmal_iff)
 
 lemma approx_monad_iff: "x \<approx> y \<longleftrightarrow> monad x = monad y"
-  by (auto simp add: monad_def dest: approx_sym elim!: approx_trans equalityCE)
+  apply (simp add: monad_def set_eq_iff)
+  using approx_reorient approx_trans by blast
 
 lemma Infinitesimal_approx: "x \<in> Infinitesimal \<Longrightarrow> y \<in> Infinitesimal \<Longrightarrow> x \<approx> y"
-  apply (simp add: mem_infmal_iff)
-  apply (blast intro: approx_trans approx_sym)
-  done
+  by (simp add: Infinitesimal_diff approx_def)
 
 lemma approx_add: "a \<approx> b \<Longrightarrow> c \<approx> d \<Longrightarrow> a + c \<approx> b + d"
 proof (unfold approx_def)
@@ -604,10 +586,7 @@
 qed
 
 lemma approx_minus: "a \<approx> b \<Longrightarrow> - a \<approx> - b"
-  apply (rule approx_minus_iff [THEN iffD2, THEN approx_sym])
-  apply (drule approx_minus_iff [THEN iffD1])
-  apply (simp add: add.commute)
-  done
+  by (metis approx_def approx_sym minus_diff_eq minus_diff_minus)
 
 lemma approx_minus2: "- a \<approx> - b \<Longrightarrow> a \<approx> b"
   by (auto dest: approx_minus)
@@ -654,16 +633,10 @@
   by (force simp add: bex_Infinitesimal_iff [symmetric])
 
 lemma Infinitesimal_add_approx: "y \<in> Infinitesimal \<Longrightarrow> x + y = z \<Longrightarrow> x \<approx> z"
-  apply (rule bex_Infinitesimal_iff [THEN iffD1])
-  apply (drule Infinitesimal_minus_iff [THEN iffD2])
-  apply (auto simp add: add.assoc [symmetric])
-  done
+  using approx_sym bex_Infinitesimal_iff2 by blast
 
 lemma Infinitesimal_add_approx_self: "y \<in> Infinitesimal \<Longrightarrow> x \<approx> x + y"
-  apply (rule bex_Infinitesimal_iff [THEN iffD1])
-  apply (drule Infinitesimal_minus_iff [THEN iffD2])
-  apply (auto simp add: add.assoc [symmetric])
-  done
+  by (simp add: Infinitesimal_add_approx)
 
 lemma Infinitesimal_add_approx_self2: "y \<in> Infinitesimal \<Longrightarrow> x \<approx> y + x"
   by (auto dest: Infinitesimal_add_approx_self simp add: add.commute)
@@ -672,31 +645,19 @@
   by (blast intro!: Infinitesimal_add_approx_self Infinitesimal_minus_iff [THEN iffD2])
 
 lemma Infinitesimal_add_cancel: "y \<in> Infinitesimal \<Longrightarrow> x + y \<approx> z \<Longrightarrow> x \<approx> z"
-  apply (drule_tac x = x in Infinitesimal_add_approx_self [THEN approx_sym])
-  apply (erule approx_trans3 [THEN approx_sym], assumption)
-  done
+  using Infinitesimal_add_approx approx_trans by blast
 
 lemma Infinitesimal_add_right_cancel: "y \<in> Infinitesimal \<Longrightarrow> x \<approx> z + y \<Longrightarrow> x \<approx> z"
-  apply (drule_tac x = z in Infinitesimal_add_approx_self2 [THEN approx_sym])
-  apply (erule approx_trans3 [THEN approx_sym])
-  apply (simp add: add.commute)
-  apply (erule approx_sym)
-  done
+  by (metis Infinitesimal_add_approx_self approx_monad_iff)
 
-lemma approx_add_left_cancel: "d + b  \<approx> d + c \<Longrightarrow> b \<approx> c"
-  apply (drule approx_minus_iff [THEN iffD1])
-  apply (simp add: approx_minus_iff [symmetric] ac_simps)
-  done
+lemma approx_add_left_cancel: "d + b \<approx> d + c \<Longrightarrow> b \<approx> c"
+  by (metis add_diff_cancel_left bex_Infinitesimal_iff)
 
 lemma approx_add_right_cancel: "b + d \<approx> c + d \<Longrightarrow> b \<approx> c"
-  apply (rule approx_add_left_cancel)
-  apply (simp add: add.commute)
-  done
+  by (simp add: approx_def)
 
 lemma approx_add_mono1: "b \<approx> c \<Longrightarrow> d + b \<approx> d + c"
-  apply (rule approx_minus_iff [THEN iffD2])
-  apply (simp add: approx_minus_iff [symmetric] ac_simps)
-  done
+  by (simp add: approx_add)
 
 lemma approx_add_mono2: "b \<approx> c \<Longrightarrow> b + a \<approx> c + a"
   by (simp add: add.commute approx_add_mono1)
@@ -708,52 +669,41 @@
   by (simp add: add.commute)
 
 lemma approx_HFinite: "x \<in> HFinite \<Longrightarrow> x \<approx> y \<Longrightarrow> y \<in> HFinite"
-  apply (drule bex_Infinitesimal_iff2 [THEN iffD2], safe)
-  apply (drule Infinitesimal_subset_HFinite [THEN subsetD, THEN HFinite_minus_iff [THEN iffD2]])
-  apply (drule HFinite_add)
-   apply (auto simp add: add.assoc)
-  done
+  by (metis HFinite_add Infinitesimal_subset_HFinite approx_sym subsetD bex_Infinitesimal_iff2)
 
 lemma approx_star_of_HFinite: "x \<approx> star_of D \<Longrightarrow> x \<in> HFinite"
   by (rule approx_sym [THEN [2] approx_HFinite], auto)
 
 lemma approx_mult_HFinite: "a \<approx> b \<Longrightarrow> c \<approx> d \<Longrightarrow> b \<in> HFinite \<Longrightarrow> d \<in> HFinite \<Longrightarrow> a * c \<approx> b * d"
   for a b c d :: "'a::real_normed_algebra star"
-  apply (rule approx_trans)
-   apply (rule_tac [2] approx_mult2)
-    apply (rule approx_mult1)
-     prefer 2 apply (blast intro: approx_HFinite approx_sym, auto)
-  done
+  by (meson approx_HFinite approx_mult2 approx_mult_subst2 approx_sym)
 
 lemma scaleHR_left_diff_distrib: "\<And>a b x. scaleHR (a - b) x = scaleHR a x - scaleHR b x"
   by transfer (rule scaleR_left_diff_distrib)
 
 lemma approx_scaleR1: "a \<approx> star_of b \<Longrightarrow> c \<in> HFinite \<Longrightarrow> scaleHR a c \<approx> b *\<^sub>R c"
-  apply (unfold approx_def)
-  apply (drule (1) Infinitesimal_HFinite_scaleHR)
-  apply (simp only: scaleHR_left_diff_distrib)
-  apply (simp add: scaleHR_def star_scaleR_def [symmetric])
-  done
+  unfolding approx_def
+  by (metis Infinitesimal_HFinite_scaleHR scaleHR_def scaleHR_left_diff_distrib star_scaleR_def starfun2_star_of)
 
 lemma approx_scaleR2: "a \<approx> b \<Longrightarrow> c *\<^sub>R a \<approx> c *\<^sub>R b"
   by (simp add: approx_def Infinitesimal_scaleR2 scaleR_right_diff_distrib [symmetric])
 
 lemma approx_scaleR_HFinite: "a \<approx> star_of b \<Longrightarrow> c \<approx> d \<Longrightarrow> d \<in> HFinite \<Longrightarrow> scaleHR a c \<approx> b *\<^sub>R d"
-  apply (rule approx_trans)
-   apply (rule_tac [2] approx_scaleR2)
-   apply (rule approx_scaleR1)
-    prefer 2 apply (blast intro: approx_HFinite approx_sym, auto)
-  done
+  by (meson approx_HFinite approx_scaleR1 approx_scaleR2 approx_sym approx_trans)
 
 lemma approx_mult_star_of: "a \<approx> star_of b \<Longrightarrow> c \<approx> star_of d \<Longrightarrow> a * c \<approx> star_of b * star_of d"
   for a c :: "'a::real_normed_algebra star"
   by (blast intro!: approx_mult_HFinite approx_star_of_HFinite HFinite_star_of)
 
-lemma approx_SReal_mult_cancel_zero: "a \<in> \<real> \<Longrightarrow> a \<noteq> 0 \<Longrightarrow> a * x \<approx> 0 \<Longrightarrow> x \<approx> 0"
-  for a x :: hypreal
-  apply (drule Reals_inverse [THEN SReal_subset_HFinite [THEN subsetD]])
-  apply (auto dest: approx_mult2 simp add: mult.assoc [symmetric])
-  done
+lemma approx_SReal_mult_cancel_zero:
+  fixes a x :: hypreal
+  assumes "a \<in> \<real>" "a \<noteq> 0" "a * x \<approx> 0" shows "x \<approx> 0"
+proof -
+  have "inverse a \<in> HFinite"
+    using Reals_inverse SReal_subset_HFinite assms(1) by blast
+  then show ?thesis
+    using assms by (auto dest: approx_mult2 simp add: mult.assoc [symmetric])
+qed
 
 lemma approx_mult_SReal1: "a \<in> \<real> \<Longrightarrow> x \<approx> 0 \<Longrightarrow> x * a \<approx> 0"
   for a x :: hypreal
@@ -767,25 +717,31 @@
   for a x :: hypreal
   by (blast intro: approx_SReal_mult_cancel_zero approx_mult_SReal2)
 
-lemma approx_SReal_mult_cancel: "a \<in> \<real> \<Longrightarrow> a \<noteq> 0 \<Longrightarrow> a * w \<approx> a * z \<Longrightarrow> w \<approx> z"
-  for a w z :: hypreal
-  apply (drule Reals_inverse [THEN SReal_subset_HFinite [THEN subsetD]])
-  apply (auto dest: approx_mult2 simp add: mult.assoc [symmetric])
-  done
+lemma approx_SReal_mult_cancel:
+  fixes a w z :: hypreal
+  assumes "a \<in> \<real>" "a \<noteq> 0" "a * w \<approx> a * z" shows "w \<approx> z"
+proof -
+  have "inverse a \<in> HFinite"
+    using Reals_inverse SReal_subset_HFinite assms(1) by blast
+  then show ?thesis
+    using assms by (auto dest: approx_mult2 simp add: mult.assoc [symmetric])
+qed
 
 lemma approx_SReal_mult_cancel_iff1 [simp]: "a \<in> \<real> \<Longrightarrow> a \<noteq> 0 \<Longrightarrow> a * w \<approx> a * z \<longleftrightarrow> w \<approx> z"
   for a w z :: hypreal
-  by (auto intro!: approx_mult2 SReal_subset_HFinite [THEN subsetD]
-      intro: approx_SReal_mult_cancel)
+  by (meson SReal_subset_HFinite approx_SReal_mult_cancel approx_mult2 subsetD)
 
-lemma approx_le_bound: "z \<le> f \<Longrightarrow> f \<approx> g \<Longrightarrow> g \<le> z ==> f \<approx> z"
-  for z :: hypreal
-  apply (simp add: bex_Infinitesimal_iff2 [symmetric], auto)
-  apply (rule_tac x = "g + y - z" in bexI)
-   apply simp
-  apply (rule Infinitesimal_interval2)
-     apply (rule_tac [2] Infinitesimal_zero, auto)
-  done
+lemma approx_le_bound:
+  fixes z :: hypreal
+  assumes "z \<le> f" " f \<approx> g" "g \<le> z" shows "f \<approx> z"
+proof -
+  obtain y where "z \<le> g + y" and "y \<in> Infinitesimal" "f = g + y"
+    using assms bex_Infinitesimal_iff2 by auto
+  then have "z - g \<in> Infinitesimal"
+    using assms(3) hrabs_le_Infinitesimal by auto 
+  then show ?thesis
+    by (metis approx_def approx_trans2 assms(2))
+qed
 
 lemma approx_hnorm: "x \<approx> y \<Longrightarrow> hnorm x \<approx> hnorm y"
   for x y :: "'a::real_normed_vector star"
@@ -810,9 +766,7 @@
 
 lemma Infinitesimal_less_SReal: "x \<in> \<real> \<Longrightarrow> y \<in> Infinitesimal \<Longrightarrow> 0 < x \<Longrightarrow> y < x"
   for x y :: hypreal
-  apply (simp add: Infinitesimal_def)
-  apply (rule abs_ge_self [THEN order_le_less_trans], auto)
-  done
+  using InfinitesimalD by fastforce
 
 lemma Infinitesimal_less_SReal2: "y \<in> Infinitesimal \<Longrightarrow> \<forall>r \<in> Reals. 0 < r \<longrightarrow> y < r"
   for y :: hypreal
@@ -820,21 +774,19 @@
 
 lemma SReal_not_Infinitesimal: "0 < y \<Longrightarrow> y \<in> \<real> ==> y \<notin> Infinitesimal"
   for y :: hypreal
-  apply (simp add: Infinitesimal_def)
-  apply (auto simp add: abs_if)
-  done
+  by (auto simp add: Infinitesimal_def abs_if)
 
 lemma SReal_minus_not_Infinitesimal: "y < 0 \<Longrightarrow> y \<in> \<real> \<Longrightarrow> y \<notin> Infinitesimal"
   for y :: hypreal
-  apply (subst Infinitesimal_minus_iff [symmetric])
-  apply (rule SReal_not_Infinitesimal, auto)
-  done
+  using Infinitesimal_minus_iff Reals_minus SReal_not_Infinitesimal neg_0_less_iff_less by blast
 
 lemma SReal_Int_Infinitesimal_zero: "\<real> Int Infinitesimal = {0::hypreal}"
-  apply auto
-  apply (cut_tac x = x and y = 0 in linorder_less_linear)
-  apply (blast dest: SReal_not_Infinitesimal SReal_minus_not_Infinitesimal)
-  done
+  proof -
+  have "x = 0" if "x \<in> \<real>" "x \<in> Infinitesimal" for x :: "real star"
+    using that SReal_minus_not_Infinitesimal SReal_not_Infinitesimal not_less_iff_gr_or_eq by blast
+  then show ?thesis
+    by auto
+qed
 
 lemma SReal_Infinitesimal_zero: "x \<in> \<real> \<Longrightarrow> x \<in> Infinitesimal \<Longrightarrow> x = 0"
   for x :: hypreal
@@ -849,12 +801,15 @@
   by (rule SReal_HFinite_diff_Infinitesimal) auto
 
 lemma star_of_Infinitesimal_iff_0 [iff]: "star_of x \<in> Infinitesimal \<longleftrightarrow> x = 0"
-  apply (auto simp add: Infinitesimal_def)
-  apply (drule_tac x="hnorm (star_of x)" in bspec)
-   apply (simp add: SReal_def)
-   apply (rule_tac x="norm x" in exI, simp)
-  apply simp
-  done
+proof
+  show "x = 0" if "star_of x \<in> Infinitesimal"
+  proof -
+    have "hnorm (star_n (\<lambda>n. x)) \<in> Standard"
+      by (metis Reals_eq_Standard SReal_iff star_of_def star_of_norm)
+    then show ?thesis
+      by (metis InfinitesimalD2 less_irrefl star_of_norm that zero_less_norm_iff)
+  qed
+qed auto
 
 lemma star_of_HFinite_diff_Infinitesimal: "x \<noteq> 0 \<Longrightarrow> star_of x \<in> HFinite - Infinitesimal"
   by simp
@@ -866,39 +821,26 @@
 text \<open>Again: \<open>1\<close> is a special case, but not \<open>0\<close> this time.\<close>
 lemma one_not_Infinitesimal [simp]:
   "(1::'a::{real_normed_vector,zero_neq_one} star) \<notin> Infinitesimal"
-  apply (simp only: star_one_def star_of_Infinitesimal_iff_0)
-  apply simp
-  done
+  by (metis star_of_Infinitesimal_iff_0 star_one_def zero_neq_one)
 
 lemma approx_SReal_not_zero: "y \<in> \<real> \<Longrightarrow> x \<approx> y \<Longrightarrow> y \<noteq> 0 \<Longrightarrow> x \<noteq> 0"
   for x y :: hypreal
-  apply (cut_tac x = 0 and y = y in linorder_less_linear, simp)
-  apply (blast dest: approx_sym [THEN mem_infmal_iff [THEN iffD2]]
-      SReal_not_Infinitesimal SReal_minus_not_Infinitesimal)
-  done
+  using SReal_Infinitesimal_zero approx_sym mem_infmal_iff by auto
 
 lemma HFinite_diff_Infinitesimal_approx:
   "x \<approx> y \<Longrightarrow> y \<in> HFinite - Infinitesimal \<Longrightarrow> x \<in> HFinite - Infinitesimal"
-  apply (auto intro: approx_sym [THEN [2] approx_HFinite] simp: mem_infmal_iff)
-  apply (drule approx_trans3, assumption)
-  apply (blast dest: approx_sym)
-  done
+  by (meson Diff_iff approx_HFinite approx_sym approx_trans3 mem_infmal_iff)
 
 text \<open>The premise \<open>y \<noteq> 0\<close> is essential; otherwise \<open>x / y = 0\<close> and we lose the
   \<open>HFinite\<close> premise.\<close>
 lemma Infinitesimal_ratio:
   "y \<noteq> 0 \<Longrightarrow> y \<in> Infinitesimal \<Longrightarrow> x / y \<in> HFinite \<Longrightarrow> x \<in> Infinitesimal"
   for x y :: "'a::{real_normed_div_algebra,field} star"
-  apply (drule Infinitesimal_HFinite_mult2, assumption)
-  apply (simp add: divide_inverse mult.assoc)
-  done
+  using Infinitesimal_HFinite_mult by fastforce
 
 lemma Infinitesimal_SReal_divide: "x \<in> Infinitesimal \<Longrightarrow> y \<in> \<real> \<Longrightarrow> x / y \<in> Infinitesimal"
   for x y :: hypreal
-  apply (simp add: divide_inverse)
-  apply (auto intro!: Infinitesimal_HFinite_mult
-      dest!: Reals_inverse [THEN SReal_subset_HFinite [THEN subsetD]])
-  done
+  by (metis HFinite_star_of Infinitesimal_HFinite_mult Reals_inverse SReal_iff divide_inverse)
 
 
 section \<open>Standard Part Theorem\<close>
@@ -912,28 +854,15 @@
 subsection \<open>Uniqueness: Two Infinitely Close Reals are Equal\<close>
 
 lemma star_of_approx_iff [simp]: "star_of x \<approx> star_of y \<longleftrightarrow> x = y"
-  apply safe
-  apply (simp add: approx_def)
-  apply (simp only: star_of_diff [symmetric])
-  apply (simp only: star_of_Infinitesimal_iff_0)
-  apply simp
-  done
+  by (metis approx_def right_minus_eq star_of_Infinitesimal_iff_0 star_of_simps(2))
 
 lemma SReal_approx_iff: "x \<in> \<real> \<Longrightarrow> y \<in> \<real> \<Longrightarrow> x \<approx> y \<longleftrightarrow> x = y"
   for x y :: hypreal
-  apply auto
-  apply (simp add: approx_def)
-  apply (drule (1) Reals_diff)
-  apply (drule (1) SReal_Infinitesimal_zero)
-  apply simp
-  done
+  by (meson Reals_diff SReal_Infinitesimal_zero approx_def approx_refl right_minus_eq)
 
 lemma numeral_approx_iff [simp]:
-  "(numeral v \<approx> (numeral w :: 'a::{numeral,real_normed_vector} star)) =
-    (numeral v = (numeral w :: 'a))"
-  apply (unfold star_numeral_def)
-  apply (rule star_of_approx_iff)
-  done
+  "(numeral v \<approx> (numeral w :: 'a::{numeral,real_normed_vector} star)) = (numeral v = (numeral w :: 'a))"
+  by (metis star_of_approx_iff star_of_numeral)
 
 text \<open>And also for \<open>0 \<approx> #nn\<close> and \<open>1 \<approx> #nn\<close>, \<open>#nn \<approx> 0\<close> and \<open>#nn \<approx> 1\<close>.\<close>
 lemma [simp]:
@@ -943,10 +872,8 @@
   "((1::'b::{numeral,one,real_normed_vector} star) \<approx> numeral w) = (numeral w = (1::'b))"
   "\<not> (0 \<approx> (1::'c::{zero_neq_one,real_normed_vector} star))"
   "\<not> (1 \<approx> (0::'c::{zero_neq_one,real_normed_vector} star))"
-       apply (unfold star_numeral_def star_zero_def star_one_def)
-       apply (unfold star_of_approx_iff)
-       apply (auto intro: sym)
-  done
+  unfolding star_numeral_def star_zero_def star_one_def star_of_approx_iff
+  by (auto intro: sym)
 
 lemma star_of_approx_numeral_iff [simp]: "star_of k \<approx> numeral w \<longleftrightarrow> k = numeral w"
   by (subst star_of_approx_iff [symmetric]) auto
@@ -970,23 +897,19 @@
   for Q :: "real set" and Y :: real
   by (simp add: isUb_def setle_def)
 
-lemma hypreal_of_real_isLub1: "isLub \<real> (hypreal_of_real ` Q) (hypreal_of_real Y) \<Longrightarrow> isLub UNIV Q Y"
-  for Q :: "real set" and Y :: real
-  apply (simp add: isLub_def leastP_def)
-  apply (auto intro: hypreal_of_real_isUb_iff [THEN iffD2]
-      simp add: hypreal_of_real_isUb_iff setge_def)
-  done
-
-lemma hypreal_of_real_isLub2: "isLub UNIV Q Y \<Longrightarrow> isLub \<real> (hypreal_of_real ` Q) (hypreal_of_real Y)"
+lemma hypreal_of_real_isLub_iff:
+  "isLub \<real> (hypreal_of_real ` Q) (hypreal_of_real Y) = isLub (UNIV :: real set) Q Y" (is "?lhs = ?rhs")
   for Q :: "real set" and Y :: real
-  apply (auto simp add: isLub_def leastP_def hypreal_of_real_isUb_iff setge_def)
-  apply (metis SReal_iff hypreal_of_real_isUb_iff isUbD2a star_of_le)
-  done
-
-lemma hypreal_of_real_isLub_iff:
-  "isLub \<real> (hypreal_of_real ` Q) (hypreal_of_real Y) = isLub (UNIV :: real set) Q Y"
-  for Q :: "real set" and Y :: real
-  by (blast intro: hypreal_of_real_isLub1 hypreal_of_real_isLub2)
+proof 
+  assume ?lhs
+  then show ?rhs
+    by (simp add: isLub_def leastP_def) (metis hypreal_of_real_isUb_iff mem_Collect_eq setge_def star_of_le)
+next
+  assume ?rhs
+  then show ?lhs
+  apply (simp add: isLub_def leastP_def hypreal_of_real_isUb_iff setge_def)
+    by (metis SReal_iff hypreal_of_real_isUb_iff isUb_def star_of_le)
+qed
 
 lemma lemma_isUb_hypreal_of_real: "isUb \<real> P Y \<Longrightarrow> \<exists>Yo. isUb \<real> P (hypreal_of_real Yo)"
   by (auto simp add: SReal_iff isUb_def)
@@ -994,58 +917,47 @@
 lemma lemma_isLub_hypreal_of_real: "isLub \<real> P Y \<Longrightarrow> \<exists>Yo. isLub \<real> P (hypreal_of_real Yo)"
   by (auto simp add: isLub_def leastP_def isUb_def SReal_iff)
 
-lemma lemma_isLub_hypreal_of_real2: "\<exists>Yo. isLub \<real> P (hypreal_of_real Yo) \<Longrightarrow> \<exists>Y. isLub \<real> P Y"
-  by (auto simp add: isLub_def leastP_def isUb_def)
-
-lemma SReal_complete: "P \<subseteq> \<real> \<Longrightarrow> \<exists>x. x \<in> P \<Longrightarrow> \<exists>Y. isUb \<real> P Y \<Longrightarrow> \<exists>t::hypreal. isLub \<real> P t"
-  apply (frule SReal_hypreal_of_real_image)
-   apply (auto, drule lemma_isUb_hypreal_of_real)
-  apply (auto intro!: reals_complete lemma_isLub_hypreal_of_real2
-      simp add: hypreal_of_real_isLub_iff hypreal_of_real_isUb_iff)
-  done
+lemma SReal_complete:
+  fixes P :: "hypreal set"
+  assumes "isUb \<real> P Y" "P \<subseteq> \<real>" "P \<noteq> {}"
+    shows "\<exists>t. isLub \<real> P t"
+proof -
+  obtain Q where "P = hypreal_of_real ` Q"
+    by (metis \<open>P \<subseteq> \<real>\<close> hypreal_of_real_image subset_imageE)
+  then show ?thesis
+    by (metis assms(1) \<open>P \<noteq> {}\<close> equals0I hypreal_of_real_isLub_iff hypreal_of_real_isUb_iff image_empty lemma_isUb_hypreal_of_real reals_complete)
+qed
 
 
 text \<open>Lemmas about lubs.\<close>
 
-lemma lemma_st_part_ub: "x \<in> HFinite \<Longrightarrow> \<exists>u. isUb \<real> {s. s \<in> \<real> \<and> s < x} u"
-  for x :: hypreal
-  apply (drule HFiniteD, safe)
-  apply (rule exI, rule isUbI)
-   apply (auto intro: setleI isUbI simp add: abs_less_iff)
-  done
-
-lemma lemma_st_part_nonempty: "x \<in> HFinite \<Longrightarrow> \<exists>y. y \<in> {s. s \<in> \<real> \<and> s < x}"
-  for x :: hypreal
-  apply (drule HFiniteD, safe)
-  apply (drule Reals_minus)
-  apply (rule_tac x = "-t" in exI)
-  apply (auto simp add: abs_less_iff)
-  done
-
-lemma lemma_st_part_lub: "x \<in> HFinite \<Longrightarrow> \<exists>t. isLub \<real> {s. s \<in> \<real> \<and> s < x} t"
-  for x :: hypreal
-  by (blast intro!: SReal_complete lemma_st_part_ub lemma_st_part_nonempty Collect_restrict)
+lemma lemma_st_part_lub:
+  fixes x :: hypreal
+  assumes "x \<in> HFinite"
+  shows "\<exists>t. isLub \<real> {s. s \<in> \<real> \<and> s < x} t"
+proof -
+  obtain t where t: "t \<in> \<real>" "hnorm x < t"
+    using HFiniteD assms by blast
+  then have "isUb \<real> {s. s \<in> \<real> \<and> s < x} t"
+    by (simp add: abs_less_iff isUbI le_less_linear less_imp_not_less setleI)
+  moreover have "\<exists>y. y \<in> \<real> \<and> y < x"
+    using t by (rule_tac x = "-t" in exI) (auto simp add: abs_less_iff)
+  ultimately show ?thesis
+    using SReal_complete by fastforce
+qed
 
 lemma lemma_st_part_le1:
   "x \<in> HFinite \<Longrightarrow> isLub \<real> {s. s \<in> \<real> \<and> s < x} t \<Longrightarrow> r \<in> \<real> \<Longrightarrow> 0 < r \<Longrightarrow> x \<le> t + r"
   for x r t :: hypreal
-  apply (frule isLubD1a)
-  apply (rule ccontr, drule linorder_not_le [THEN iffD2])
-  apply (drule (1) Reals_add)
-  apply (drule_tac y = "r + t" in isLubD1 [THEN setleD], auto)
-  done
+  by (metis (no_types, lifting) Reals_add add.commute isLubD1a isLubD2 less_add_same_cancel2 mem_Collect_eq not_le)
 
 lemma hypreal_setle_less_trans: "S *<= x \<Longrightarrow> x < y \<Longrightarrow> S *<= y"
   for x y :: hypreal
-  apply (simp add: setle_def)
-  apply (auto dest!: bspec order_le_less_trans intro: order_less_imp_le)
-  done
+  by (meson le_less_trans less_imp_le setle_def)
 
 lemma hypreal_gt_isUb: "isUb R S x \<Longrightarrow> x < y \<Longrightarrow> y \<in> R \<Longrightarrow> isUb R S y"
   for x y :: hypreal
-  apply (simp add: isUb_def)
-  apply (blast intro: hypreal_setle_less_trans)
-  done
+  using hypreal_setle_less_trans isUb_def by blast
 
 lemma lemma_st_part_gt_ub: "x \<in> HFinite \<Longrightarrow> x < y \<Longrightarrow> y \<in> \<real> \<Longrightarrow> isUb \<real> {s. s \<in> \<real> \<and> s < x} y"
   for x y :: hypreal
@@ -1053,9 +965,7 @@
 
 lemma lemma_minus_le_zero: "t \<le> t + -r \<Longrightarrow> r \<le> 0"
   for r t :: hypreal
-  apply (drule_tac c = "-t" in add_left_mono)
-  apply (auto simp add: add.assoc [symmetric])
-  done
+  by simp
 
 lemma lemma_st_part_le2:
   "x \<in> HFinite \<Longrightarrow> isLub \<real> {s. s \<in> \<real> \<and> s < x} t \<Longrightarrow> r \<in> \<real> \<Longrightarrow> 0 < r \<Longrightarrow> t + -r \<le> x"
@@ -1072,9 +982,7 @@
 lemma lemma_st_part1a:
   "x \<in> HFinite \<Longrightarrow> isLub \<real> {s. s \<in> \<real> \<and> s < x} t \<Longrightarrow> r \<in> \<real> \<Longrightarrow> 0 < r \<Longrightarrow> x + -t \<le> r"
   for x r t :: hypreal
-  apply (subgoal_tac "x \<le> t + r")
-   apply (auto intro: lemma_st_part_le1)
-  done
+  using lemma_st_part_le1 by fastforce
 
 lemma lemma_st_part2a:
   "x \<in> HFinite \<Longrightarrow> isLub \<real> {s. s \<in> \<real> \<and> s < x} t \<Longrightarrow> r \<in> \<real> \<Longrightarrow> 0 < r \<Longrightarrow> - (x + -t) \<le> r"
@@ -1141,46 +1049,28 @@
 
 lemma lemma_st_part_Ex: "x \<in> HFinite \<Longrightarrow> \<exists>t\<in>Reals. \<forall>r \<in> Reals. 0 < r \<longrightarrow> \<bar>x - t\<bar> < r"
   for x :: hypreal
-  apply (frule lemma_st_part_lub, safe)
-  apply (frule isLubD1a)
-  apply (blast dest: lemma_st_part_major2)
-  done
+  by (meson isLubD1a lemma_st_part_lub lemma_st_part_major2)
 
 lemma st_part_Ex: "x \<in> HFinite \<Longrightarrow> \<exists>t\<in>Reals. x \<approx> t"
   for x :: hypreal
-  apply (simp add: approx_def Infinitesimal_def)
-  apply (drule lemma_st_part_Ex, auto)
-  done
+  by (metis InfinitesimalI approx_def hypreal_hnorm_def lemma_st_part_Ex)
 
 text \<open>There is a unique real infinitely close.\<close>
 lemma st_part_Ex1: "x \<in> HFinite \<Longrightarrow> \<exists>!t::hypreal. t \<in> \<real> \<and> x \<approx> t"
-  apply (drule st_part_Ex, safe)
-   apply (drule_tac [2] approx_sym, drule_tac [2] approx_sym, drule_tac [2] approx_sym)
-   apply (auto intro!: approx_unique_real)
-  done
+  by (meson SReal_approx_iff approx_trans2 st_part_Ex)
 
 
 subsection \<open>Finite, Infinite and Infinitesimal\<close>
 
 lemma HFinite_Int_HInfinite_empty [simp]: "HFinite Int HInfinite = {}"
-  apply (simp add: HFinite_def HInfinite_def)
-  apply (auto dest: order_less_trans)
-  done
+  using Compl_HFinite by blast
 
 lemma HFinite_not_HInfinite:
-  assumes x: "x \<in> HFinite"
-  shows "x \<notin> HInfinite"
-proof
-  assume x': "x \<in> HInfinite"
-  with x have "x \<in> HFinite \<inter> HInfinite" by blast
-  then show False by auto
-qed
+  assumes x: "x \<in> HFinite" shows "x \<notin> HInfinite"
+  using Compl_HFinite x by blast
 
 lemma not_HFinite_HInfinite: "x \<notin> HFinite \<Longrightarrow> x \<in> HInfinite"
-  apply (simp add: HInfinite_def HFinite_def, auto)
-  apply (drule_tac x = "r + 1" in bspec)
-   apply (auto)
-  done
+  using Compl_HFinite by blast
 
 lemma HInfinite_HFinite_disj: "x \<in> HInfinite \<or> x \<in> HFinite"
   by (blast intro: not_HFinite_HInfinite)
@@ -1191,17 +1081,13 @@
 lemma HFinite_HInfinite_iff: "x \<in> HFinite \<longleftrightarrow> x \<notin> HInfinite"
   by (simp add: HInfinite_HFinite_iff)
 
-
 lemma HInfinite_diff_HFinite_Infinitesimal_disj:
   "x \<notin> Infinitesimal \<Longrightarrow> x \<in> HInfinite \<or> x \<in> HFinite - Infinitesimal"
   by (fast intro: not_HFinite_HInfinite)
 
 lemma HFinite_inverse: "x \<in> HFinite \<Longrightarrow> x \<notin> Infinitesimal \<Longrightarrow> inverse x \<in> HFinite"
   for x :: "'a::real_normed_div_algebra star"
-  apply (subgoal_tac "x \<noteq> 0")
-   apply (cut_tac x = "inverse x" in HInfinite_HFinite_disj)
-   apply (auto dest!: HInfinite_inverse_Infinitesimal simp: nonzero_inverse_inverse_eq)
-  done
+  using HInfinite_inverse_Infinitesimal not_HFinite_HInfinite by force
 
 lemma HFinite_inverse2: "x \<in> HFinite - Infinitesimal \<Longrightarrow> inverse x \<in> HFinite"
   for x :: "'a::real_normed_div_algebra star"
@@ -1210,17 +1096,12 @@
 text \<open>Stronger statement possible in fact.\<close>
 lemma Infinitesimal_inverse_HFinite: "x \<notin> Infinitesimal \<Longrightarrow> inverse x \<in> HFinite"
   for x :: "'a::real_normed_div_algebra star"
-  apply (drule HInfinite_diff_HFinite_Infinitesimal_disj)
-  apply (blast intro: HFinite_inverse HInfinite_inverse_Infinitesimal Infinitesimal_subset_HFinite [THEN subsetD])
-  done
+  using HFinite_HInfinite_iff HInfinite_inverse_Infinitesimal by fastforce
 
 lemma HFinite_not_Infinitesimal_inverse:
   "x \<in> HFinite - Infinitesimal \<Longrightarrow> inverse x \<in> HFinite - Infinitesimal"
   for x :: "'a::real_normed_div_algebra star"
-  apply (auto intro: Infinitesimal_inverse_HFinite)
-  apply (drule Infinitesimal_HFinite_mult2, assumption)
-  apply (simp add: not_Infinitesimal_not_zero)
-  done
+  using HFinite_Infinitesimal_not_zero HFinite_inverse2 Infinitesimal_HFinite_mult2 by fastforce
 
 lemma approx_inverse: "x \<approx> y \<Longrightarrow> y \<in> HFinite - Infinitesimal \<Longrightarrow> inverse x \<approx> inverse y"
   for x y :: "'a::real_normed_div_algebra star"
@@ -1245,32 +1126,21 @@
 lemma inverse_add_Infinitesimal_approx2:
   "x \<in> HFinite - Infinitesimal \<Longrightarrow> h \<in> Infinitesimal \<Longrightarrow> inverse (h + x) \<approx> inverse x"
   for x h :: "'a::real_normed_div_algebra star"
-  apply (rule add.commute [THEN subst])
-  apply (blast intro: inverse_add_Infinitesimal_approx)
-  done
+  by (metis add.commute inverse_add_Infinitesimal_approx)
 
 lemma inverse_add_Infinitesimal_approx_Infinitesimal:
   "x \<in> HFinite - Infinitesimal \<Longrightarrow> h \<in> Infinitesimal \<Longrightarrow> inverse (x + h) - inverse x \<approx> h"
   for x h :: "'a::real_normed_div_algebra star"
-  apply (rule approx_trans2)
-   apply (auto intro: inverse_add_Infinitesimal_approx
-      simp add: mem_infmal_iff approx_minus_iff [symmetric])
-  done
+  by (meson Infinitesimal_approx bex_Infinitesimal_iff inverse_add_Infinitesimal_approx)
 
 lemma Infinitesimal_square_iff: "x \<in> Infinitesimal \<longleftrightarrow> x * x \<in> Infinitesimal"
   for x :: "'a::real_normed_div_algebra star"
-  apply (auto intro: Infinitesimal_mult)
-  apply (rule ccontr, frule Infinitesimal_inverse_HFinite)
-  apply (frule not_Infinitesimal_not_zero)
-  apply (auto dest: Infinitesimal_HFinite_mult simp add: mult.assoc)
-  done
+  using Infinitesimal_mult Infinitesimal_mult_disj by auto
 declare Infinitesimal_square_iff [symmetric, simp]
 
 lemma HFinite_square_iff [simp]: "x * x \<in> HFinite \<longleftrightarrow> x \<in> HFinite"
   for x :: "'a::real_normed_div_algebra star"
-  apply (auto intro: HFinite_mult)
-  apply (auto dest: HInfinite_mult simp add: HFinite_HInfinite_iff)
-  done
+  using HFinite_HInfinite_iff HFinite_mult HInfinite_mult by blast
 
 lemma HInfinite_square_iff [simp]: "x * x \<in> HInfinite \<longleftrightarrow> x \<in> HInfinite"
   for x :: "'a::real_normed_div_algebra star"
@@ -1278,26 +1148,17 @@
 
 lemma approx_HFinite_mult_cancel: "a \<in> HFinite - Infinitesimal \<Longrightarrow> a * w \<approx> a * z \<Longrightarrow> w \<approx> z"
   for a w z :: "'a::real_normed_div_algebra star"
-  apply safe
-  apply (frule HFinite_inverse, assumption)
-  apply (drule not_Infinitesimal_not_zero)
-  apply (auto dest: approx_mult2 simp add: mult.assoc [symmetric])
-  done
+  by (metis DiffD2 Infinitesimal_mult_disj bex_Infinitesimal_iff right_diff_distrib)
 
 lemma approx_HFinite_mult_cancel_iff1: "a \<in> HFinite - Infinitesimal \<Longrightarrow> a * w \<approx> a * z \<longleftrightarrow> w \<approx> z"
   for a w z :: "'a::real_normed_div_algebra star"
   by (auto intro: approx_mult2 approx_HFinite_mult_cancel)
 
 lemma HInfinite_HFinite_add_cancel: "x + y \<in> HInfinite \<Longrightarrow> y \<in> HFinite \<Longrightarrow> x \<in> HInfinite"
-  apply (rule ccontr)
-  apply (drule HFinite_HInfinite_iff [THEN iffD2])
-  apply (auto dest: HFinite_add simp add: HInfinite_HFinite_iff)
-  done
+  using HFinite_add HInfinite_HFinite_iff by blast
 
 lemma HInfinite_HFinite_add: "x \<in> HInfinite \<Longrightarrow> y \<in> HFinite \<Longrightarrow> x + y \<in> HInfinite"
-  apply (rule_tac y = "-y" in HInfinite_HFinite_add_cancel)
-   apply (auto simp add: add.assoc HFinite_minus_iff)
-  done
+  by (metis (no_types, hide_lams) HFinite_HInfinite_iff HFinite_add HFinite_minus_iff add.commute add_minus_cancel)
 
 lemma HInfinite_ge_HInfinite: "x \<in> HInfinite \<Longrightarrow> x \<le> y \<Longrightarrow> 0 \<le> x \<Longrightarrow> y \<in> HInfinite"
   for x y :: hypreal
@@ -1305,30 +1166,17 @@
 
 lemma Infinitesimal_inverse_HInfinite: "x \<in> Infinitesimal \<Longrightarrow> x \<noteq> 0 \<Longrightarrow> inverse x \<in> HInfinite"
   for x :: "'a::real_normed_div_algebra star"
-  apply (rule ccontr, drule HFinite_HInfinite_iff [THEN iffD2])
-  apply (auto dest: Infinitesimal_HFinite_mult2)
-  done
+  by (metis Infinitesimal_HFinite_mult not_HFinite_HInfinite one_not_Infinitesimal right_inverse)
 
 lemma HInfinite_HFinite_not_Infinitesimal_mult:
   "x \<in> HInfinite \<Longrightarrow> y \<in> HFinite - Infinitesimal \<Longrightarrow> x * y \<in> HInfinite"
   for x y :: "'a::real_normed_div_algebra star"
-  apply (rule ccontr, drule HFinite_HInfinite_iff [THEN iffD2])
-  apply (frule HFinite_Infinitesimal_not_zero)
-  apply (drule HFinite_not_Infinitesimal_inverse)
-  apply (safe, drule HFinite_mult)
-   apply (auto simp add: mult.assoc HFinite_HInfinite_iff)
-  done
+  by (metis (no_types, hide_lams) HFinite_HInfinite_iff HFinite_Infinitesimal_not_zero HFinite_inverse2 HFinite_mult mult.assoc mult.right_neutral right_inverse)
 
 lemma HInfinite_HFinite_not_Infinitesimal_mult2:
   "x \<in> HInfinite \<Longrightarrow> y \<in> HFinite - Infinitesimal \<Longrightarrow> y * x \<in> HInfinite"
   for x y :: "'a::real_normed_div_algebra star"
-  apply (rule ccontr, drule HFinite_HInfinite_iff [THEN iffD2])
-  apply (frule HFinite_Infinitesimal_not_zero)
-  apply (drule HFinite_not_Infinitesimal_inverse)
-  apply (safe, drule_tac x="inverse y" in HFinite_mult)
-   apply assumption
-  apply (auto simp add: mult.assoc [symmetric] HFinite_HInfinite_iff)
-  done
+  by (metis Diff_iff HInfinite_HFinite_iff HInfinite_inverse_Infinitesimal Infinitesimal_HFinite_mult2 divide_inverse mult_zero_right nonzero_eq_divide_eq)
 
 lemma HInfinite_gt_SReal: "x \<in> HInfinite \<Longrightarrow> 0 < x \<Longrightarrow> y \<in> \<real> \<Longrightarrow> y < x"
   for x y :: hypreal
@@ -1338,7 +1186,6 @@
   for x :: hypreal
   by (auto intro: HInfinite_gt_SReal)
 
-
 lemma not_HInfinite_one [simp]: "1 \<notin> HInfinite"
   by (simp add: HInfinite_HFinite_iff)
 
@@ -1379,9 +1226,7 @@
   by (simp (no_asm)) (simp add: approx_monad_iff)
 
 lemma approx_subset_monad2: "x \<approx> y \<Longrightarrow> {x, y} \<le> monad y"
-  apply (drule approx_sym)
-  apply (fast dest: approx_subset_monad)
-  done
+  using approx_subset_monad approx_sym by auto
 
 lemma mem_monad_approx: "u \<in> monad x \<Longrightarrow> x \<approx> u"
   by (simp add: monad_def)
@@ -1390,28 +1235,18 @@
   by (simp add: monad_def)
 
 lemma approx_mem_monad2: "x \<approx> u \<Longrightarrow> x \<in> monad u"
-  apply (simp add: monad_def)
-  apply (blast intro!: approx_sym)
-  done
+  using approx_mem_monad approx_sym by blast
 
 lemma approx_mem_monad_zero: "x \<approx> y \<Longrightarrow> x \<in> monad 0 \<Longrightarrow> y \<in> monad 0"
-  apply (drule mem_monad_approx)
-  apply (fast intro: approx_mem_monad approx_trans)
-  done
+  using approx_trans monad_def by blast
 
 lemma Infinitesimal_approx_hrabs: "x \<approx> y \<Longrightarrow> x \<in> Infinitesimal \<Longrightarrow> \<bar>x\<bar> \<approx> \<bar>y\<bar>"
   for x y :: hypreal
-  apply (drule Infinitesimal_monad_zero_iff [THEN iffD1])
-  apply (blast intro: approx_mem_monad_zero monad_zero_hrabs_iff [THEN iffD1]
-      mem_monad_approx approx_trans3)
-  done
+  using approx_hnorm by fastforce
 
 lemma less_Infinitesimal_less: "0 < x \<Longrightarrow> x \<notin> Infinitesimal \<Longrightarrow> e \<in> Infinitesimal \<Longrightarrow> e < x"
   for x :: hypreal
-  apply (rule ccontr)
-  apply (auto intro: Infinitesimal_zero [THEN [2] Infinitesimal_interval]
-      dest!: order_le_imp_less_or_eq simp add: linorder_not_less)
-  done
+  using Infinitesimal_interval less_linear by blast
 
 lemma Ball_mem_monad_gt_zero: "0 < x \<Longrightarrow> x \<notin> Infinitesimal \<Longrightarrow> u \<in> monad x \<Longrightarrow> 0 < u"
   for u x :: hypreal
@@ -1454,18 +1289,12 @@
 lemma hrabs_add_Infinitesimal_cancel:
   "e \<in> Infinitesimal \<Longrightarrow> e' \<in> Infinitesimal \<Longrightarrow> \<bar>x + e\<bar> = \<bar>y + e'\<bar> \<Longrightarrow> \<bar>x\<bar> \<approx> \<bar>y\<bar>"
   for e e' x y :: hypreal
-  apply (drule_tac x = x in approx_hrabs_add_Infinitesimal)
-  apply (drule_tac x = y in approx_hrabs_add_Infinitesimal)
-  apply (auto intro: approx_trans2)
-  done
+  by (metis approx_hrabs_add_Infinitesimal approx_trans2)
 
 lemma hrabs_add_minus_Infinitesimal_cancel:
   "e \<in> Infinitesimal \<Longrightarrow> e' \<in> Infinitesimal \<Longrightarrow> \<bar>x + -e\<bar> = \<bar>y + -e'\<bar> \<Longrightarrow> \<bar>x\<bar> \<approx> \<bar>y\<bar>"
   for e e' x y :: hypreal
-  apply (drule_tac x = x in approx_hrabs_add_minus_Infinitesimal)
-  apply (drule_tac x = y in approx_hrabs_add_minus_Infinitesimal)
-  apply (auto intro: approx_trans2)
-  done
+  by (meson Infinitesimal_minus_iff hrabs_add_Infinitesimal_cancel)
 
 
 subsection \<open>More \<^term>\<open>HFinite\<close> and \<^term>\<open>Infinitesimal\<close> Theorems\<close>
@@ -1493,9 +1322,7 @@
 lemma Infinitesimal_add_hrabs_hypreal_of_real_less2:
   "x \<in> Infinitesimal \<Longrightarrow> \<bar>hypreal_of_real r\<bar> < hypreal_of_real y \<Longrightarrow>
     \<bar>x + hypreal_of_real r\<bar> < hypreal_of_real y"
-  apply (rule add.commute [THEN subst])
-  apply (erule Infinitesimal_add_hrabs_hypreal_of_real_less, assumption)
-  done
+  using Infinitesimal_add_hrabs_hypreal_of_real_less by fastforce
 
 lemma hypreal_of_real_le_add_Infininitesimal_cancel:
   "u \<in> Infinitesimal \<Longrightarrow> v \<in> Infinitesimal \<Longrightarrow>
@@ -1513,10 +1340,7 @@
 
 lemma hypreal_of_real_less_Infinitesimal_le_zero:
   "hypreal_of_real x < e \<Longrightarrow> e \<in> Infinitesimal \<Longrightarrow> hypreal_of_real x \<le> 0"
-  apply (rule linorder_not_less [THEN iffD1], safe)
-  apply (drule Infinitesimal_interval)
-     apply (drule_tac [4] SReal_hypreal_of_real [THEN SReal_Infinitesimal_zero], auto)
-  done
+  by (metis Infinitesimal_interval eq_iff le_less_linear star_of_Infinitesimal_iff_0 star_of_eq_0)
 
 (*used once, in Lim/NSDERIV_inverse*)
 lemma Infinitesimal_add_not_zero: "h \<in> Infinitesimal \<Longrightarrow> x \<noteq> 0 \<Longrightarrow> star_of x + h \<noteq> 0"
@@ -1527,16 +1351,11 @@
 
 lemma Infinitesimal_square_cancel [simp]: "x * x + y * y \<in> Infinitesimal \<Longrightarrow> x * x \<in> Infinitesimal"
   for x y :: hypreal
-  apply (rule Infinitesimal_interval2)
-     apply (rule_tac [3] zero_le_square, assumption)
-   apply auto
-  done
+  by (meson Infinitesimal_interval2 le_add_same_cancel1 not_Infinitesimal_not_zero zero_le_square)
 
 lemma HFinite_square_cancel [simp]: "x * x + y * y \<in> HFinite \<Longrightarrow> x * x \<in> HFinite"
   for x y :: hypreal
-  apply (rule HFinite_bounded, assumption)
-   apply auto
-  done
+  using HFinite_bounded le_add_same_cancel1 zero_le_square by blast
 
 lemma Infinitesimal_square_cancel2 [simp]: "x * x + y * y \<in> Infinitesimal \<Longrightarrow> y * y \<in> Infinitesimal"
   for x y :: hypreal
@@ -1596,27 +1415,16 @@
   done
 
 lemma monad_hrabs_less: "y \<in> monad x \<Longrightarrow> 0 < hypreal_of_real e \<Longrightarrow> \<bar>y - x\<bar> < hypreal_of_real e"
-  apply (drule mem_monad_approx [THEN approx_sym])
-  apply (drule bex_Infinitesimal_iff [THEN iffD2])
-  apply (auto dest!: InfinitesimalD)
-  done
+  by (simp add: Infinitesimal_approx_minus approx_sym less_Infinitesimal_less mem_monad_approx)
 
 lemma mem_monad_SReal_HFinite: "x \<in> monad (hypreal_of_real  a) \<Longrightarrow> x \<in> HFinite"
-  apply (drule mem_monad_approx [THEN approx_sym])
-  apply (drule bex_Infinitesimal_iff2 [THEN iffD2])
-  apply (safe dest!: Infinitesimal_subset_HFinite [THEN subsetD])
-  apply (erule SReal_hypreal_of_real [THEN SReal_subset_HFinite [THEN subsetD], THEN HFinite_add])
-  done
+  using HFinite_star_of approx_HFinite mem_monad_approx by blast
 
 
 subsection \<open>Theorems about Standard Part\<close>
 
 lemma st_approx_self: "x \<in> HFinite \<Longrightarrow> st x \<approx> x"
-  apply (simp add: st_def)
-  apply (frule st_part_Ex, safe)
-  apply (rule someI2)
-   apply (auto intro: approx_sym)
-  done
+  by (metis (no_types, lifting) approx_refl approx_trans3 someI_ex st_def st_part_Ex st_part_Ex1)
 
 lemma st_SReal: "x \<in> HFinite \<Longrightarrow> st x \<in> \<real>"
   apply (simp add: st_def)
@@ -1813,9 +1621,6 @@
   for u :: real
   by auto
 
-lemma lemma_Int_HIa: "{n. u < norm (X n)} \<inter> {n. norm (X n) < u} = {}"
-  by (auto intro: order_less_asym)
-
 lemma FreeUltrafilterNat_HInfinite:
   "\<forall>u. eventually (\<lambda>n. u < norm (X n)) \<U> \<Longrightarrow> star_n X \<in> HInfinite"
   apply (rule HInfinite_HFinite_iff [THEN iffD2])
@@ -1862,9 +1667,7 @@
 text \<open>Infinitesimals as smaller than \<open>1/n\<close> for all \<open>n::nat (> 0)\<close>.\<close>
 
 lemma lemma_Infinitesimal: "(\<forall>r. 0 < r \<longrightarrow> x < r) \<longleftrightarrow> (\<forall>n. x < inverse (real (Suc n)))"
-  apply (auto simp del: of_nat_Suc)
-  apply (blast dest!: reals_Archimedean intro: order_less_trans)
-  done
+  by (meson inverse_positive_iff_positive less_trans of_nat_0_less_iff reals_Archimedean zero_less_Suc)
 
 lemma lemma_Infinitesimal2:
   "(\<forall>r \<in> Reals. 0 < r \<longrightarrow> x < r) \<longleftrightarrow> (\<forall>n. x < inverse(hypreal_of_nat (Suc n)))"
@@ -1881,9 +1684,7 @@
 
 lemma Infinitesimal_hypreal_of_nat_iff:
   "Infinitesimal = {x. \<forall>n. hnorm x < inverse (hypreal_of_nat (Suc n))}"
-  apply (simp add: Infinitesimal_def)
-  apply (auto simp add: lemma_Infinitesimal2)
-  done
+  using Infinitesimal_def lemma_Infinitesimal2 by auto
 
 
 subsection \<open>Proof that \<open>\<omega>\<close> is an infinite number\<close>
@@ -1905,11 +1706,8 @@
   apply (auto dest: order_less_trans)
   done
 
-lemma lemma_real_le_Un_eq: "{n. f n \<le> u} = {n. f n < u} \<union> {n. u = (f n :: real)}"
-  by (auto dest: order_le_imp_less_or_eq simp add: order_less_imp_le)
-
 lemma finite_real_of_nat_le_real: "finite {n::nat. real n \<le> u}"
-  by (auto simp add: lemma_real_le_Un_eq lemma_finite_omega_set finite_real_of_nat_less_real)
+  by (metis infinite_nat_iff_unbounded leD le_nat_floor mem_Collect_eq)
 
 lemma finite_rabs_real_of_nat_le_real: "finite {n::nat. \<bar>real n\<bar> \<le> u}"
   by (simp add: finite_real_of_nat_le_real)
@@ -1927,9 +1725,6 @@
 text \<open>The complement of \<open>{n. \<bar>real n\<bar> \<le> u} = {n. u < \<bar>real n\<bar>}\<close> is in
   \<open>\<U>\<close> by property of (free) ultrafilters.\<close>
 
-lemma Compl_real_le_eq: "- {n::nat. real n \<le> u} = {n. u < real n}"
-  by (auto dest!: order_le_less_trans simp add: linorder_not_le)
-
 text \<open>\<^term>\<open>\<omega>\<close> is a member of \<^term>\<open>HInfinite\<close>.\<close>
 theorem HInfinite_omega [simp]: "\<omega> \<in> HInfinite"
   apply (simp add: omega_def)
@@ -1955,12 +1750,7 @@
 text \<open>Needed for proof that we define a hyperreal \<open>[<X(n)] \<approx> hypreal_of_real a\<close> given
   that \<open>\<forall>n. |X n - a| < 1/n\<close>. Used in proof of \<open>NSLIM \<Rightarrow> LIM\<close>.\<close>
 lemma real_of_nat_less_inverse_iff: "0 < u \<Longrightarrow> u < inverse (real(Suc n)) \<longleftrightarrow> real(Suc n) < inverse u"
-  apply (simp add: inverse_eq_divide)
-  apply (subst pos_less_divide_eq, assumption)
-  apply (subst pos_less_divide_eq)
-   apply simp
-  apply (simp add: mult.commute)
-  done
+  using less_imp_inverse_less by force
 
 lemma finite_inverse_real_of_posnat_gt_real: "0 < u \<Longrightarrow> finite {n. u < inverse (real (Suc n))}"
 proof (simp only: real_of_nat_less_inverse_iff)