--- a/src/HOL/Analysis/Bounded_Linear_Function.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Bounded_Linear_Function.thy Thu Sep 22 15:44:47 2016 +0100
@@ -391,7 +391,7 @@
also have "\<dots> = (\<Sum>i\<in>Basis. (x \<bullet> i * (f i \<bullet> b)))"
using b by (simp add: setsum.delta)
also have "\<dots> = f x \<bullet> b"
- by (subst linear_componentwise[symmetric]) (unfold_locales, rule)
+ by (metis (mono_tags, lifting) Linear_Algebra.linear_componentwise linear_axioms)
finally show "(\<Sum>j\<in>Basis. \<Sum>i\<in>Basis. (x \<bullet> i * (f i \<bullet> j)) *\<^sub>R j) \<bullet> b = f x \<bullet> b" .
qed
--- a/src/HOL/Analysis/Cartesian_Euclidean_Space.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Cartesian_Euclidean_Space.thy Thu Sep 22 15:44:47 2016 +0100
@@ -1,7 +1,7 @@
section \<open>Instantiates the finite Cartesian product of Euclidean spaces as a Euclidean space.\<close>
theory Cartesian_Euclidean_Space
-imports Finite_Cartesian_Product Derivative (* Henstock_Kurzweil_Integration *)
+imports Finite_Cartesian_Product Derivative
begin
lemma subspace_special_hyperplane: "subspace {x. x $ k = 0}"
@@ -11,6 +11,7 @@
"(if k=a then 1 else (0::'a::semiring_1)) * (if k=a then 1 else 0) = (if k=a then 1 else 0)"
by simp
+(*move up?*)
lemma setsum_UNIV_sum:
fixes g :: "'a::finite + 'b::finite \<Rightarrow> _"
shows "(\<Sum>x\<in>UNIV. g x) = (\<Sum>x\<in>UNIV. g (Inl x)) + (\<Sum>x\<in>UNIV. g (Inr x))"
@@ -33,7 +34,6 @@
qed simp
qed simp
-
subsection\<open>Basic componentwise operations on vectors.\<close>
instantiation vec :: (times, finite) times
@@ -598,7 +598,7 @@
lemma basis_expansion: "setsum (\<lambda>i. (x$i) *s axis i 1) UNIV = (x::('a::ring_1) ^'n)"
by (auto simp add: axis_def vec_eq_iff if_distrib setsum.If_cases cong del: if_weak_cong)
-lemma linear_componentwise:
+lemma linear_componentwise_expansion:
fixes f:: "real ^'m \<Rightarrow> real ^ _"
assumes lf: "linear f"
shows "(f x)$j = setsum (\<lambda>i. (x$i) * (f (axis i 1)$j)) (UNIV :: 'm set)" (is "?lhs = ?rhs")
@@ -636,9 +636,7 @@
assumes lf: "linear f"
shows "matrix f *v x = f (x::real ^ 'n)"
apply (simp add: matrix_def matrix_vector_mult_def vec_eq_iff mult.commute)
- apply clarify
- apply (rule linear_componentwise[OF lf, symmetric])
- done
+ by (simp add: linear_componentwise_expansion lf)
lemma matrix_vector_mul: "linear f ==> f = (\<lambda>x. matrix f *v (x::real ^ 'n))"
by (simp add: ext matrix_works)
--- a/src/HOL/Analysis/Cauchy_Integral_Theorem.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Cauchy_Integral_Theorem.thy Thu Sep 22 15:44:47 2016 +0100
@@ -2163,7 +2163,7 @@
{ fix x y z n
assume At: "At x y z n"
then have contf': "continuous_on (convex hull {x,y,z}) f"
- using contf At_def continuous_on_subset by blast
+ using contf At_def continuous_on_subset by metis
have "\<exists>x' y' z'. At x' y' z' (Suc n) \<and> convex hull {x',y',z'} \<subseteq> convex hull {x,y,z}"
using At
apply (simp add: At_def)
@@ -3213,11 +3213,6 @@
using contour_integral_nearby [OF assms, where atends=False]
unfolding linked_paths_def by simp_all
-corollary differentiable_polynomial_function:
- fixes p :: "real \<Rightarrow> 'a::euclidean_space"
- shows "polynomial_function p \<Longrightarrow> p differentiable_on s"
-by (meson has_vector_derivative_polynomial_function differentiable_at_imp_differentiable_on differentiable_def has_vector_derivative_def)
-
lemma C1_differentiable_polynomial_function:
fixes p :: "real \<Rightarrow> 'a::euclidean_space"
shows "polynomial_function p \<Longrightarrow> p C1_differentiable_on s"
@@ -3255,7 +3250,7 @@
done
then obtain p' where p': "polynomial_function p'"
"\<And>x. (p has_vector_derivative (p' x)) (at x)"
- using has_vector_derivative_polynomial_function by force
+ by (blast intro: has_vector_derivative_polynomial_function that elim: )
then have "bounded(p' ` {0..1})"
using continuous_on_polymonial_function
by (force simp: intro!: compact_imp_bounded compact_continuous_image)
--- a/src/HOL/Analysis/Convex_Euclidean_Space.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Convex_Euclidean_Space.thy Thu Sep 22 15:44:47 2016 +0100
@@ -1,5 +1,5 @@
-(* Title: HOL/Analysis/Convex_Euclidean_Space.thy
- Authors: Robert Himmelmann, TU Muenchen; Bogdan Grechuk, University of Edinburgh; LCP
+(* Author: L C Paulson, University of Cambridge
+ Authors: Robert Himmelmann, TU Muenchen; Bogdan Grechuk, University of Edinburgh
*)
section \<open>Convex sets, functions and related things\<close>
@@ -219,7 +219,7 @@
from gxy have th0: "g (x - y) = 0"
by (simp add: linear_diff[OF g(1)])
have th1: "x - y \<in> span B" using x' y'
- by (metis span_sub)
+ by (metis span_diff)
have "x = y" using g0[OF th1 th0] by simp
}
then have giS: "inj_on g S" unfolding inj_on_def by blast
@@ -2267,7 +2267,7 @@
apply (rule subset_le_dim)
unfolding subset_eq
using \<open>a\<in>s\<close>
- apply (auto simp add:span_superset span_sub)
+ apply (auto simp add:span_superset span_diff)
done
also have "\<dots> < dim s + 1" by auto
also have "\<dots> \<le> card (s - {a})"
--- a/src/HOL/Analysis/Derivative.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Derivative.thy Thu Sep 22 15:44:47 2016 +0100
@@ -9,29 +9,7 @@
imports Brouwer_Fixpoint Operator_Norm Uniform_Limit Bounded_Linear_Function
begin
-lemma bounded_linear_component [intro]: "bounded_linear (\<lambda>x::'a::euclidean_space. x \<bullet> k)"
- by (rule bounded_linear_inner_left)
-
-lemma onorm_inner_left:
- assumes "bounded_linear r"
- shows "onorm (\<lambda>x. r x \<bullet> f) \<le> onorm r * norm f"
-proof (rule onorm_bound)
- fix x
- have "norm (r x \<bullet> f) \<le> norm (r x) * norm f"
- by (simp add: Cauchy_Schwarz_ineq2)
- also have "\<dots> \<le> onorm r * norm x * norm f"
- by (intro mult_right_mono onorm assms norm_ge_zero)
- finally show "norm (r x \<bullet> f) \<le> onorm r * norm f * norm x"
- by (simp add: ac_simps)
-qed (intro mult_nonneg_nonneg norm_ge_zero onorm_pos_le assms)
-
-lemma onorm_inner_right:
- assumes "bounded_linear r"
- shows "onorm (\<lambda>x. f \<bullet> r x) \<le> norm f * onorm r"
- apply (subst inner_commute)
- apply (rule onorm_inner_left[OF assms, THEN order_trans])
- apply simp
- done
+declare bounded_linear_inner_left [intro]
declare has_derivative_bounded_linear[dest]
--- a/src/HOL/Analysis/Euclidean_Space.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Euclidean_Space.thy Thu Sep 22 15:44:47 2016 +0100
@@ -105,10 +105,10 @@
apply (blast intro: assms)
done
-lemma DIM_positive: "0 < DIM('a::euclidean_space)"
+lemma DIM_positive [simp]: "0 < DIM('a::euclidean_space)"
by (simp add: card_gt_0_iff)
-lemma DIM_ge_Suc0 [iff]: "Suc 0 \<le> card Basis"
+lemma DIM_ge_Suc0 [simp]: "Suc 0 \<le> card Basis"
by (meson DIM_positive Suc_leI)
--- a/src/HOL/Analysis/Henstock_Kurzweil_Integration.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Henstock_Kurzweil_Integration.thy Thu Sep 22 15:44:47 2016 +0100
@@ -2902,7 +2902,7 @@
fixes f :: "'n::euclidean_space \<Rightarrow> 'm::euclidean_space"
assumes "f integrable_on s"
shows "integral s (\<lambda>x. f x \<bullet> k) = integral s f \<bullet> k"
- unfolding integral_linear[OF assms(1) bounded_linear_component,unfolded o_def] ..
+ unfolding integral_linear[OF assms(1) bounded_linear_inner_left,unfolded o_def] ..
lemma has_integral_setsum:
assumes "finite t"
@@ -3090,7 +3090,7 @@
shows "(f has_integral y) A \<longleftrightarrow> (\<forall>b\<in>Basis. ((\<lambda>x. f x \<bullet> b) has_integral (y \<bullet> b)) A)"
proof safe
fix b :: 'b assume "(f has_integral y) A"
- from has_integral_linear[OF this(1) bounded_linear_component, of b]
+ from has_integral_linear[OF this(1) bounded_linear_inner_left, of b]
show "((\<lambda>x. f x \<bullet> b) has_integral (y \<bullet> b)) A" by (simp add: o_def)
next
assume "(\<forall>b\<in>Basis. ((\<lambda>x. f x \<bullet> b) has_integral (y \<bullet> b)) A)"
@@ -3148,7 +3148,7 @@
lemma integrable_component:
"f integrable_on A \<Longrightarrow> (\<lambda>x. f x \<bullet> (y :: 'b :: euclidean_space)) integrable_on A"
- by (drule integrable_linear[OF _ bounded_linear_component[of y]]) (simp add: o_def)
+ by (drule integrable_linear[OF _ bounded_linear_inner_left[of y]]) (simp add: o_def)
--- a/src/HOL/Analysis/L2_Norm.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/L2_Norm.thy Thu Sep 22 15:44:47 2016 +0100
@@ -165,12 +165,7 @@
done
lemma member_le_setL2: "\<lbrakk>finite A; i \<in> A\<rbrakk> \<Longrightarrow> f i \<le> setL2 f A"
- apply (rule_tac s="insert i (A - {i})" and t="A" in subst)
- apply fast
- apply (subst setL2_insert)
- apply simp
- apply simp
- apply simp
- done
+ unfolding setL2_def
+ by (auto intro!: member_le_setsum real_le_rsqrt)
end
--- a/src/HOL/Analysis/Linear_Algebra.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Linear_Algebra.thy Thu Sep 22 15:44:47 2016 +0100
@@ -457,7 +457,7 @@
lemma span_neg: "x \<in> span S \<Longrightarrow> - x \<in> span S"
by (metis subspace_neg subspace_span)
-lemma span_sub: "x \<in> span S \<Longrightarrow> y \<in> span S \<Longrightarrow> x - y \<in> span S"
+lemma span_diff: "x \<in> span S \<Longrightarrow> y \<in> span S \<Longrightarrow> x - y \<in> span S"
by (metis subspace_span subspace_diff)
lemma (in real_vector) span_setsum: "(\<And>x. x \<in> A \<Longrightarrow> f x \<in> span S) \<Longrightarrow> setsum f A \<in> span S"
@@ -2615,7 +2615,7 @@
from gxy have th0: "g (x - y) = 0"
by (simp add: linear_diff[OF g(1)])
have th1: "x - y \<in> span B"
- using x' y' by (metis span_sub)
+ using x' y' by (metis span_diff)
have "x = y"
using g0[OF th1 th0] by simp
}
--- a/src/HOL/Analysis/Topology_Euclidean_Space.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Topology_Euclidean_Space.thy Thu Sep 22 15:44:47 2016 +0100
@@ -1,4 +1,4 @@
-(* title: HOL/Library/Topology_Euclidian_Space.thy
+(* Author: L C Paulson, University of Cambridge
Author: Amine Chaieb, University of Cambridge
Author: Robert Himmelmann, TU Muenchen
Author: Brian Huffman, Portland State University
@@ -4040,6 +4040,11 @@
by auto
qed
+corollary infinite_openin:
+ fixes S :: "'a :: t1_space set"
+ shows "\<lbrakk>openin (subtopology euclidean U) S; x \<in> S; x islimpt U\<rbrakk> \<Longrightarrow> infinite S"
+ by (clarsimp simp add: openin_open islimpt_eq_acc_point inf_commute)
+
lemma islimpt_range_imp_convergent_subsequence:
fixes l :: "'a :: {t1_space, first_countable_topology}"
assumes l: "l islimpt (range f)"
@@ -6906,7 +6911,7 @@
show "\<exists>e>0. \<forall>y. dist y (f x) < e \<longrightarrow> y \<in> f ` A"
proof (intro exI conjI)
show "\<delta> > 0"
- using \<open>e > 0\<close> \<open>B > 0\<close> by (simp add: \<delta>_def divide_simps) (simp add: mult_less_0_iff)
+ using \<open>e > 0\<close> \<open>B > 0\<close> by (simp add: \<delta>_def divide_simps)
have "y \<in> f ` A" if "dist y (f x) * (B * real DIM('b)) < e" for y
proof -
define u where "u \<equiv> y - f x"
@@ -9712,6 +9717,126 @@
apply (simp add: convergent_imp_bounded)
by (simp add: closed_limpt islimpt_insert sequence_unique_limpt)
+
+subsection\<open>Componentwise limits and continuity\<close>
+
+text\<open>But is the premise really necessary? Need to generalise @{thm euclidean_dist_l2}\<close>
+lemma Euclidean_dist_upper: "i \<in> Basis \<Longrightarrow> dist (x \<bullet> i) (y \<bullet> i) \<le> dist x y"
+ by (metis (no_types) member_le_setL2 euclidean_dist_l2 finite_Basis)
+
+text\<open>But is the premise @{term \<open>i \<in> Basis\<close>} really necessary?\<close>
+lemma open_preimage_inner:
+ assumes "open S" "i \<in> Basis"
+ shows "open {x. x \<bullet> i \<in> S}"
+proof (rule openI, simp)
+ fix x
+ assume x: "x \<bullet> i \<in> S"
+ with assms obtain e where "0 < e" and e: "ball (x \<bullet> i) e \<subseteq> S"
+ by (auto simp: open_contains_ball_eq)
+ have "\<exists>e>0. ball (y \<bullet> i) e \<subseteq> S" if dxy: "dist x y < e / 2" for y
+ proof (intro exI conjI)
+ have "dist (x \<bullet> i) (y \<bullet> i) < e / 2"
+ by (meson \<open>i \<in> Basis\<close> dual_order.trans Euclidean_dist_upper not_le that)
+ then have "dist (x \<bullet> i) z < e" if "dist (y \<bullet> i) z < e / 2" for z
+ by (metis dist_commute dist_triangle_half_l that)
+ then have "ball (y \<bullet> i) (e / 2) \<subseteq> ball (x \<bullet> i) e"
+ using mem_ball by blast
+ with e show "ball (y \<bullet> i) (e / 2) \<subseteq> S"
+ by (metis order_trans)
+ qed (simp add: \<open>0 < e\<close>)
+ then show "\<exists>e>0. ball x e \<subseteq> {s. s \<bullet> i \<in> S}"
+ by (metis (no_types, lifting) \<open>0 < e\<close> \<open>open S\<close> half_gt_zero_iff mem_Collect_eq mem_ball open_contains_ball_eq subsetI)
+qed
+
+proposition tendsto_componentwise_iff:
+ fixes f :: "_ \<Rightarrow> 'b::euclidean_space"
+ shows "(f \<longlongrightarrow> l) F \<longleftrightarrow> (\<forall>i \<in> Basis. ((\<lambda>x. (f x \<bullet> i)) \<longlongrightarrow> (l \<bullet> i)) F)"
+ (is "?lhs = ?rhs")
+proof
+ assume ?lhs
+ then show ?rhs
+ unfolding tendsto_def
+ apply clarify
+ apply (drule_tac x="{s. s \<bullet> i \<in> S}" in spec)
+ apply (auto simp: open_preimage_inner)
+ done
+next
+ assume R: ?rhs
+ then have "\<And>e. e > 0 \<Longrightarrow> \<forall>i\<in>Basis. \<forall>\<^sub>F x in F. dist (f x \<bullet> i) (l \<bullet> i) < e"
+ unfolding tendsto_iff by blast
+ then have R': "\<And>e. e > 0 \<Longrightarrow> \<forall>\<^sub>F x in F. \<forall>i\<in>Basis. dist (f x \<bullet> i) (l \<bullet> i) < e"
+ by (simp add: eventually_ball_finite_distrib [symmetric])
+ show ?lhs
+ unfolding tendsto_iff
+ proof clarify
+ fix e::real
+ assume "0 < e"
+ have *: "setL2 (\<lambda>i. dist (f x \<bullet> i) (l \<bullet> i)) Basis < e"
+ if "\<forall>i\<in>Basis. dist (f x \<bullet> i) (l \<bullet> i) < e / real DIM('b)" for x
+ proof -
+ have "setL2 (\<lambda>i. dist (f x \<bullet> i) (l \<bullet> i)) Basis \<le> setsum (\<lambda>i. dist (f x \<bullet> i) (l \<bullet> i)) Basis"
+ by (simp add: setL2_le_setsum)
+ also have "... < DIM('b) * (e / real DIM('b))"
+ apply (rule setsum_bounded_above_strict)
+ using that by auto
+ also have "... = e"
+ by (simp add: field_simps)
+ finally show "setL2 (\<lambda>i. dist (f x \<bullet> i) (l \<bullet> i)) Basis < e" .
+ qed
+ have "\<forall>\<^sub>F x in F. \<forall>i\<in>Basis. dist (f x \<bullet> i) (l \<bullet> i) < e / DIM('b)"
+ apply (rule R')
+ using \<open>0 < e\<close> by simp
+ then show "\<forall>\<^sub>F x in F. dist (f x) l < e"
+ apply (rule eventually_mono)
+ apply (subst euclidean_dist_l2)
+ using * by blast
+ qed
+qed
+
+
+corollary continuous_componentwise:
+ "continuous F f \<longleftrightarrow> (\<forall>i \<in> Basis. continuous F (\<lambda>x. (f x \<bullet> i)))"
+by (simp add: continuous_def tendsto_componentwise_iff [symmetric])
+
+corollary continuous_on_componentwise:
+ fixes S :: "'a :: t2_space set"
+ shows "continuous_on S f \<longleftrightarrow> (\<forall>i \<in> Basis. continuous_on S (\<lambda>x. (f x \<bullet> i)))"
+ apply (simp add: continuous_on_eq_continuous_within)
+ using continuous_componentwise by blast
+
+lemma linear_componentwise_iff:
+ "(linear f') \<longleftrightarrow> (\<forall>i\<in>Basis. linear (\<lambda>x. f' x \<bullet> i))"
+ apply (auto simp: linear_iff inner_left_distrib)
+ apply (metis inner_left_distrib euclidean_eq_iff)
+ by (metis euclidean_eqI inner_scaleR_left)
+
+lemma bounded_linear_componentwise_iff:
+ "(bounded_linear f') \<longleftrightarrow> (\<forall>i\<in>Basis. bounded_linear (\<lambda>x. f' x \<bullet> i))"
+ (is "?lhs = ?rhs")
+proof
+ assume ?lhs then show ?rhs
+ by (simp add: bounded_linear_inner_left_comp)
+next
+ assume ?rhs
+ then have "(\<forall>i\<in>Basis. \<exists>K. \<forall>x. \<bar>f' x \<bullet> i\<bar> \<le> norm x * K)" "linear f'"
+ by (auto simp: bounded_linear_def bounded_linear_axioms_def linear_componentwise_iff [symmetric] ball_conj_distrib)
+ then obtain F where F: "\<And>i x. i \<in> Basis \<Longrightarrow> \<bar>f' x \<bullet> i\<bar> \<le> norm x * F i"
+ by metis
+ have "norm (f' x) \<le> norm x * setsum F Basis" for x
+ proof -
+ have "norm (f' x) \<le> (\<Sum>i\<in>Basis. \<bar>f' x \<bullet> i\<bar>)"
+ by (rule norm_le_l1)
+ also have "... \<le> (\<Sum>i\<in>Basis. norm x * F i)"
+ by (metis F setsum_mono)
+ also have "... = norm x * setsum F Basis"
+ by (simp add: setsum_distrib_left)
+ finally show ?thesis .
+ qed
+ then show ?lhs
+ by (force simp: bounded_linear_def bounded_linear_axioms_def \<open>linear f'\<close>)
+qed
+
+
no_notation
eucl_less (infix "<e" 50)
--- a/src/HOL/Analysis/Weierstrass_Theorems.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Analysis/Weierstrass_Theorems.thy Thu Sep 22 15:44:47 2016 +0100
@@ -3,7 +3,7 @@
text\<open>By L C Paulson (2015)\<close>
theory Weierstrass_Theorems
-imports Uniform_Limit Path_Connected
+imports Uniform_Limit Path_Connected Derivative
begin
subsection \<open>Bernstein polynomials\<close>
@@ -171,13 +171,13 @@
DOI: 10.2307/2043993 http://www.jstor.org/stable/2043993\<close>
locale function_ring_on =
- fixes R :: "('a::t2_space \<Rightarrow> real) set" and s :: "'a set"
- assumes compact: "compact s"
- assumes continuous: "f \<in> R \<Longrightarrow> continuous_on s f"
+ fixes R :: "('a::t2_space \<Rightarrow> real) set" and S :: "'a set"
+ assumes compact: "compact S"
+ assumes continuous: "f \<in> R \<Longrightarrow> continuous_on S f"
assumes add: "f \<in> R \<Longrightarrow> g \<in> R \<Longrightarrow> (\<lambda>x. f x + g x) \<in> R"
assumes mult: "f \<in> R \<Longrightarrow> g \<in> R \<Longrightarrow> (\<lambda>x. f x * g x) \<in> R"
assumes const: "(\<lambda>_. c) \<in> R"
- assumes separable: "x \<in> s \<Longrightarrow> y \<in> s \<Longrightarrow> x \<noteq> y \<Longrightarrow> \<exists>f\<in>R. f x \<noteq> f y"
+ assumes separable: "x \<in> S \<Longrightarrow> y \<in> S \<Longrightarrow> x \<noteq> y \<Longrightarrow> \<exists>f\<in>R. f x \<noteq> f y"
begin
lemma minus: "f \<in> R \<Longrightarrow> (\<lambda>x. - f x) \<in> R"
@@ -196,24 +196,24 @@
by (induct I rule: finite_induct; simp add: const mult)
definition normf :: "('a::t2_space \<Rightarrow> real) \<Rightarrow> real"
- where "normf f \<equiv> SUP x:s. \<bar>f x\<bar>"
+ where "normf f \<equiv> SUP x:S. \<bar>f x\<bar>"
- lemma normf_upper: "\<lbrakk>continuous_on s f; x \<in> s\<rbrakk> \<Longrightarrow> \<bar>f x\<bar> \<le> normf f"
+ lemma normf_upper: "\<lbrakk>continuous_on S f; x \<in> S\<rbrakk> \<Longrightarrow> \<bar>f x\<bar> \<le> normf f"
apply (simp add: normf_def)
apply (rule cSUP_upper, assumption)
by (simp add: bounded_imp_bdd_above compact compact_continuous_image compact_imp_bounded continuous_on_rabs)
- lemma normf_least: "s \<noteq> {} \<Longrightarrow> (\<And>x. x \<in> s \<Longrightarrow> \<bar>f x\<bar> \<le> M) \<Longrightarrow> normf f \<le> M"
+ lemma normf_least: "S \<noteq> {} \<Longrightarrow> (\<And>x. x \<in> S \<Longrightarrow> \<bar>f x\<bar> \<le> M) \<Longrightarrow> normf f \<le> M"
by (simp add: normf_def cSUP_least)
end
lemma (in function_ring_on) one:
- assumes U: "open U" and t0: "t0 \<in> s" "t0 \<in> U" and t1: "t1 \<in> s-U"
- shows "\<exists>V. open V \<and> t0 \<in> V \<and> s \<inter> V \<subseteq> U \<and>
- (\<forall>e>0. \<exists>f \<in> R. f ` s \<subseteq> {0..1} \<and> (\<forall>t \<in> s \<inter> V. f t < e) \<and> (\<forall>t \<in> s - U. f t > 1 - e))"
+ assumes U: "open U" and t0: "t0 \<in> S" "t0 \<in> U" and t1: "t1 \<in> S-U"
+ shows "\<exists>V. open V \<and> t0 \<in> V \<and> S \<inter> V \<subseteq> U \<and>
+ (\<forall>e>0. \<exists>f \<in> R. f ` S \<subseteq> {0..1} \<and> (\<forall>t \<in> S \<inter> V. f t < e) \<and> (\<forall>t \<in> S - U. f t > 1 - e))"
proof -
- have "\<exists>pt \<in> R. pt t0 = 0 \<and> pt t > 0 \<and> pt ` s \<subseteq> {0..1}" if t: "t \<in> s - U" for t
+ have "\<exists>pt \<in> R. pt t0 = 0 \<and> pt t > 0 \<and> pt ` S \<subseteq> {0..1}" if t: "t \<in> S - U" for t
proof -
have "t \<noteq> t0" using t t0 by auto
then obtain g where g: "g \<in> R" "g t \<noteq> g t0"
@@ -239,28 +239,28 @@
by (simp add: p_def h_def)
moreover have "p t > 0"
using nfp ht2 by (simp add: p_def)
- moreover have "\<And>x. x \<in> s \<Longrightarrow> p x \<in> {0..1}"
+ moreover have "\<And>x. x \<in> S \<Longrightarrow> p x \<in> {0..1}"
using nfp normf_upper [OF continuous [OF hsq] ] by (auto simp: p_def)
- ultimately show "\<exists>pt \<in> R. pt t0 = 0 \<and> pt t > 0 \<and> pt ` s \<subseteq> {0..1}"
+ ultimately show "\<exists>pt \<in> R. pt t0 = 0 \<and> pt t > 0 \<and> pt ` S \<subseteq> {0..1}"
by auto
qed
- then obtain pf where pf: "\<And>t. t \<in> s-U \<Longrightarrow> pf t \<in> R \<and> pf t t0 = 0 \<and> pf t t > 0"
- and pf01: "\<And>t. t \<in> s-U \<Longrightarrow> pf t ` s \<subseteq> {0..1}"
+ then obtain pf where pf: "\<And>t. t \<in> S-U \<Longrightarrow> pf t \<in> R \<and> pf t t0 = 0 \<and> pf t t > 0"
+ and pf01: "\<And>t. t \<in> S-U \<Longrightarrow> pf t ` S \<subseteq> {0..1}"
by metis
- have com_sU: "compact (s-U)"
+ have com_sU: "compact (S-U)"
using compact closed_Int_compact U by (simp add: Diff_eq compact_Int_closed open_closed)
- have "\<And>t. t \<in> s-U \<Longrightarrow> \<exists>A. open A \<and> A \<inter> s = {x\<in>s. 0 < pf t x}"
+ have "\<And>t. t \<in> S-U \<Longrightarrow> \<exists>A. open A \<and> A \<inter> S = {x\<in>S. 0 < pf t x}"
apply (rule open_Collect_positive)
by (metis pf continuous)
- then obtain Uf where Uf: "\<And>t. t \<in> s-U \<Longrightarrow> open (Uf t) \<and> (Uf t) \<inter> s = {x\<in>s. 0 < pf t x}"
+ then obtain Uf where Uf: "\<And>t. t \<in> S-U \<Longrightarrow> open (Uf t) \<and> (Uf t) \<inter> S = {x\<in>S. 0 < pf t x}"
by metis
- then have open_Uf: "\<And>t. t \<in> s-U \<Longrightarrow> open (Uf t)"
+ then have open_Uf: "\<And>t. t \<in> S-U \<Longrightarrow> open (Uf t)"
by blast
- have tUft: "\<And>t. t \<in> s-U \<Longrightarrow> t \<in> Uf t"
+ have tUft: "\<And>t. t \<in> S-U \<Longrightarrow> t \<in> Uf t"
using pf Uf by blast
- then have *: "s-U \<subseteq> (\<Union>x \<in> s-U. Uf x)"
+ then have *: "S-U \<subseteq> (\<Union>x \<in> S-U. Uf x)"
by blast
- obtain subU where subU: "subU \<subseteq> s - U" "finite subU" "s - U \<subseteq> (\<Union>x \<in> subU. Uf x)"
+ obtain subU where subU: "subU \<subseteq> S - U" "finite subU" "S - U \<subseteq> (\<Union>x \<in> subU. Uf x)"
by (blast intro: that open_Uf compactE_image [OF com_sU _ *])
then have [simp]: "subU \<noteq> {}"
using t1 by auto
@@ -271,7 +271,7 @@
unfolding p_def using subU pf by (fast intro: pf const mult setsum)
have pt0 [simp]: "p t0 = 0"
using subU pf by (auto simp: p_def intro: setsum.neutral)
- have pt_pos: "p t > 0" if t: "t \<in> s-U" for t
+ have pt_pos: "p t > 0" if t: "t \<in> S-U" for t
proof -
obtain i where i: "i \<in> subU" "t \<in> Uf i" using subU t by blast
show ?thesis
@@ -282,7 +282,7 @@
apply (force elim!: subsetCE)
done
qed
- have p01: "p x \<in> {0..1}" if t: "x \<in> s" for x
+ have p01: "p x \<in> {0..1}" if t: "x \<in> S" for x
proof -
have "0 \<le> p x"
using subU cardp t
@@ -297,26 +297,26 @@
ultimately show ?thesis
by auto
qed
- have "compact (p ` (s-U))"
+ have "compact (p ` (S-U))"
by (meson Diff_subset com_sU compact_continuous_image continuous continuous_on_subset pR)
- then have "open (- (p ` (s-U)))"
+ then have "open (- (p ` (S-U)))"
by (simp add: compact_imp_closed open_Compl)
- moreover have "0 \<in> - (p ` (s-U))"
+ moreover have "0 \<in> - (p ` (S-U))"
by (metis (no_types) ComplI image_iff not_less_iff_gr_or_eq pt_pos)
- ultimately obtain delta0 where delta0: "delta0 > 0" "ball 0 delta0 \<subseteq> - (p ` (s-U))"
+ ultimately obtain delta0 where delta0: "delta0 > 0" "ball 0 delta0 \<subseteq> - (p ` (S-U))"
by (auto simp: elim!: openE)
- then have pt_delta: "\<And>x. x \<in> s-U \<Longrightarrow> p x \<ge> delta0"
+ then have pt_delta: "\<And>x. x \<in> S-U \<Longrightarrow> p x \<ge> delta0"
by (force simp: ball_def dist_norm dest: p01)
define \<delta> where "\<delta> = delta0/2"
have "delta0 \<le> 1" using delta0 p01 [of t1] t1
by (force simp: ball_def dist_norm dest: p01)
with delta0 have \<delta>01: "0 < \<delta>" "\<delta> < 1"
by (auto simp: \<delta>_def)
- have pt_\<delta>: "\<And>x. x \<in> s-U \<Longrightarrow> p x \<ge> \<delta>"
+ have pt_\<delta>: "\<And>x. x \<in> S-U \<Longrightarrow> p x \<ge> \<delta>"
using pt_delta delta0 by (force simp: \<delta>_def)
- have "\<exists>A. open A \<and> A \<inter> s = {x\<in>s. p x < \<delta>/2}"
+ have "\<exists>A. open A \<and> A \<inter> S = {x\<in>S. p x < \<delta>/2}"
by (rule open_Collect_less_Int [OF continuous [OF pR] continuous_on_const])
- then obtain V where V: "open V" "V \<inter> s = {x\<in>s. p x < \<delta>/2}"
+ then obtain V where V: "open V" "V \<inter> S = {x\<in>S. p x < \<delta>/2}"
by blast
define k where "k = nat\<lfloor>1/\<delta>\<rfloor> + 1"
have "k>0" by (simp add: k_def)
@@ -334,12 +334,12 @@
define q where [abs_def]: "q n t = (1 - p t ^ n) ^ (k^n)" for n t
have qR: "q n \<in> R" for n
by (simp add: q_def const diff power pR)
- have q01: "\<And>n t. t \<in> s \<Longrightarrow> q n t \<in> {0..1}"
+ have q01: "\<And>n t. t \<in> S \<Longrightarrow> q n t \<in> {0..1}"
using p01 by (simp add: q_def power_le_one algebra_simps)
have qt0 [simp]: "\<And>n. n>0 \<Longrightarrow> q n t0 = 1"
using t0 pf by (simp add: q_def power_0_left)
{ fix t and n::nat
- assume t: "t \<in> s \<inter> V"
+ assume t: "t \<in> S \<inter> V"
with \<open>k>0\<close> V have "k * p t < k * \<delta> / 2"
by force
then have "1 - (k * \<delta> / 2)^n \<le> 1 - (k * p t)^n"
@@ -351,7 +351,7 @@
finally have "1 - (k * \<delta> / 2) ^ n \<le> q n t" .
} note limitV = this
{ fix t and n::nat
- assume t: "t \<in> s - U"
+ assume t: "t \<in> S - U"
with \<open>k>0\<close> U have "k * \<delta> \<le> k * p t"
by (simp add: pt_\<delta>)
with k\<delta> have kpt: "1 < k * p t"
@@ -406,20 +406,20 @@
done
{ fix t and e::real
assume "e>0"
- have "t \<in> s \<inter> V \<Longrightarrow> 1 - q (NN e) t < e" "t \<in> s - U \<Longrightarrow> q (NN e) t < e"
+ have "t \<in> S \<inter> V \<Longrightarrow> 1 - q (NN e) t < e" "t \<in> S - U \<Longrightarrow> q (NN e) t < e"
proof -
- assume t: "t \<in> s \<inter> V"
+ assume t: "t \<in> S \<inter> V"
show "1 - q (NN e) t < e"
by (metis add.commute diff_le_eq not_le limitV [OF t] less_le_trans [OF NN1 [OF \<open>e>0\<close>]])
next
- assume t: "t \<in> s - U"
+ assume t: "t \<in> S - U"
show "q (NN e) t < e"
using limitNonU [OF t] less_le_trans [OF NN0 [OF \<open>e>0\<close>]] not_le by blast
qed
- } then have "\<And>e. e > 0 \<Longrightarrow> \<exists>f\<in>R. f ` s \<subseteq> {0..1} \<and> (\<forall>t \<in> s \<inter> V. f t < e) \<and> (\<forall>t \<in> s - U. 1 - e < f t)"
+ } then have "\<And>e. e > 0 \<Longrightarrow> \<exists>f\<in>R. f ` S \<subseteq> {0..1} \<and> (\<forall>t \<in> S \<inter> V. f t < e) \<and> (\<forall>t \<in> S - U. 1 - e < f t)"
using q01
by (rule_tac x="\<lambda>x. 1 - q (NN e) x" in bexI) (auto simp: algebra_simps intro: diff const qR)
- moreover have t0V: "t0 \<in> V" "s \<inter> V \<subseteq> U"
+ moreover have t0V: "t0 \<in> V" "S \<inter> V \<subseteq> U"
using pt_\<delta> t0 U V \<delta>01 by fastforce+
ultimately show ?thesis using V t0V
by blast
@@ -427,23 +427,23 @@
text\<open>Non-trivial case, with @{term A} and @{term B} both non-empty\<close>
lemma (in function_ring_on) two_special:
- assumes A: "closed A" "A \<subseteq> s" "a \<in> A"
- and B: "closed B" "B \<subseteq> s" "b \<in> B"
+ assumes A: "closed A" "A \<subseteq> S" "a \<in> A"
+ and B: "closed B" "B \<subseteq> S" "b \<in> B"
and disj: "A \<inter> B = {}"
and e: "0 < e" "e < 1"
- shows "\<exists>f \<in> R. f ` s \<subseteq> {0..1} \<and> (\<forall>x \<in> A. f x < e) \<and> (\<forall>x \<in> B. f x > 1 - e)"
+ shows "\<exists>f \<in> R. f ` S \<subseteq> {0..1} \<and> (\<forall>x \<in> A. f x < e) \<and> (\<forall>x \<in> B. f x > 1 - e)"
proof -
{ fix w
assume "w \<in> A"
- then have "open ( - B)" "b \<in> s" "w \<notin> B" "w \<in> s"
+ then have "open ( - B)" "b \<in> S" "w \<notin> B" "w \<in> S"
using assms by auto
- then have "\<exists>V. open V \<and> w \<in> V \<and> s \<inter> V \<subseteq> -B \<and>
- (\<forall>e>0. \<exists>f \<in> R. f ` s \<subseteq> {0..1} \<and> (\<forall>x \<in> s \<inter> V. f x < e) \<and> (\<forall>x \<in> s \<inter> B. f x > 1 - e))"
+ then have "\<exists>V. open V \<and> w \<in> V \<and> S \<inter> V \<subseteq> -B \<and>
+ (\<forall>e>0. \<exists>f \<in> R. f ` S \<subseteq> {0..1} \<and> (\<forall>x \<in> S \<inter> V. f x < e) \<and> (\<forall>x \<in> S \<inter> B. f x > 1 - e))"
using one [of "-B" w b] assms \<open>w \<in> A\<close> by simp
}
then obtain Vf where Vf:
- "\<And>w. w \<in> A \<Longrightarrow> open (Vf w) \<and> w \<in> Vf w \<and> s \<inter> Vf w \<subseteq> -B \<and>
- (\<forall>e>0. \<exists>f \<in> R. f ` s \<subseteq> {0..1} \<and> (\<forall>x \<in> s \<inter> Vf w. f x < e) \<and> (\<forall>x \<in> s \<inter> B. f x > 1 - e))"
+ "\<And>w. w \<in> A \<Longrightarrow> open (Vf w) \<and> w \<in> Vf w \<and> S \<inter> Vf w \<subseteq> -B \<and>
+ (\<forall>e>0. \<exists>f \<in> R. f ` S \<subseteq> {0..1} \<and> (\<forall>x \<in> S \<inter> Vf w. f x < e) \<and> (\<forall>x \<in> S \<inter> B. f x > 1 - e))"
by metis
then have open_Vf: "\<And>w. w \<in> A \<Longrightarrow> open (Vf w)"
by blast
@@ -459,17 +459,17 @@
using \<open>a \<in> A\<close> by auto
then have cardp: "card subA > 0" using subA
by (simp add: card_gt_0_iff)
- have "\<And>w. w \<in> A \<Longrightarrow> \<exists>f \<in> R. f ` s \<subseteq> {0..1} \<and> (\<forall>x \<in> s \<inter> Vf w. f x < e / card subA) \<and> (\<forall>x \<in> s \<inter> B. f x > 1 - e / card subA)"
+ have "\<And>w. w \<in> A \<Longrightarrow> \<exists>f \<in> R. f ` S \<subseteq> {0..1} \<and> (\<forall>x \<in> S \<inter> Vf w. f x < e / card subA) \<and> (\<forall>x \<in> S \<inter> B. f x > 1 - e / card subA)"
using Vf e cardp by simp
then obtain ff where ff:
- "\<And>w. w \<in> A \<Longrightarrow> ff w \<in> R \<and> ff w ` s \<subseteq> {0..1} \<and>
- (\<forall>x \<in> s \<inter> Vf w. ff w x < e / card subA) \<and> (\<forall>x \<in> s \<inter> B. ff w x > 1 - e / card subA)"
+ "\<And>w. w \<in> A \<Longrightarrow> ff w \<in> R \<and> ff w ` S \<subseteq> {0..1} \<and>
+ (\<forall>x \<in> S \<inter> Vf w. ff w x < e / card subA) \<and> (\<forall>x \<in> S \<inter> B. ff w x > 1 - e / card subA)"
by metis
define pff where [abs_def]: "pff x = (\<Prod>w \<in> subA. ff w x)" for x
have pffR: "pff \<in> R"
unfolding pff_def using subA ff by (auto simp: intro: setprod)
moreover
- have pff01: "pff x \<in> {0..1}" if t: "x \<in> s" for x
+ have pff01: "pff x \<in> {0..1}" if t: "x \<in> S" for x
proof -
have "0 \<le> pff x"
using subA cardp t
@@ -486,7 +486,7 @@
qed
moreover
{ fix v x
- assume v: "v \<in> subA" and x: "x \<in> Vf v" "x \<in> s"
+ assume v: "v \<in> subA" and x: "x \<in> Vf v" "x \<in> S"
from subA v have "pff x = ff v x * (\<Prod>w \<in> subA - {v}. ff w x)"
unfolding pff_def by (metis setprod.remove)
also have "... \<le> ff v x * 1"
@@ -509,7 +509,7 @@
moreover
{ fix x
assume x: "x \<in> B"
- then have "x \<in> s"
+ then have "x \<in> S"
using B by auto
have "1 - e \<le> (1 - e / card subA) ^ card subA"
using Bernoulli_inequality [of "-e / card subA" "card subA"] e cardp
@@ -532,11 +532,11 @@
qed
lemma (in function_ring_on) two:
- assumes A: "closed A" "A \<subseteq> s"
- and B: "closed B" "B \<subseteq> s"
+ assumes A: "closed A" "A \<subseteq> S"
+ and B: "closed B" "B \<subseteq> S"
and disj: "A \<inter> B = {}"
and e: "0 < e" "e < 1"
- shows "\<exists>f \<in> R. f ` s \<subseteq> {0..1} \<and> (\<forall>x \<in> A. f x < e) \<and> (\<forall>x \<in> B. f x > 1 - e)"
+ shows "\<exists>f \<in> R. f ` S \<subseteq> {0..1} \<and> (\<forall>x \<in> A. f x < e) \<and> (\<forall>x \<in> B. f x > 1 - e)"
proof (cases "A \<noteq> {} \<and> B \<noteq> {}")
case True then show ?thesis
apply (simp add: ex_in_conv [symmetric])
@@ -556,57 +556,57 @@
text\<open>The special case where @{term f} is non-negative and @{term"e<1/3"}\<close>
lemma (in function_ring_on) Stone_Weierstrass_special:
- assumes f: "continuous_on s f" and fpos: "\<And>x. x \<in> s \<Longrightarrow> f x \<ge> 0"
+ assumes f: "continuous_on S f" and fpos: "\<And>x. x \<in> S \<Longrightarrow> f x \<ge> 0"
and e: "0 < e" "e < 1/3"
- shows "\<exists>g \<in> R. \<forall>x\<in>s. \<bar>f x - g x\<bar> < 2*e"
+ shows "\<exists>g \<in> R. \<forall>x\<in>S. \<bar>f x - g x\<bar> < 2*e"
proof -
define n where "n = 1 + nat \<lceil>normf f / e\<rceil>"
- define A where "A j = {x \<in> s. f x \<le> (j - 1/3)*e}" for j :: nat
- define B where "B j = {x \<in> s. f x \<ge> (j + 1/3)*e}" for j :: nat
+ define A where "A j = {x \<in> S. f x \<le> (j - 1/3)*e}" for j :: nat
+ define B where "B j = {x \<in> S. f x \<ge> (j + 1/3)*e}" for j :: nat
have ngt: "(n-1) * e \<ge> normf f" "n\<ge>1"
using e
apply (simp_all add: n_def field_simps of_nat_Suc)
by (metis real_nat_ceiling_ge mult.commute not_less pos_less_divide_eq)
- then have ge_fx: "(n-1) * e \<ge> f x" if "x \<in> s" for x
+ then have ge_fx: "(n-1) * e \<ge> f x" if "x \<in> S" for x
using f normf_upper that by fastforce
{ fix j
- have A: "closed (A j)" "A j \<subseteq> s"
+ have A: "closed (A j)" "A j \<subseteq> S"
apply (simp_all add: A_def Collect_restrict)
apply (rule continuous_on_closed_Collect_le [OF f continuous_on_const])
apply (simp add: compact compact_imp_closed)
done
- have B: "closed (B j)" "B j \<subseteq> s"
+ have B: "closed (B j)" "B j \<subseteq> S"
apply (simp_all add: B_def Collect_restrict)
apply (rule continuous_on_closed_Collect_le [OF continuous_on_const f])
apply (simp add: compact compact_imp_closed)
done
have disj: "(A j) \<inter> (B j) = {}"
using e by (auto simp: A_def B_def field_simps)
- have "\<exists>f \<in> R. f ` s \<subseteq> {0..1} \<and> (\<forall>x \<in> A j. f x < e/n) \<and> (\<forall>x \<in> B j. f x > 1 - e/n)"
+ have "\<exists>f \<in> R. f ` S \<subseteq> {0..1} \<and> (\<forall>x \<in> A j. f x < e/n) \<and> (\<forall>x \<in> B j. f x > 1 - e/n)"
apply (rule two)
using e A B disj ngt
apply simp_all
done
}
- then obtain xf where xfR: "\<And>j. xf j \<in> R" and xf01: "\<And>j. xf j ` s \<subseteq> {0..1}"
+ then obtain xf where xfR: "\<And>j. xf j \<in> R" and xf01: "\<And>j. xf j ` S \<subseteq> {0..1}"
and xfA: "\<And>x j. x \<in> A j \<Longrightarrow> xf j x < e/n"
and xfB: "\<And>x j. x \<in> B j \<Longrightarrow> xf j x > 1 - e/n"
by metis
define g where [abs_def]: "g x = e * (\<Sum>i\<le>n. xf i x)" for x
have gR: "g \<in> R"
unfolding g_def by (fast intro: mult const setsum xfR)
- have gge0: "\<And>x. x \<in> s \<Longrightarrow> g x \<ge> 0"
+ have gge0: "\<And>x. x \<in> S \<Longrightarrow> g x \<ge> 0"
using e xf01 by (simp add: g_def zero_le_mult_iff image_subset_iff setsum_nonneg)
have A0: "A 0 = {}"
using fpos e by (fastforce simp: A_def)
- have An: "A n = s"
+ have An: "A n = S"
using e ngt f normf_upper by (fastforce simp: A_def field_simps of_nat_diff)
have Asub: "A j \<subseteq> A i" if "i\<ge>j" for i j
using e that apply (clarsimp simp: A_def)
apply (erule order_trans, simp)
done
{ fix t
- assume t: "t \<in> s"
+ assume t: "t \<in> S"
define j where "j = (LEAST j. t \<in> A j)"
have jn: "j \<le> n"
using t An by (simp add: Least_le j_def)
@@ -701,16 +701,16 @@
text\<open>The ``unpretentious'' formulation\<close>
lemma (in function_ring_on) Stone_Weierstrass_basic:
- assumes f: "continuous_on s f" and e: "e > 0"
- shows "\<exists>g \<in> R. \<forall>x\<in>s. \<bar>f x - g x\<bar> < e"
+ assumes f: "continuous_on S f" and e: "e > 0"
+ shows "\<exists>g \<in> R. \<forall>x\<in>S. \<bar>f x - g x\<bar> < e"
proof -
- have "\<exists>g \<in> R. \<forall>x\<in>s. \<bar>(f x + normf f) - g x\<bar> < 2 * min (e/2) (1/4)"
+ have "\<exists>g \<in> R. \<forall>x\<in>S. \<bar>(f x + normf f) - g x\<bar> < 2 * min (e/2) (1/4)"
apply (rule Stone_Weierstrass_special)
apply (rule Limits.continuous_on_add [OF f Topological_Spaces.continuous_on_const])
using normf_upper [OF f] apply force
apply (simp add: e, linarith)
done
- then obtain g where "g \<in> R" "\<forall>x\<in>s. \<bar>g x - (f x + normf f)\<bar> < e"
+ then obtain g where "g \<in> R" "\<forall>x\<in>S. \<bar>g x - (f x + normf f)\<bar> < e"
by force
then show ?thesis
apply (rule_tac x="\<lambda>x. g x - normf f" in bexI)
@@ -720,16 +720,16 @@
theorem (in function_ring_on) Stone_Weierstrass:
- assumes f: "continuous_on s f"
- shows "\<exists>F\<in>UNIV \<rightarrow> R. LIM n sequentially. F n :> uniformly_on s f"
+ assumes f: "continuous_on S f"
+ shows "\<exists>F\<in>UNIV \<rightarrow> R. LIM n sequentially. F n :> uniformly_on S f"
proof -
{ fix e::real
assume e: "0 < e"
then obtain N::nat where N: "0 < N" "0 < inverse N" "inverse N < e"
by (auto simp: real_arch_inverse [of e])
{ fix n :: nat and x :: 'a and g :: "'a \<Rightarrow> real"
- assume n: "N \<le> n" "\<forall>x\<in>s. \<bar>f x - g x\<bar> < 1 / (1 + real n)"
- assume x: "x \<in> s"
+ assume n: "N \<le> n" "\<forall>x\<in>S. \<bar>f x - g x\<bar> < 1 / (1 + real n)"
+ assume x: "x \<in> S"
have "\<not> real (Suc n) < inverse e"
using \<open>N \<le> n\<close> N using less_imp_inverse_less by force
then have "1 / (1 + real n) \<le> e"
@@ -737,13 +737,13 @@
then have "\<bar>f x - g x\<bar> < e"
using n(2) x by auto
} note * = this
- have "\<forall>\<^sub>F n in sequentially. \<forall>x\<in>s. \<bar>f x - (SOME g. g \<in> R \<and> (\<forall>x\<in>s. \<bar>f x - g x\<bar> < 1 / (1 + real n))) x\<bar> < e"
+ have "\<forall>\<^sub>F n in sequentially. \<forall>x\<in>S. \<bar>f x - (SOME g. g \<in> R \<and> (\<forall>x\<in>S. \<bar>f x - g x\<bar> < 1 / (1 + real n))) x\<bar> < e"
apply (rule eventually_sequentiallyI [of N])
apply (auto intro: someI2_bex [OF Stone_Weierstrass_basic [OF f]] *)
done
} then
show ?thesis
- apply (rule_tac x="\<lambda>n::nat. SOME g. g \<in> R \<and> (\<forall>x\<in>s. \<bar>f x - g x\<bar> < 1 / (1 + n))" in bexI)
+ apply (rule_tac x="\<lambda>n::nat. SOME g. g \<in> R \<and> (\<forall>x\<in>S. \<bar>f x - g x\<bar> < 1 / (1 + n))" in bexI)
prefer 2 apply (force intro: someI2_bex [OF Stone_Weierstrass_basic [OF f]])
unfolding uniform_limit_iff
apply (auto simp: dist_norm abs_minus_commute)
@@ -752,21 +752,21 @@
text\<open>A HOL Light formulation\<close>
corollary Stone_Weierstrass_HOL:
- fixes R :: "('a::t2_space \<Rightarrow> real) set" and s :: "'a set"
- assumes "compact s" "\<And>c. P(\<lambda>x. c::real)"
- "\<And>f. P f \<Longrightarrow> continuous_on s f"
+ fixes R :: "('a::t2_space \<Rightarrow> real) set" and S :: "'a set"
+ assumes "compact S" "\<And>c. P(\<lambda>x. c::real)"
+ "\<And>f. P f \<Longrightarrow> continuous_on S f"
"\<And>f g. P(f) \<and> P(g) \<Longrightarrow> P(\<lambda>x. f x + g x)" "\<And>f g. P(f) \<and> P(g) \<Longrightarrow> P(\<lambda>x. f x * g x)"
- "\<And>x y. x \<in> s \<and> y \<in> s \<and> ~(x = y) \<Longrightarrow> \<exists>f. P(f) \<and> ~(f x = f y)"
- "continuous_on s f"
+ "\<And>x y. x \<in> S \<and> y \<in> S \<and> ~(x = y) \<Longrightarrow> \<exists>f. P(f) \<and> ~(f x = f y)"
+ "continuous_on S f"
"0 < e"
- shows "\<exists>g. P(g) \<and> (\<forall>x \<in> s. \<bar>f x - g x\<bar> < e)"
+ shows "\<exists>g. P(g) \<and> (\<forall>x \<in> S. \<bar>f x - g x\<bar> < e)"
proof -
interpret PR: function_ring_on "Collect P"
apply unfold_locales
using assms
by auto
show ?thesis
- using PR.Stone_Weierstrass_basic [OF \<open>continuous_on s f\<close> \<open>0 < e\<close>]
+ using PR.Stone_Weierstrass_basic [OF \<open>continuous_on S f\<close> \<open>0 < e\<close>]
by blast
qed
@@ -994,7 +994,7 @@
lemma continuous_on_polymonial_function:
fixes f :: "'a::real_normed_vector \<Rightarrow> 'b::euclidean_space"
assumes "polynomial_function f"
- shows "continuous_on s f"
+ shows "continuous_on S f"
using continuous_polymonial_function [OF assms] continuous_at_imp_continuous_on
by blast
@@ -1035,8 +1035,7 @@
lemma has_vector_derivative_polynomial_function:
fixes p :: "real \<Rightarrow> 'a::euclidean_space"
assumes "polynomial_function p"
- shows "\<exists>p'. polynomial_function p' \<and>
- (\<forall>x. (p has_vector_derivative (p' x)) (at x))"
+ obtains p' where "polynomial_function p'" "\<And>x. (p has_vector_derivative (p' x)) (at x)"
proof -
{ fix b :: 'a
assume "b \<in> Basis"
@@ -1057,9 +1056,10 @@
"\<And>b x. b \<in> Basis \<Longrightarrow> ((\<lambda>u. (p u \<bullet> b) *\<^sub>R b) has_vector_derivative qf b x) (at x)"
by metis
show ?thesis
+ apply (rule_tac p'="\<lambda>x. \<Sum>b\<in>Basis. qf b x" in that)
+ apply (force intro: qf)
apply (subst euclidean_representation_setsum_fun [of p, symmetric])
- apply (rule_tac x="\<lambda>x. \<Sum>b\<in>Basis. qf b x" in exI)
- apply (auto intro: has_vector_derivative_setsum qf)
+ apply (auto intro: has_vector_derivative_setsum qf)
done
qed
@@ -1081,8 +1081,8 @@
lemma Stone_Weierstrass_real_polynomial_function:
fixes f :: "'a::euclidean_space \<Rightarrow> real"
- assumes "compact s" "continuous_on s f" "0 < e"
- shows "\<exists>g. real_polynomial_function g \<and> (\<forall>x \<in> s. \<bar>f x - g x\<bar> < e)"
+ assumes "compact S" "continuous_on S f" "0 < e"
+ obtains g where "real_polynomial_function g" "\<And>x. x \<in> S \<Longrightarrow> \<bar>f x - g x\<bar> < e"
proof -
interpret PR: function_ring_on "Collect real_polynomial_function"
apply unfold_locales
@@ -1090,27 +1090,27 @@
apply (auto intro: real_polynomial_function_separable)
done
show ?thesis
- using PR.Stone_Weierstrass_basic [OF \<open>continuous_on s f\<close> \<open>0 < e\<close>]
+ using PR.Stone_Weierstrass_basic [OF \<open>continuous_on S f\<close> \<open>0 < e\<close>] that
by blast
qed
lemma Stone_Weierstrass_polynomial_function:
fixes f :: "'a::euclidean_space \<Rightarrow> 'b::euclidean_space"
- assumes s: "compact s"
- and f: "continuous_on s f"
+ assumes S: "compact S"
+ and f: "continuous_on S f"
and e: "0 < e"
- shows "\<exists>g. polynomial_function g \<and> (\<forall>x \<in> s. norm(f x - g x) < e)"
+ shows "\<exists>g. polynomial_function g \<and> (\<forall>x \<in> S. norm(f x - g x) < e)"
proof -
{ fix b :: 'b
assume "b \<in> Basis"
- have "\<exists>p. real_polynomial_function p \<and> (\<forall>x \<in> s. \<bar>f x \<bullet> b - p x\<bar> < e / DIM('b))"
- apply (rule exE [OF Stone_Weierstrass_real_polynomial_function [OF s _, of "\<lambda>x. f x \<bullet> b" "e / card Basis"]])
+ have "\<exists>p. real_polynomial_function p \<and> (\<forall>x \<in> S. \<bar>f x \<bullet> b - p x\<bar> < e / DIM('b))"
+ apply (rule exE [OF Stone_Weierstrass_real_polynomial_function [OF S _, of "\<lambda>x. f x \<bullet> b" "e / card Basis"]])
using e f
apply (auto simp: Euclidean_Space.DIM_positive intro: continuous_intros)
done
}
then obtain pf where pf:
- "\<And>b. b \<in> Basis \<Longrightarrow> real_polynomial_function (pf b) \<and> (\<forall>x \<in> s. \<bar>f x \<bullet> b - pf b x\<bar> < e / DIM('b))"
+ "\<And>b. b \<in> Basis \<Longrightarrow> real_polynomial_function (pf b) \<and> (\<forall>x \<in> S. \<bar>f x \<bullet> b - pf b x\<bar> < e / DIM('b))"
apply (rule bchoice [rule_format, THEN exE])
apply assumption
apply (force simp add: intro: that)
@@ -1120,12 +1120,12 @@
by (simp add: polynomial_function_setsum polynomial_function_mult real_polynomial_function_eq)
moreover
{ fix x
- assume "x \<in> s"
+ assume "x \<in> S"
have "norm (\<Sum>b\<in>Basis. (f x \<bullet> b) *\<^sub>R b - pf b x *\<^sub>R b) \<le> (\<Sum>b\<in>Basis. norm ((f x \<bullet> b) *\<^sub>R b - pf b x *\<^sub>R b))"
by (rule norm_setsum)
also have "... < of_nat DIM('b) * (e / DIM('b))"
apply (rule setsum_bounded_above_strict)
- apply (simp add: Real_Vector_Spaces.scaleR_diff_left [symmetric] pf \<open>x \<in> s\<close>)
+ apply (simp add: Real_Vector_Spaces.scaleR_diff_left [symmetric] pf \<open>x \<in> S\<close>)
apply (rule DIM_positive)
done
also have "... = e"
@@ -1178,31 +1178,31 @@
qed
lemma connected_open_polynomial_connected:
- fixes s :: "'a::euclidean_space set"
- assumes s: "open s" "connected s"
- and "x \<in> s" "y \<in> s"
- shows "\<exists>g. polynomial_function g \<and> path_image g \<subseteq> s \<and>
+ fixes S :: "'a::euclidean_space set"
+ assumes S: "open S" "connected S"
+ and "x \<in> S" "y \<in> S"
+ shows "\<exists>g. polynomial_function g \<and> path_image g \<subseteq> S \<and>
pathstart g = x \<and> pathfinish g = y"
proof -
- have "path_connected s" using assms
+ have "path_connected S" using assms
by (simp add: connected_open_path_connected)
- with \<open>x \<in> s\<close> \<open>y \<in> s\<close> obtain p where p: "path p" "path_image p \<subseteq> s" "pathstart p = x" "pathfinish p = y"
+ with \<open>x \<in> S\<close> \<open>y \<in> S\<close> obtain p where p: "path p" "path_image p \<subseteq> S" "pathstart p = x" "pathfinish p = y"
by (force simp: path_connected_def)
- have "\<exists>e. 0 < e \<and> (\<forall>x \<in> path_image p. ball x e \<subseteq> s)"
- proof (cases "s = UNIV")
+ have "\<exists>e. 0 < e \<and> (\<forall>x \<in> path_image p. ball x e \<subseteq> S)"
+ proof (cases "S = UNIV")
case True then show ?thesis
by (simp add: gt_ex)
next
case False
- then have "- s \<noteq> {}" by blast
+ then have "- S \<noteq> {}" by blast
then show ?thesis
- apply (rule_tac x="setdist (path_image p) (-s)" in exI)
- using s p
+ apply (rule_tac x="setdist (path_image p) (-S)" in exI)
+ using S p
apply (simp add: setdist_gt_0_compact_closed compact_path_image open_closed)
- using setdist_le_dist [of _ "path_image p" _ "-s"]
+ using setdist_le_dist [of _ "path_image p" _ "-S"]
by fastforce
qed
- then obtain e where "0 < e"and eb: "\<And>x. x \<in> path_image p \<Longrightarrow> ball x e \<subseteq> s"
+ then obtain e where "0 < e"and eb: "\<And>x. x \<in> path_image p \<Longrightarrow> ball x e \<subseteq> S"
by auto
show ?thesis
using path_approx_polynomial_function [OF \<open>path p\<close> \<open>0 < e\<close>]
@@ -1213,6 +1213,179 @@
done
qed
+lemma has_derivative_componentwise_within:
+ "(f has_derivative f') (at a within S) \<longleftrightarrow>
+ (\<forall>i \<in> Basis. ((\<lambda>x. f x \<bullet> i) has_derivative (\<lambda>x. f' x \<bullet> i)) (at a within S))"
+ apply (simp add: has_derivative_within)
+ apply (subst tendsto_componentwise_iff)
+ apply (simp add: bounded_linear_componentwise_iff [symmetric] ball_conj_distrib)
+ apply (simp add: algebra_simps)
+ done
+
+lemma differentiable_componentwise_within:
+ "f differentiable (at a within S) \<longleftrightarrow>
+ (\<forall>i \<in> Basis. (\<lambda>x. f x \<bullet> i) differentiable at a within S)"
+proof -
+ { assume "\<forall>i\<in>Basis. \<exists>D. ((\<lambda>x. f x \<bullet> i) has_derivative D) (at a within S)"
+ then obtain f' where f':
+ "\<And>i. i \<in> Basis \<Longrightarrow> ((\<lambda>x. f x \<bullet> i) has_derivative f' i) (at a within S)"
+ by metis
+ have eq: "(\<lambda>x. (\<Sum>j\<in>Basis. f' j x *\<^sub>R j) \<bullet> i) = f' i" if "i \<in> Basis" for i
+ using that by (simp add: inner_add_left inner_add_right)
+ have "\<exists>D. \<forall>i\<in>Basis. ((\<lambda>x. f x \<bullet> i) has_derivative (\<lambda>x. D x \<bullet> i)) (at a within S)"
+ apply (rule_tac x="\<lambda>x::'a. (\<Sum>j\<in>Basis. f' j x *\<^sub>R j) :: 'b" in exI)
+ apply (simp add: eq f')
+ done
+ }
+ then show ?thesis
+ apply (simp add: differentiable_def)
+ using has_derivative_componentwise_within
+ by blast
+qed
+
+lemma polynomial_function_inner [intro]:
+ fixes i :: "'a::euclidean_space"
+ shows "polynomial_function g \<Longrightarrow> polynomial_function (\<lambda>x. g x \<bullet> i)"
+ apply (subst euclidean_representation [where x=i, symmetric])
+ apply (force simp: inner_setsum_right polynomial_function_iff_Basis_inner polynomial_function_setsum)
+ done
+
+text\<open> Differentiability of real and vector polynomial functions.\<close>
+
+lemma differentiable_at_real_polynomial_function:
+ "real_polynomial_function f \<Longrightarrow> f differentiable (at a within S)"
+ by (induction f rule: real_polynomial_function.induct)
+ (simp_all add: bounded_linear_imp_differentiable)
+
+lemma differentiable_on_real_polynomial_function:
+ "real_polynomial_function p \<Longrightarrow> p differentiable_on S"
+by (simp add: differentiable_at_imp_differentiable_on differentiable_at_real_polynomial_function)
+
+lemma differentiable_at_polynomial_function:
+ fixes f :: "_ \<Rightarrow> 'a::euclidean_space"
+ shows "polynomial_function f \<Longrightarrow> f differentiable (at a within S)"
+ by (metis differentiable_at_real_polynomial_function polynomial_function_iff_Basis_inner differentiable_componentwise_within)
+
+lemma differentiable_on_polynomial_function:
+ fixes f :: "_ \<Rightarrow> 'a::euclidean_space"
+ shows "polynomial_function f \<Longrightarrow> f differentiable_on S"
+by (simp add: differentiable_at_polynomial_function differentiable_on_def)
+
+lemma vector_eq_dot_span:
+ assumes "x \<in> span B" "y \<in> span B" and i: "\<And>i. i \<in> B \<Longrightarrow> i \<bullet> x = i \<bullet> y"
+ shows "x = y"
+proof -
+ have "\<And>i. i \<in> B \<Longrightarrow> orthogonal (x - y) i"
+ by (simp add: i inner_commute inner_diff_right orthogonal_def)
+ moreover have "x - y \<in> span B"
+ by (simp add: assms span_diff)
+ ultimately have "x - y = 0"
+ using orthogonal_to_span orthogonal_self by blast
+ then show ?thesis by simp
+qed
+
+lemma orthonormal_basis_expand:
+ assumes B: "pairwise orthogonal B"
+ and 1: "\<And>i. i \<in> B \<Longrightarrow> norm i = 1"
+ and "x \<in> span B"
+ and "finite B"
+ shows "(\<Sum>i\<in>B. (x \<bullet> i) *\<^sub>R i) = x"
+proof (rule vector_eq_dot_span [OF _ \<open>x \<in> span B\<close>])
+ show "(\<Sum>i\<in>B. (x \<bullet> i) *\<^sub>R i) \<in> span B"
+ by (simp add: span_clauses span_setsum)
+ show "i \<bullet> (\<Sum>i\<in>B. (x \<bullet> i) *\<^sub>R i) = i \<bullet> x" if "i \<in> B" for i
+ proof -
+ have [simp]: "i \<bullet> j = (if j = i then 1 else 0)" if "j \<in> B" for j
+ using B 1 that \<open>i \<in> B\<close>
+ by (force simp: norm_eq_1 orthogonal_def pairwise_def)
+ have "i \<bullet> (\<Sum>i\<in>B. (x \<bullet> i) *\<^sub>R i) = (\<Sum>j\<in>B. x \<bullet> j * (i \<bullet> j))"
+ by (simp add: inner_setsum_right)
+ also have "... = (\<Sum>j\<in>B. if j = i then x \<bullet> i else 0)"
+ by (rule setsum.cong; simp)
+ also have "... = i \<bullet> x"
+ by (simp add: \<open>finite B\<close> that inner_commute setsum.delta)
+ finally show ?thesis .
+ qed
+qed
+
+
+lemma Stone_Weierstrass_polynomial_function_subspace:
+ fixes f :: "'a::euclidean_space \<Rightarrow> 'b::euclidean_space"
+ assumes "compact S"
+ and contf: "continuous_on S f"
+ and "0 < e"
+ and "subspace T" "f ` S \<subseteq> T"
+ obtains g where "polynomial_function g" "g ` S \<subseteq> T"
+ "\<And>x. x \<in> S \<Longrightarrow> norm(f x - g x) < e"
+proof -
+ obtain B where "B \<subseteq> T" and orthB: "pairwise orthogonal B"
+ and B1: "\<And>x. x \<in> B \<Longrightarrow> norm x = 1"
+ and "independent B" and cardB: "card B = dim T"
+ and spanB: "span B = T"
+ using orthonormal_basis_subspace \<open>subspace T\<close> by metis
+ then have "finite B"
+ by (simp add: independent_imp_finite)
+ then obtain n::nat and b where "B = b ` {i. i < n}" "inj_on b {i. i < n}"
+ using finite_imp_nat_seg_image_inj_on by metis
+ with cardB have "n = card B" "dim T = n"
+ by (auto simp: card_image)
+ have fx: "(\<Sum>i\<in>B. (f x \<bullet> i) *\<^sub>R i) = f x" if "x \<in> S" for x
+ apply (rule orthonormal_basis_expand [OF orthB B1 _ \<open>finite B\<close>])
+ using \<open>f ` S \<subseteq> T\<close> spanB that by auto
+ have cont: "continuous_on S (\<lambda>x. \<Sum>i\<in>B. (f x \<bullet> i) *\<^sub>R i)"
+ by (intro continuous_intros contf)
+ obtain g where "polynomial_function g"
+ and g: "\<And>x. x \<in> S \<Longrightarrow> norm ((\<Sum>i\<in>B. (f x \<bullet> i) *\<^sub>R i) - g x) < e / (n+2)"
+ using Stone_Weierstrass_polynomial_function [OF \<open>compact S\<close> cont, of "e / real (n + 2)"] \<open>0 < e\<close>
+ by auto
+ with fx have g: "\<And>x. x \<in> S \<Longrightarrow> norm (f x - g x) < e / (n+2)"
+ by auto
+ show ?thesis
+ proof
+ show "polynomial_function (\<lambda>x. \<Sum>i\<in>B. (g x \<bullet> i) *\<^sub>R i)"
+ apply (rule polynomial_function_setsum)
+ apply (simp add: \<open>finite B\<close>)
+ using \<open>polynomial_function g\<close> by auto
+ show "(\<lambda>x. \<Sum>i\<in>B. (g x \<bullet> i) *\<^sub>R i) ` S \<subseteq> T"
+ using \<open>B \<subseteq> T\<close> by (blast intro: subspace_setsum subspace_mul \<open>subspace T\<close>)
+ show "norm (f x - (\<Sum>i\<in>B. (g x \<bullet> i) *\<^sub>R i)) < e" if "x \<in> S" for x
+ proof -
+ have orth': "pairwise (\<lambda>i j. orthogonal ((f x \<bullet> i) *\<^sub>R i - (g x \<bullet> i) *\<^sub>R i)
+ ((f x \<bullet> j) *\<^sub>R j - (g x \<bullet> j) *\<^sub>R j)) B"
+ apply (rule pairwise_mono [OF orthB])
+ apply (auto simp: orthogonal_def inner_diff_right inner_diff_left)
+ done
+ then have "(norm (\<Sum>i\<in>B. (f x \<bullet> i) *\<^sub>R i - (g x \<bullet> i) *\<^sub>R i))\<^sup>2 =
+ (\<Sum>i\<in>B. (norm ((f x \<bullet> i) *\<^sub>R i - (g x \<bullet> i) *\<^sub>R i))\<^sup>2)"
+ by (simp add: norm_setsum_Pythagorean [OF \<open>finite B\<close> orth'])
+ also have "... = (\<Sum>i\<in>B. (norm (((f x - g x) \<bullet> i) *\<^sub>R i))\<^sup>2)"
+ by (simp add: algebra_simps)
+ also have "... \<le> (\<Sum>i\<in>B. (norm (f x - g x))\<^sup>2)"
+ apply (rule setsum_mono)
+ apply (simp add: B1)
+ apply (rule order_trans [OF Cauchy_Schwarz_ineq])
+ by (simp add: B1 dot_square_norm)
+ also have "... = n * norm (f x - g x)^2"
+ by (simp add: \<open>n = card B\<close>)
+ also have "... \<le> n * (e / (n+2))^2"
+ apply (rule mult_left_mono)
+ apply (meson dual_order.order_iff_strict g norm_ge_zero power_mono that, simp)
+ done
+ also have "... \<le> e^2 / (n+2)"
+ using \<open>0 < e\<close> by (simp add: divide_simps power2_eq_square)
+ also have "... < e^2"
+ using \<open>0 < e\<close> by (simp add: divide_simps)
+ finally have "(norm (\<Sum>i\<in>B. (f x \<bullet> i) *\<^sub>R i - (g x \<bullet> i) *\<^sub>R i))\<^sup>2 < e^2" .
+ then have "(norm (\<Sum>i\<in>B. (f x \<bullet> i) *\<^sub>R i - (g x \<bullet> i) *\<^sub>R i)) < e"
+ apply (rule power2_less_imp_less)
+ using \<open>0 < e\<close> by auto
+ then show ?thesis
+ using fx that by (simp add: setsum_subtractf)
+ qed
+ qed
+qed
+
+
hide_fact linear add mult const
end
--- a/src/HOL/Groups_Big.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Groups_Big.thy Thu Sep 22 15:44:47 2016 +0100
@@ -624,6 +624,24 @@
with eq show False by simp
qed
+lemma member_le_setsum:
+ fixes f :: "_ \<Rightarrow> 'b::{semiring_1, ordered_comm_monoid_add}"
+ assumes le: "\<And>x. x \<in> A \<Longrightarrow> 0 \<le> f x"
+ and "i \<in> A"
+ and "finite A"
+ shows "f i \<le> setsum f A"
+proof -
+ have "f i \<le> setsum f (A \<inter> {i})"
+ by (simp add: assms)
+ also have "... = (\<Sum>x\<in>A. if x \<in> {i} then f x else 0)"
+ using assms setsum.inter_restrict by blast
+ also have "... \<le> setsum f A"
+ apply (rule setsum_mono)
+ apply (auto simp: le)
+ done
+ finally show ?thesis .
+qed
+
lemma setsum_negf: "(\<Sum>x\<in>A. - f x) = - (\<Sum>x\<in>A. f x)"
for f :: "'b \<Rightarrow> 'a::ab_group_add"
by (induct A rule: infinite_finite_induct) auto
--- a/src/HOL/Set.thy Wed Sep 21 16:59:51 2016 +0100
+++ b/src/HOL/Set.thy Thu Sep 22 15:44:47 2016 +0100
@@ -1852,6 +1852,9 @@
lemma pairwise_subset: "pairwise P S \<Longrightarrow> T \<subseteq> S \<Longrightarrow> pairwise P T"
by (force simp: pairwise_def)
+lemma pairwise_mono: "\<lbrakk>pairwise P A; \<And>x y. P x y \<Longrightarrow> Q x y\<rbrakk> \<Longrightarrow> pairwise Q A"
+ by (auto simp: pairwise_def)
+
definition disjnt :: "'a set \<Rightarrow> 'a set \<Rightarrow> bool"
where "disjnt A B \<longleftrightarrow> A \<inter> B = {}"