merged
authorwenzelm
Wed, 18 Nov 2020 21:53:58 +0100
changeset 72655 c88e9369a772
parent 72645 f8cc3153ac77 (diff)
parent 72654 99a6bcd1e8e4 (current diff)
child 72656 a17c17ab931c
merged
--- a/src/HOL/Analysis/Elementary_Normed_Spaces.thy	Wed Nov 18 21:39:55 2020 +0100
+++ b/src/HOL/Analysis/Elementary_Normed_Spaces.thy	Wed Nov 18 21:53:58 2020 +0100
@@ -85,23 +85,23 @@
 subsection \<open>Support\<close>
 
 definition (in monoid_add) support_on :: "'b set \<Rightarrow> ('b \<Rightarrow> 'a) \<Rightarrow> 'b set"
-  where "support_on s f = {x\<in>s. f x \<noteq> 0}"
+  where "support_on S f = {x\<in>S. f x \<noteq> 0}"
 
-lemma in_support_on: "x \<in> support_on s f \<longleftrightarrow> x \<in> s \<and> f x \<noteq> 0"
+lemma in_support_on: "x \<in> support_on S f \<longleftrightarrow> x \<in> S \<and> f x \<noteq> 0"
   by (simp add: support_on_def)
 
 lemma support_on_simps[simp]:
   "support_on {} f = {}"
-  "support_on (insert x s) f =
-    (if f x = 0 then support_on s f else insert x (support_on s f))"
-  "support_on (s \<union> t) f = support_on s f \<union> support_on t f"
-  "support_on (s \<inter> t) f = support_on s f \<inter> support_on t f"
-  "support_on (s - t) f = support_on s f - support_on t f"
-  "support_on (f ` s) g = f ` (support_on s (g \<circ> f))"
+  "support_on (insert x S) f =
+    (if f x = 0 then support_on S f else insert x (support_on S f))"
+  "support_on (S \<union> T) f = support_on S f \<union> support_on T f"
+  "support_on (S \<inter> T) f = support_on S f \<inter> support_on T f"
+  "support_on (S - T) f = support_on S f - support_on T f"
+  "support_on (f ` S) g = f ` (support_on S (g \<circ> f))"
   unfolding support_on_def by auto
 
 lemma support_on_cong:
-  "(\<And>x. x \<in> s \<Longrightarrow> f x = 0 \<longleftrightarrow> g x = 0) \<Longrightarrow> support_on s f = support_on s g"
+  "(\<And>x. x \<in> S \<Longrightarrow> f x = 0 \<longleftrightarrow> g x = 0) \<Longrightarrow> support_on S f = support_on S g"
   by (auto simp: support_on_def)
 
 lemma support_on_if: "a \<noteq> 0 \<Longrightarrow> support_on A (\<lambda>x. if P x then a else 0) = {x\<in>A. P x}"
@@ -153,14 +153,13 @@
     proof (clarsimp, intro conjI impI subsetI)
       show "\<lbrakk>0 \<le> m; a \<le> b; x \<in> {m *\<^sub>R a + c..m *\<^sub>R b + c}\<rbrakk>
             \<Longrightarrow> x \<in> (\<lambda>x. m *\<^sub>R x + c) ` {a..b}" for x
-        apply (rule_tac x="inverse m *\<^sub>R (x-c)" in rev_image_eqI)
-        using False apply (auto simp: pos_le_divideR_eq pos_divideR_le_eq le_diff_eq diff_le_eq)
-        done
+        using False
+        by (rule_tac x="inverse m *\<^sub>R (x-c)" in image_eqI)
+           (auto simp: pos_le_divideR_eq pos_divideR_le_eq le_diff_eq diff_le_eq)
       show "\<lbrakk>\<not> 0 \<le> m; a \<le> b;  x \<in> {m *\<^sub>R b + c..m *\<^sub>R a + c}\<rbrakk>
             \<Longrightarrow> x \<in> (\<lambda>x. m *\<^sub>R x + c) ` {a..b}" for x
-        apply (rule_tac x="inverse m *\<^sub>R (x-c)" in rev_image_eqI)
-         apply (auto simp add: neg_le_divideR_eq neg_divideR_le_eq not_le le_diff_eq diff_le_eq)
-        done
+        by (rule_tac x="inverse m *\<^sub>R (x-c)" in image_eqI)
+           (auto simp add: neg_le_divideR_eq neg_divideR_le_eq le_diff_eq diff_le_eq)
     qed
   qed
 qed
@@ -196,12 +195,12 @@
       have "\<exists>x'\<in>ball x e. x' \<noteq> y \<and> dist x' y < d"
       proof (cases "d \<le> dist x y")
         case True
-        then show "\<exists>x'\<in>ball x e. x' \<noteq> y \<and> dist x' y < d"
+        then show ?thesis
         proof (cases "x = y")
           case True
           then have False
             using \<open>d \<le> dist x y\<close> \<open>d>0\<close> by auto
-          then show "\<exists>x'\<in>ball x e. x' \<noteq> y \<and> dist x' y < d"
+          then show ?thesis
             by auto
         next
           case False
@@ -226,17 +225,9 @@
             by (auto simp: dist_commute)
           moreover
           have "dist (y - (d / (2 * dist y x)) *\<^sub>R (y - x)) y < d"
-            unfolding dist_norm
-            apply simp
-            unfolding norm_minus_cancel
-            using \<open>d > 0\<close> \<open>x\<noteq>y\<close>[unfolded dist_nz] dist_commute[of x y]
-            unfolding dist_norm
-            apply auto
-            done
-          ultimately show "\<exists>x'\<in>ball x e. x' \<noteq> y \<and> dist x' y < d"
-            apply (rule_tac x = "y - (d / (2*dist y x)) *\<^sub>R (y - x)" in bexI)
-            apply auto
-            done
+            using \<open>0 < d\<close> by (fastforce simp: dist_norm)
+          ultimately show ?thesis
+            by (rule_tac x = "y - (d / (2*dist y x)) *\<^sub>R (y - x)" in bexI) auto
         qed
       next
         case False
@@ -244,21 +235,15 @@
         show "\<exists>x' \<in> ball x e. x' \<noteq> y \<and> dist x' y < d"
         proof (cases "x = y")
           case True
-          obtain z where **: "z \<noteq> y" "dist z y < min e d"
+          obtain z where z: "z \<noteq> y" "dist z y < min e d"
             using perfect_choose_dist[of "min e d" y]
             using \<open>d > 0\<close> \<open>e>0\<close> by auto
-          show "\<exists>x'\<in>ball x e. x' \<noteq> y \<and> dist x' y < d"
-            unfolding \<open>x = y\<close>
-            using \<open>z \<noteq> y\<close> **
-            apply (rule_tac x=z in bexI)
-            apply (auto simp: dist_commute)
-            done
+          show ?thesis
+            by (metis True z dist_commute mem_ball min_less_iff_conj)
         next
           case False
-          then show "\<exists>x'\<in>ball x e. x' \<noteq> y \<and> dist x' y < d"
-            using \<open>d>0\<close> \<open>d > dist x y\<close> \<open>?rhs\<close>
-            apply (rule_tac x=x in bexI, auto)
-            done
+          then show ?thesis
+            using \<open>d>0\<close> \<open>d > dist x y\<close> \<open>?rhs\<close> by force
         qed
       qed
     }
@@ -276,7 +261,7 @@
   assume "y \<in> T" "open T"
   then obtain r where "0 < r" "\<forall>z. dist z y < r \<longrightarrow> z \<in> T"
     unfolding open_dist by fast
-  (* choose point between x and y, within distance r of y. *)
+  \<comment>\<open>choose point between @{term x} and @{term y}, within distance @{term r} of @{term y}.\<close>
   define k where "k = min 1 (r / (2 * dist x y))"
   define z where "z = y + scaleR k (x - y)"
   have z_def2: "z = x + scaleR (1 - k) (y - x)"
@@ -287,14 +272,7 @@
   then have "z \<in> T"
     using \<open>\<forall>z. dist z y < r \<longrightarrow> z \<in> T\<close> by simp
   have "dist x z < dist x y"
-    unfolding z_def2 dist_norm
-    apply (simp add: norm_minus_commute)
-    apply (simp only: dist_norm [symmetric])
-    apply (subgoal_tac "\<bar>1 - k\<bar> * dist x y < 1 * dist x y", simp)
-    apply (rule mult_strict_right_mono)
-    apply (simp add: k_def \<open>0 < r\<close> \<open>x \<noteq> y\<close>)
-    apply (simp add: \<open>x \<noteq> y\<close>)
-    done
+    using \<open>0 < r\<close> assms by (simp add: z_def2 k_def dist_norm norm_minus_commute) 
   then have "z \<in> ball x (dist x y)"
     by simp
   have "z \<noteq> y"
@@ -310,31 +288,28 @@
 
 lemma mem_ball_0 [simp]: "x \<in> ball 0 e \<longleftrightarrow> norm x < e"
   for x :: "'a::real_normed_vector"
-  by (simp add: dist_norm)
+  by simp
 
 lemma mem_cball_0 [simp]: "x \<in> cball 0 e \<longleftrightarrow> norm x \<le> e"
   for x :: "'a::real_normed_vector"
-  by (simp add: dist_norm)
+  by simp
 
 lemma closure_ball [simp]:
   fixes x :: "'a::real_normed_vector"
-  shows "0 < e \<Longrightarrow> closure (ball x e) = cball x e"
-  apply (rule equalityI)
-  apply (rule closure_minimal)
-  apply (rule ball_subset_cball)
-  apply (rule closed_cball)
-  apply (rule subsetI, rename_tac y)
-  apply (simp add: le_less [where 'a=real])
-  apply (erule disjE)
-  apply (rule subsetD [OF closure_subset], simp)
-  apply (simp add: closure_def, clarify)
-  apply (rule closure_ball_lemma)
-  apply simp
-  done
+  assumes "0 < e"
+  shows "closure (ball x e) = cball x e"
+proof
+  show "closure (ball x e) \<subseteq> cball x e"
+    using closed_cball closure_minimal by blast
+  have "\<And>y. dist x y < e \<or> dist x y = e \<Longrightarrow> y \<in> closure (ball x e)"
+    by (metis Un_iff assms closure_ball_lemma closure_def dist_eq_0_iff mem_Collect_eq mem_ball)
+  then show "cball x e \<subseteq> closure (ball x e)"
+    by force
+qed
 
 lemma mem_sphere_0 [simp]: "x \<in> sphere 0 e \<longleftrightarrow> norm x = e"
   for x :: "'a::real_normed_vector"
-  by (simp add: dist_norm)
+  by simp
 
 (* In a trivial vector space, this fails for e = 0. *)
 lemma interior_cball [simp]:
@@ -440,20 +415,27 @@
 lemma image_add_ball [simp]:
   fixes a :: "'a::real_normed_vector"
   shows "(+) b ` ball a r = ball (a+b) r"
-apply (intro equalityI subsetI)
-apply (force simp: dist_norm)
-apply (rule_tac x="x-b" in image_eqI)
-apply (auto simp: dist_norm algebra_simps)
-done
+proof -
+  { fix x :: 'a
+    assume "dist (a + b) x < r"
+    moreover
+    have "b + (x - b) = x"
+      by simp
+    ultimately have "x \<in> (+) b ` ball a r"
+      by (metis add.commute dist_add_cancel image_eqI mem_ball) }
+  then show ?thesis
+    by (auto simp: add.commute)
+qed
 
 lemma image_add_cball [simp]:
   fixes a :: "'a::real_normed_vector"
   shows "(+) b ` cball a r = cball (a+b) r"
-apply (intro equalityI subsetI)
-apply (force simp: dist_norm)
-apply (rule_tac x="x-b" in image_eqI)
-apply (auto simp: dist_norm algebra_simps)
-done
+proof -
+  have "\<And>x. dist (a + b) x \<le> r \<Longrightarrow> \<exists>y\<in>cball a r. x = b + y"
+    by (metis (no_types) add.commute diff_add_cancel dist_add_cancel2 mem_cball)
+  then show ?thesis
+    by (force simp: add.commute)
+qed
 
 
 subsection\<^marker>\<open>tag unimportant\<close> \<open>Various Lemmas on Normed Algebras\<close>
@@ -492,20 +474,21 @@
 
 lemma trivial_limit_at_infinity:
   "\<not> trivial_limit (at_infinity :: ('a::{real_normed_vector,perfect_space}) filter)"
-  unfolding trivial_limit_def eventually_at_infinity
-  apply clarsimp
-  apply (subgoal_tac "\<exists>x::'a. x \<noteq> 0", clarify)
-   apply (rule_tac x="scaleR (b / norm x) x" in exI, simp)
-  apply (cut_tac islimpt_UNIV [of "0::'a", unfolded islimpt_def])
-  apply (drule_tac x=UNIV in spec, simp)
-  done
+proof -
+  obtain x::'a where "x \<noteq> 0"
+    by (meson perfect_choose_dist zero_less_one)
+  then have "b \<le> norm ((b / norm x) *\<^sub>R x)" for b
+    by simp
+  then show ?thesis
+    unfolding trivial_limit_def eventually_at_infinity
+    by blast
+qed
 
 lemma at_within_ball_bot_iff:
   fixes x y :: "'a::{real_normed_vector,perfect_space}"
   shows "at x within ball y r = bot \<longleftrightarrow> (r=0 \<or> x \<notin> cball y r)"
-  unfolding trivial_limit_within 
-  apply (auto simp add:trivial_limit_within islimpt_ball )
-  by (metis le_less_trans less_eq_real_def zero_le_dist)
+  unfolding trivial_limit_within
+  by (metis (no_types) cball_empty equals0D islimpt_ball less_linear) 
 
 
 subsection \<open>Limits\<close>
@@ -516,9 +499,12 @@
 corollary Lim_at_infinityI [intro?]:
   assumes "\<And>e. e > 0 \<Longrightarrow> \<exists>B. \<forall>x. norm x \<ge> B \<longrightarrow> dist (f x) l \<le> e"
   shows "(f \<longlongrightarrow> l) at_infinity"
-  apply (simp add: Lim_at_infinity, clarify)
-  apply (rule ex_forward [OF assms [OF half_gt_zero]], auto)
-  done
+proof -
+  have "\<And>e. e > 0 \<Longrightarrow> \<exists>B. \<forall>x. norm x \<ge> B \<longrightarrow> dist (f x) l < e"
+    by (meson assms dense le_less_trans)
+  then show ?thesis
+    using Lim_at_infinity by blast
+qed
 
 lemma Lim_transform_within_set_eq:
   fixes a :: "'a::metric_space" and l :: "'b::metric_space"
@@ -555,12 +541,13 @@
   assumes f: "(f \<longlongrightarrow> 0) F" and g: "eventually (\<lambda>x. norm(g x) \<le> B) F"
     shows "((\<lambda>z. f z * g z) \<longlongrightarrow> 0) F"
 proof -
-  have *: "((\<lambda>x. norm (f x) * B) \<longlongrightarrow> 0) F"
-    by (simp add: f tendsto_mult_left_zero tendsto_norm_zero)
   have "((\<lambda>x. norm (f x) * norm (g x)) \<longlongrightarrow> 0) F"
-    apply (rule Lim_null_comparison [OF _ *])
-    apply (simp add: eventually_mono [OF g] mult_left_mono)
-    done
+  proof (rule Lim_null_comparison)
+    show "\<forall>\<^sub>F x in F. norm (norm (f x) * norm (g x)) \<le> norm (f x) * B"
+      by (simp add: eventually_mono [OF g] mult_left_mono)
+    show "((\<lambda>x. norm (f x) * B) \<longlongrightarrow> 0) F"
+      by (simp add: f tendsto_mult_left_zero tendsto_norm_zero)
+  qed
   then show ?thesis
     by (subst tendsto_norm_zero_iff [symmetric]) (simp add: norm_mult)
 qed
@@ -570,12 +557,13 @@
   assumes g: "eventually (\<lambda>x. norm(g x) \<le> B) F" and f: "(f \<longlongrightarrow> 0) F"
     shows "((\<lambda>z. g z * f z) \<longlongrightarrow> 0) F"
 proof -
-  have *: "((\<lambda>x. B * norm (f x)) \<longlongrightarrow> 0) F"
-    by (simp add: f tendsto_mult_right_zero tendsto_norm_zero)
   have "((\<lambda>x. norm (g x) * norm (f x)) \<longlongrightarrow> 0) F"
-    apply (rule Lim_null_comparison [OF _ *])
-    apply (simp add: eventually_mono [OF g] mult_right_mono)
-    done
+  proof (rule Lim_null_comparison)
+    show "\<forall>\<^sub>F x in F. norm (norm (g x) * norm (f x)) \<le> B * norm (f x)"
+      by (simp add: eventually_mono [OF g] mult_right_mono)
+    show "((\<lambda>x. B * norm (f x)) \<longlongrightarrow> 0) F"
+      by (simp add: f tendsto_mult_right_zero tendsto_norm_zero)
+  qed
   then show ?thesis
     by (subst tendsto_norm_zero_iff [symmetric]) (simp add: norm_mult)
 qed
@@ -597,10 +585,10 @@
       by (rule f)
     finally show ?thesis .
   qed
-  show "\<forall>\<^sub>F x in net. dist (f x *\<^sub>R g x) 0 < \<epsilon>"
-    apply (rule eventually_mono [OF eventually_conj [OF tendstoD [OF f B] gB] ])
-    apply (auto simp: \<open>0 < \<epsilon>\<close> field_split_simps * split: if_split_asm)
-    done
+  have "\<And>x. \<lbrakk>\<bar>f x\<bar> < \<epsilon> / (\<bar>B\<bar> + 1); norm (g x) \<le> B\<rbrakk> \<Longrightarrow> \<bar>f x\<bar> * norm (g x) < \<epsilon>"
+    by (simp add: "*" pos_less_divide_eq)
+  then show "\<forall>\<^sub>F x in net. dist (f x *\<^sub>R g x) 0 < \<epsilon>"
+    using \<open>0 < \<epsilon>\<close> by (auto intro: eventually_mono [OF eventually_conj [OF tendstoD [OF f B] gB]])
 qed
 
 lemma Lim_norm_ubound:
@@ -641,12 +629,10 @@
   shows "netlimit (at a) = a"
 proof (cases "\<exists>x. x \<noteq> a")
   case True then obtain x where x: "x \<noteq> a" ..
-  have "\<not> trivial_limit (at a)"
-    unfolding trivial_limit_def eventually_at dist_norm
-    apply clarsimp
-    apply (rule_tac x="a + scaleR (d / 2) (sgn (x - a))" in exI)
-    apply (simp add: norm_sgn sgn_zero_iff x)
-    done
+  have "\<And>d. 0 < d \<Longrightarrow> \<exists>x. x \<noteq> a \<and> norm (x - a) < d"
+    by (rule_tac x="a + scaleR (d / 2) (sgn (x - a))" in exI) (simp add: norm_sgn sgn_zero_iff x)
+  then have "\<not> trivial_limit (at a)"
+    by (auto simp: trivial_limit_def eventually_at dist_norm)
   then show ?thesis
     by (rule Lim_ident_at [of a UNIV])
 qed simp
@@ -671,9 +657,7 @@
   by (meson less_imp_le not_le order_trans zero_less_one)
 
 lemma bounded_pos_less: "bounded S \<longleftrightarrow> (\<exists>b>0. \<forall>x\<in> S. norm x < b)"
-  apply (simp add: bounded_pos)
-  apply (safe; rule_tac x="b+1" in exI; force)
-  done
+  by (metis bounded_pos le_less_trans less_imp_le linordered_field_no_ub)
 
 lemma Bseq_eq_bounded:
   fixes f :: "nat \<Rightarrow> 'a::real_normed_vector"
@@ -700,9 +684,7 @@
 lemma bounded_scaling:
   fixes S :: "'a::real_normed_vector set"
   shows "bounded S \<Longrightarrow> bounded ((\<lambda>x. c *\<^sub>R x) ` S)"
-  apply (rule bounded_linear_image, assumption)
-  apply (rule bounded_linear_scaleR_right)
-  done
+  by (simp add: bounded_linear_image bounded_linear_scaleR_right)
 
 lemma bounded_scaleR_comp:
   fixes f :: "'a \<Rightarrow> 'b::real_normed_vector"
@@ -818,13 +800,13 @@
 proof -
   obtain M where M: "\<And>x. norm (a x * z ^ x) \<le> M"
     using summable_imp_bounded [OF sum] by (force simp: bounded_iff)
-  then have *: "summable (\<lambda>n. norm (a n) * norm w ^ n)"
-    by (rule_tac M=M in Abel_lemma) (auto simp: norm_mult norm_power intro: no)
   show ?thesis
-    apply (rule series_comparison_complex [of "(\<lambda>n. of_real(norm(a n) * norm w ^ n))"])
-    apply (simp only: summable_complex_of_real *)
-    apply (auto simp: norm_mult norm_power)
-    done
+  proof (rule series_comparison_complex)
+    have "\<And>n. norm (a n) * norm z ^ n \<le> M"
+      by (metis (no_types) M norm_mult norm_power)
+    then show "summable (\<lambda>n. complex_of_real (norm (a n) * norm w ^ n))"
+      using Abel_lemma no norm_ge_zero summable_of_real by blast
+  qed (auto simp: norm_mult norm_power)
 qed
 
 
@@ -931,9 +913,7 @@
   have *: "\<And>S T. S \<in> range F \<and> T \<in> range F \<Longrightarrow> S \<subseteq> T \<or> T \<subseteq> S"
     by (metis mono image_iff le_cases)
   show ?thesis
-    apply (rule compact_chain [OF _ _ *])
-    using F apply (blast intro: dest: *)+
-    done
+    using F by (intro compact_chain [OF _ _ *]; blast dest: *)
 qed
 
 text\<open>The Baire property of dense sets\<close>
@@ -1006,17 +986,17 @@
       qed
       let ?\<Phi> = "\<lambda>n X. openin (top_of_set S) X \<and> X \<noteq> {} \<and>
                       S \<inter> closure X \<subseteq> ?g n \<and> closure X \<subseteq> ball x e"
-      have "closure (S \<inter> ball x (e / 2)) \<subseteq> closure(ball x (e/2))"
+      have "closure (S \<inter> ball x (e/2)) \<subseteq> closure(ball x (e/2))"
         by (simp add: closure_mono)
       also have "...  \<subseteq> ball x e"
         using \<open>e > 0\<close> by auto
-      finally have "closure (S \<inter> ball x (e / 2)) \<subseteq> ball x e" .
-      moreover have"openin (top_of_set S) (S \<inter> ball x (e / 2))" "S \<inter> ball x (e / 2) \<noteq> {}"
+      finally have "closure (S \<inter> ball x (e/2)) \<subseteq> ball x e" .
+      moreover have"openin (top_of_set S) (S \<inter> ball x (e/2))" "S \<inter> ball x (e/2) \<noteq> {}"
         using \<open>0 < e\<close> \<open>x \<in> S\<close> by auto
-      ultimately obtain Y where Y: "?\<Phi> 0 Y \<and> Y \<subseteq> S \<inter> ball x (e / 2)"
+      ultimately obtain Y where Y: "?\<Phi> 0 Y \<and> Y \<subseteq> S \<inter> ball x (e/2)"
             using * [of "S \<inter> ball x (e/2)" 0] by metis
       show thesis
-      proof (rule exE [OF dependent_nat_choice [of ?\<Phi> "\<lambda>n X Y. Y \<subseteq> X"]])
+      proof (rule exE [OF dependent_nat_choice])
         show "\<exists>x. ?\<Phi> 0 x"
           using Y by auto
         show "\<exists>Y. ?\<Phi> (Suc n) Y \<and> Y \<subseteq> X" if "?\<Phi> n X" for X n
@@ -1159,20 +1139,16 @@
     {
       fix y
       assume "dist y (c *\<^sub>R x) < e * \<bar>c\<bar>"
+      then have "norm (c *\<^sub>R ((1 / c) *\<^sub>R y - x)) < e * norm c"
+        by (simp add: \<open>c \<noteq> 0\<close> dist_norm scale_right_diff_distrib)
       then have "norm ((1 / c) *\<^sub>R y - x) < e"
-        unfolding dist_norm
-        using norm_scaleR[of c "(1 / c) *\<^sub>R y - x", unfolded scaleR_right_diff_distrib, unfolded scaleR_scaleR] assms(1)
-          assms(1)[unfolded zero_less_abs_iff[symmetric]] by (simp del:zero_less_abs_iff)
+        by (simp add: \<open>c \<noteq> 0\<close>)
       then have "y \<in> (*\<^sub>R) c ` s"
         using rev_image_eqI[of "(1 / c) *\<^sub>R y" s y "(*\<^sub>R) c"]
-        using e[THEN spec[where x="(1 / c) *\<^sub>R y"]]
-        using assms(1)
-        unfolding dist_norm scaleR_scaleR
-        by auto
+        by (simp add: \<open>c \<noteq> 0\<close> dist_norm e)
     }
     ultimately have "\<exists>e>0. \<forall>x'. dist x' (c *\<^sub>R x) < e \<longrightarrow> x' \<in> (*\<^sub>R) c ` s"
-      apply (rule_tac x="e * \<bar>c\<bar>" in exI, auto)
-      done
+      by (rule_tac x="e * \<bar>c\<bar>" in exI, auto)
   }
   then show ?thesis unfolding open_dist by auto
 qed
@@ -1243,11 +1219,7 @@
     by (auto simp: diff_diff_eq)
   then show "x \<in> (+) a ` interior S"
     unfolding image_iff
-    apply (rule_tac x="x - a" in bexI)
-    unfolding mem_interior
-    using \<open>e > 0\<close>
-    apply auto
-    done
+    by (metis \<open>0 < e\<close> add.commute diff_add_cancel mem_interior)
 next
   fix x
   assume "x \<in> (+) a ` interior S"
@@ -1301,11 +1273,7 @@
   shows "compact {x + y | x y. x \<in> s \<and> y \<in> t}"
 proof -
   have *: "{x + y | x y. x \<in> s \<and> y \<in> t} = (\<lambda>z. fst z + snd z) ` (s \<times> t)"
-    apply auto
-    unfolding image_iff
-    apply (rule_tac x="(xa, y)" in bexI)
-    apply auto
-    done
+    by (fastforce simp: image_iff)
   have "continuous_on (s \<times> t) (\<lambda>z. fst z + snd z)"
     unfolding continuous_on by (rule ballI) (intro tendsto_intros)
   then show ?thesis
@@ -1318,10 +1286,8 @@
     and "compact t"
   shows "compact {x - y | x y. x \<in> s \<and> y \<in> t}"
 proof-
-  have "{x - y | x y. x\<in>s \<and> y \<in> t} =  {x + y | x y. x \<in> s \<and> y \<in> (uminus ` t)}"
-    apply auto
-    apply (rule_tac x= xa in exI, auto)
-    done
+  have "{x - y | x y. x\<in>s \<and> y \<in> t} = {x + y | x y. x \<in> s \<and> y \<in> (uminus ` t)}"
+    using diff_conv_add_uminus by force
   then show ?thesis
     using compact_sums[OF assms(1) compact_negations[OF assms(2)]] by auto
 qed
@@ -1396,11 +1362,7 @@
       using f(3)
       by auto
     then have "l \<in> ?S"
-      using \<open>l' \<in> S\<close>
-      apply auto
-      apply (rule_tac x=l' in exI)
-      apply (rule_tac x="l - l'" in exI, auto)
-      done
+      using \<open>l' \<in> S\<close> by force
   }
   moreover have "?S = (\<Union>x\<in> S. \<Union>y \<in> T. {x + y})"
     by force
@@ -1428,7 +1390,7 @@
   have "(\<Union>x\<in> S. \<Union>y \<in> uminus ` T. {x + y}) = (\<Union>x\<in> S. \<Union>y \<in> T. {x - y})"
     by force
   then show ?thesis
-    using compact_closed_sums[OF assms(1) closed_negations[OF assms(2)]] by auto
+    by (metis assms closed_negations compact_closed_sums)
 qed
 
 lemma closed_compact_differences:
@@ -1504,39 +1466,30 @@
 subsection\<^marker>\<open>tag unimportant\<close>\<open>Homeomorphisms\<close>
 
 lemma homeomorphic_scaling:
-  fixes s :: "'a::real_normed_vector set"
+  fixes S :: "'a::real_normed_vector set"
   assumes "c \<noteq> 0"
-  shows "s homeomorphic ((\<lambda>x. c *\<^sub>R x) ` s)"
+  shows "S homeomorphic ((\<lambda>x. c *\<^sub>R x) ` S)"
   unfolding homeomorphic_minimal
   apply (rule_tac x="\<lambda>x. c *\<^sub>R x" in exI)
   apply (rule_tac x="\<lambda>x. (1 / c) *\<^sub>R x" in exI)
-  using assms
-  apply (auto simp: continuous_intros)
-  done
+  using assms by (auto simp: continuous_intros)
 
 lemma homeomorphic_translation:
-  fixes s :: "'a::real_normed_vector set"
-  shows "s homeomorphic ((\<lambda>x. a + x) ` s)"
+  fixes S :: "'a::real_normed_vector set"
+  shows "S homeomorphic ((\<lambda>x. a + x) ` S)"
   unfolding homeomorphic_minimal
   apply (rule_tac x="\<lambda>x. a + x" in exI)
   apply (rule_tac x="\<lambda>x. -a + x" in exI)
-  using continuous_on_add [OF continuous_on_const continuous_on_id, of s a]
-    continuous_on_add [OF continuous_on_const continuous_on_id, of "plus a ` s" "- a"]
-  apply auto
-  done
+  by (auto simp: continuous_intros)
 
 lemma homeomorphic_affinity:
-  fixes s :: "'a::real_normed_vector set"
+  fixes S :: "'a::real_normed_vector set"
   assumes "c \<noteq> 0"
-  shows "s homeomorphic ((\<lambda>x. a + c *\<^sub>R x) ` s)"
+  shows "S homeomorphic ((\<lambda>x. a + c *\<^sub>R x) ` S)"
 proof -
-  have *: "(+) a ` (*\<^sub>R) c ` s = (\<lambda>x. a + c *\<^sub>R x) ` s" by auto
+  have *: "(+) a ` (*\<^sub>R) c ` S = (\<lambda>x. a + c *\<^sub>R x) ` S" by auto
   show ?thesis
-    using homeomorphic_trans
-    using homeomorphic_scaling[OF assms, of s]
-    using homeomorphic_translation[of "(\<lambda>x. c *\<^sub>R x) ` s" a]
-    unfolding *
-    by auto
+    by (metis "*" assms homeomorphic_scaling homeomorphic_trans homeomorphic_translation)
 qed
 
 lemma homeomorphic_balls:
@@ -1549,16 +1502,12 @@
     apply(rule_tac x="\<lambda>x. b + (e/d) *\<^sub>R (x - a)" in exI)
     apply(rule_tac x="\<lambda>x. a + (d/e) *\<^sub>R (x - b)" in exI)
     using assms
-    apply (auto intro!: continuous_intros
-      simp: dist_commute dist_norm pos_divide_less_eq mult_strict_left_mono)
-    done
+    by (auto intro!: continuous_intros simp: dist_commute dist_norm pos_divide_less_eq)
   show ?cth unfolding homeomorphic_minimal
     apply(rule_tac x="\<lambda>x. b + (e/d) *\<^sub>R (x - a)" in exI)
     apply(rule_tac x="\<lambda>x. a + (d/e) *\<^sub>R (x - b)" in exI)
     using assms
-    apply (auto intro!: continuous_intros
-      simp: dist_commute dist_norm pos_divide_le_eq mult_strict_left_mono)
-    done
+    by (auto intro!: continuous_intros simp: dist_commute dist_norm pos_divide_le_eq)
 qed
 
 lemma homeomorphic_spheres:
@@ -1569,9 +1518,7 @@
     apply(rule_tac x="\<lambda>x. b + (e/d) *\<^sub>R (x - a)" in exI)
     apply(rule_tac x="\<lambda>x. a + (d/e) *\<^sub>R (x - b)" in exI)
     using assms
-    apply (auto intro!: continuous_intros
-      simp: dist_commute dist_norm pos_divide_less_eq mult_strict_left_mono)
-    done
+    by (auto intro!: continuous_intros simp: dist_commute dist_norm pos_divide_less_eq)
 
 lemma homeomorphic_ball01_UNIV:
   "ball (0::'a::real_normed_vector) 1 homeomorphic (UNIV:: 'a set)"
@@ -1585,24 +1532,21 @@
   then show "(\<lambda>z::'a. z /\<^sub>R (1 - norm z)) ` ?B = ?U"
     by blast
   have "x \<in> range (\<lambda>z. (1 / (1 + norm z)) *\<^sub>R z)" if "norm x < 1" for x::'a
-    apply (rule_tac x="x /\<^sub>R (1 - norm x)" in image_eqI)
-    using that apply (auto simp: field_split_simps)
-    done
+    using that
+    by (rule_tac x="x /\<^sub>R (1 - norm x)" in image_eqI) (auto simp: field_split_simps)
   then show "(\<lambda>z::'a. z /\<^sub>R (1 + norm z)) ` ?U = ?B"
     by (force simp: field_split_simps dest: add_less_zeroD)
   show "continuous_on (ball 0 1) (\<lambda>z. z /\<^sub>R (1 - norm z))"
     by (rule continuous_intros | force)+
-  show "continuous_on UNIV (\<lambda>z. z /\<^sub>R (1 + norm z))"
-    apply (intro continuous_intros)
-    apply (metis le_add_same_cancel1 norm_ge_zero not_le zero_less_one)
-    done
+  have 0: "\<And>z. 1 + norm z \<noteq> 0"
+    by (metis (no_types) le_add_same_cancel1 norm_ge_zero not_one_le_zero)
+  then show "continuous_on UNIV (\<lambda>z. z /\<^sub>R (1 + norm z))"
+    by (auto intro!: continuous_intros)
   show "\<And>x. x \<in> ball 0 1 \<Longrightarrow>
          x /\<^sub>R (1 - norm x) /\<^sub>R (1 + norm (x /\<^sub>R (1 - norm x))) = x"
     by (auto simp: field_split_simps)
   show "\<And>y. y /\<^sub>R (1 + norm y) /\<^sub>R (1 - norm (y /\<^sub>R (1 + norm y))) = y"
-    apply (auto simp: field_split_simps)
-    apply (metis le_add_same_cancel1 norm_ge_zero not_le zero_less_one)
-    done
+    using 0 by (auto simp: field_split_simps)
 qed
 
 proposition homeomorphic_ball_UNIV:
@@ -1625,14 +1569,12 @@
       by (fastforce simp add: Set.image_subset_iff cong: conj_cong)
   next
     case False
-    then obtain z where z: "z \<in> S" "f z \<noteq> f x"
+    then obtain z where "z \<in> S" "f z \<noteq> f x"
       by blast
-    have finn: "finite {norm (z - f x) |z. z \<in> f ` S - {f x}}"
+    moreover have finn: "finite {norm (z - f x) |z. z \<in> f ` S - {f x}}"
       using assms by simp
-    then have *: "0 < Inf{norm(z - f x) | z. z \<in> f ` S - {f x}}"
-      apply (rule finite_imp_less_Inf)
-      using z apply force+
-      done
+    ultimately have *: "0 < Inf{norm(z - f x) | z. z \<in> f ` S - {f x}}"
+      by (force intro: finite_imp_less_Inf)
     show ?thesis
       by (force intro!: * cInf_le_finite [OF finn])
   qed
@@ -1720,24 +1662,43 @@
   { fix x assume x: "x \<in> S"
     then obtain e where "e>0" and ele: "\<And>y. \<lbrakk>y \<in> S; f y \<noteq> f x\<rbrakk> \<Longrightarrow> e \<le> norm (f y - f x)"
       using conf no [OF x] by auto
-    then have e2: "0 \<le> e / 2"
+    then have e2: "0 \<le> e/2"
       by simp
-    have "f y = f x" if "y \<in> S" and ccs: "f y \<in> connected_component_set (f ` S) (f x)" for y
-      apply (rule ccontr)
-      using connected_closed [of "connected_component_set (f ` S) (f x)"] \<open>e>0\<close>
-      apply (simp add: del: ex_simps)
-      apply (drule spec [where x="cball (f x) (e / 2)"])
-      apply (drule spec [where x="- ball(f x) e"])
-      apply (auto simp: dist_norm open_closed [symmetric] simp del: le_divide_eq_numeral1 dest!: connected_component_in)
-        apply (metis diff_self e2 ele norm_minus_commute norm_zero not_less)
-       using centre_in_cball connected_component_refl_eq e2 x apply blast
-      using ccs
-      apply (force simp: cball_def dist_norm norm_minus_commute dest: ele [OF \<open>y \<in> S\<close>])
-      done
+    define F where "F \<equiv> connected_component_set (f ` S) (f x)"
+    have False if "y \<in> S" and ccs: "f y \<in> F" and not: "f y \<noteq> f x" for y 
+    proof -
+      define C where "C \<equiv> cball (f x) (e/2)"
+      define D where "D \<equiv> - ball (f x) e"
+      have disj: "C \<inter> D = {}"
+        unfolding C_def D_def using \<open>0 < e\<close> by fastforce
+      moreover have FCD: "F \<subseteq> C \<union> D"
+      proof -
+        have "t \<in> C \<or> t \<in> D" if "t \<in> F" for t
+        proof -
+          obtain y where "y \<in> S" "t = f y"
+            using F_def \<open>t \<in> F\<close> connected_component_in by blast
+          then show ?thesis
+            by (metis C_def ComplI D_def centre_in_cball dist_norm e2 ele mem_ball norm_minus_commute not_le)
+        qed
+        then show ?thesis
+          by auto
+      qed
+      ultimately have "C \<inter> F = {} \<or> D \<inter> F = {}"
+        using connected_closed [of "F"] \<open>e>0\<close> not
+        unfolding C_def D_def
+        by (metis Elementary_Metric_Spaces.open_ball F_def closed_cball connected_connected_component inf_bot_left open_closed)
+      moreover have "C \<inter> F \<noteq> {}"
+        unfolding disjoint_iff
+        by (metis FCD ComplD image_eqI mem_Collect_eq subsetD x  D_def F_def Un_iff \<open>0 < e\<close> centre_in_ball connected_component_refl_eq)
+      moreover have "D \<inter> F \<noteq> {}"
+        unfolding disjoint_iff
+        by (metis ComplI D_def ccs dist_norm ele mem_ball norm_minus_commute not not_le that(1))
+      ultimately show ?thesis by metis
+    qed
     moreover have "connected_component_set (f ` S) (f x) \<subseteq> f ` S"
       by (auto simp: connected_component_in)
     ultimately have "connected_component_set (f ` S) (f x) = {f x}"
-      by (auto simp: x)
+      by (auto simp: x F_def)
   }
   with assms show ?thesis
     by blast
--- a/src/HOL/Data_Structures/Queue_2Lists.thy	Wed Nov 18 21:39:55 2020 +0100
+++ b/src/HOL/Data_Structures/Queue_2Lists.thy	Wed Nov 18 21:53:58 2020 +0100
@@ -3,7 +3,9 @@
 section \<open>Queue Implementation via 2 Lists\<close>
 
 theory Queue_2Lists
-imports Queue_Spec
+imports
+  Queue_Spec
+  Reverse
 begin
 
 text \<open>Definitions:\<close>
@@ -11,7 +13,7 @@
 type_synonym 'a queue = "'a list \<times> 'a list"
 
 fun norm :: "'a queue \<Rightarrow> 'a queue" where
-"norm (fs,rs) = (if fs = [] then (rev rs, []) else (fs,rs))"
+"norm (fs,rs) = (if fs = [] then (itrev rs [], []) else (fs,rs))"
 
 fun enq :: "'a \<Rightarrow> 'a queue \<Rightarrow> 'a queue" where
 "enq a (fs,rs) = norm(fs, a # rs)"
@@ -42,7 +44,7 @@
 next
   case (2 q) thus ?case by(cases q) (simp)
 next
-  case (3 q) thus ?case by(cases q) (simp)
+  case (3 q) thus ?case by(cases q) (simp add: itrev_Nil)
 next
   case (4 q) thus ?case by(cases q) (auto simp: neq_Nil_conv)
 next
@@ -58,7 +60,7 @@
 text \<open>Running times:\<close>
 
 fun T_norm :: "'a queue \<Rightarrow> nat" where
-"T_norm (fs,rs) = (if fs = [] then length rs else 0) + 1"
+"T_norm (fs,rs) = (if fs = [] then T_itrev rs [] else 0) + 1"
 
 fun T_enq :: "'a \<Rightarrow> 'a queue \<Rightarrow> nat" where
 "T_enq a (fs,rs) = T_norm(fs, a # rs) + 1"
@@ -77,10 +79,10 @@
 fun \<Phi> :: "'a queue \<Rightarrow> nat" where
 "\<Phi>(fs,rs) = length rs"
 
-lemma a_enq: "T_enq a (fs,rs) + \<Phi>(enq a (fs,rs)) - \<Phi>(fs,rs) \<le> 3"
-by(auto)
+lemma a_enq: "T_enq a (fs,rs) + \<Phi>(enq a (fs,rs)) - \<Phi>(fs,rs) \<le> 4"
+by(auto simp: T_itrev)
 
-lemma a_deq: "T_deq (fs,rs) + \<Phi>(deq (fs,rs)) - \<Phi>(fs,rs) \<le> 2"
-by(auto)
+lemma a_deq: "T_deq (fs,rs) + \<Phi>(deq (fs,rs)) - \<Phi>(fs,rs) \<le> 3"
+by(auto simp: T_itrev)
 
 end
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/HOL/Data_Structures/Reverse.thy	Wed Nov 18 21:53:58 2020 +0100
@@ -0,0 +1,36 @@
+theory Reverse
+imports Main
+begin
+
+fun T_append :: "'a list \<Rightarrow> 'a list \<Rightarrow> nat" where
+"T_append [] ys = 1" |
+"T_append (x#xs) ys = T_append xs ys + 1"
+
+fun T_rev :: "'a list \<Rightarrow> nat" where
+"T_rev [] = 1" |
+"T_rev (x#xs) = T_rev xs + T_append (rev xs) [x] + 1"
+
+lemma T_append: "T_append xs ys = length xs + 1"
+by(induction xs) auto
+
+lemma T_rev: "T_rev xs \<le> (length xs + 1)^2"
+by(induction xs) (auto simp: T_append power2_eq_square)
+
+fun itrev :: "'a list \<Rightarrow> 'a list \<Rightarrow> 'a list" where
+"itrev [] ys = ys" |
+"itrev (x#xs) ys = itrev xs (x # ys)"
+
+lemma itrev: "itrev xs ys = rev xs @ ys"
+by(induction xs arbitrary: ys) auto
+
+lemma itrev_Nil: "itrev xs [] = rev xs"
+by(simp add: itrev)
+
+fun T_itrev :: "'a list \<Rightarrow> 'a list \<Rightarrow> nat" where
+"T_itrev [] ys = 1" |
+"T_itrev (x#xs) ys = T_itrev xs (x # ys) + 1"
+
+lemma T_itrev: "T_itrev xs ys = length xs + 1"
+by(induction xs arbitrary: ys) auto
+
+end
\ No newline at end of file
--- a/src/HOL/Tools/ATP/atp_problem.ML	Wed Nov 18 21:39:55 2020 +0100
+++ b/src/HOL/Tools/ATP/atp_problem.ML	Wed Nov 18 21:53:58 2020 +0100
@@ -370,6 +370,10 @@
   | is_format_typed (DFG _) = true
   | is_format_typed _ = false
 
+fun is_format_with_fool (THF (With_FOOL, _, _)) = true
+  | is_format_with_fool (TFF (With_FOOL, _)) = true
+  | is_format_with_fool _ = false
+
 fun tptp_string_of_role Axiom = "axiom"
   | tptp_string_of_role Definition = "definition"
   | tptp_string_of_role Lemma = "lemma"
@@ -465,7 +469,7 @@
         "[" ^ commas (map of_term ts) ^ "]"
       else if is_tptp_equal s then
         space_implode (" " ^ tptp_equal ^ " ") (map of_term ts)
-        |> is_format_higher_order format ? parens
+        |> (is_format_higher_order format orelse is_format_with_fool format) ? parens
       else if s = tptp_ho_forall orelse s = tptp_ho_exists then
         (case ts of
           [AAbs (((s', ty), tm), [])] =>