src/HOL/Analysis/Line_Segment.thy
author wenzelm
Mon, 11 Sep 2023 19:30:48 +0200
changeset 78659 b5f3d1051b13
parent 78477 37abfe400ae6
child 79582 7822b55b26ce
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
     1
(* Title:      HOL/Analysis/Line_Segment.thy
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
     2
   Author:     L C Paulson, University of Cambridge
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
     3
   Author:     Robert Himmelmann, TU Muenchen
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
     4
   Author:     Bogdan Grechuk, University of Edinburgh
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
     5
   Author:     Armin Heller, TU Muenchen
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
     6
   Author:     Johannes Hoelzl, TU Muenchen
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
     7
*)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
     8
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
     9
section \<open>Line Segment\<close>
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    10
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    11
theory Line_Segment
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    12
imports
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    13
  Convex
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    14
  Topology_Euclidean_Space
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    15
begin
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    16
71169
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
    17
subsection\<^marker>\<open>tag unimportant\<close> \<open>Topological Properties of Convex Sets, Metric Spaces and Functions\<close>
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    18
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    19
lemma convex_supp_sum:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    20
  assumes "convex S" and 1: "supp_sum u I = 1"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    21
      and "\<And>i. i \<in> I \<Longrightarrow> 0 \<le> u i \<and> (u i = 0 \<or> f i \<in> S)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    22
    shows "supp_sum (\<lambda>i. u i *\<^sub>R f i) I \<in> S"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    23
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    24
  have fin: "finite {i \<in> I. u i \<noteq> 0}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    25
    using 1 sum.infinite by (force simp: supp_sum_def support_on_def)
71169
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
    26
  then have "supp_sum (\<lambda>i. u i *\<^sub>R f i) I = sum (\<lambda>i. u i *\<^sub>R f i) {i \<in> I. u i \<noteq> 0}"
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    27
    by (force intro: sum.mono_neutral_left simp: supp_sum_def support_on_def)
71169
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
    28
  also have "... \<in> S"
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
    29
    using 1 assms by (force simp: supp_sum_def support_on_def intro: convex_sum [OF fin \<open>convex S\<close>])
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
    30
  finally show ?thesis .
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    31
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    32
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    33
lemma sphere_eq_empty [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    34
  fixes a :: "'a::{real_normed_vector, perfect_space}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    35
  shows "sphere a r = {} \<longleftrightarrow> r < 0"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
    36
  by (metis empty_iff linorder_not_less mem_sphere sphere_empty vector_choose_dist)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    37
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    38
lemma cone_closure:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    39
  fixes S :: "'a::real_normed_vector set"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    40
  assumes "cone S"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    41
  shows "cone (closure S)"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
    42
  by (metis UnCI assms closure_Un_frontier closure_eq_empty closure_scaleR cone_iff)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    43
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    44
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    45
corollary component_complement_connected:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    46
  fixes S :: "'a::real_normed_vector set"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    47
  assumes "connected S" "C \<in> components (-S)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    48
  shows "connected(-C)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    49
  using component_diff_connected [of S UNIV] assms
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    50
  by (auto simp: Compl_eq_Diff_UNIV)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    51
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    52
proposition clopen:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    53
  fixes S :: "'a :: real_normed_vector set"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    54
  shows "closed S \<and> open S \<longleftrightarrow> S = {} \<or> S = UNIV"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
    55
  using  connected_UNIV by (force simp add: connected_clopen)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    56
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    57
corollary compact_open:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    58
  fixes S :: "'a :: euclidean_space set"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    59
  shows "compact S \<and> open S \<longleftrightarrow> S = {}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    60
  by (auto simp: compact_eq_bounded_closed clopen)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    61
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    62
corollary finite_imp_not_open:
71169
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
    63
  fixes S :: "'a::{real_normed_vector, perfect_space} set"
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
    64
  shows "\<lbrakk>finite S; open S\<rbrakk> \<Longrightarrow> S={}"
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    65
  using clopen [of S] finite_imp_closed not_bounded_UNIV by blast
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    66
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    67
corollary empty_interior_finite:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    68
    fixes S :: "'a::{real_normed_vector, perfect_space} set"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    69
    shows "finite S \<Longrightarrow> interior S = {}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    70
  by (metis interior_subset finite_subset open_interior [of S] finite_imp_not_open)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    71
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    72
text \<open>Balls, being convex, are connected.\<close>
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    73
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    74
lemma convex_local_global_minimum:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    75
  fixes s :: "'a::real_normed_vector set"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    76
  assumes "e > 0"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    77
    and "convex_on s f"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    78
    and "ball x e \<subseteq> s"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    79
    and "\<forall>y\<in>ball x e. f x \<le> f y"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    80
  shows "\<forall>y\<in>s. f x \<le> f y"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    81
proof (rule ccontr)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    82
  have "x \<in> s" using assms(1,3) by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    83
  assume "\<not> ?thesis"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    84
  then obtain y where "y\<in>s" and y: "f x > f y" by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    85
  then have xy: "0 < dist x y"  by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    86
  then obtain u where "0 < u" "u \<le> 1" and u: "u < e / dist x y"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    87
    using field_lbound_gt_zero[of 1 "e / dist x y"] xy \<open>e>0\<close> by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    88
  then have "f ((1-u) *\<^sub>R x + u *\<^sub>R y) \<le> (1-u) * f x + u * f y"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
    89
    using \<open>x\<in>s\<close> \<open>y\<in>s\<close> by (smt (verit) assms(2) convex_on_def)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    90
  moreover
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    91
  have *: "x - ((1 - u) *\<^sub>R x + u *\<^sub>R y) = u *\<^sub>R (x - y)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    92
    by (simp add: algebra_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    93
  have "(1 - u) *\<^sub>R x + u *\<^sub>R y \<in> ball x e"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
    94
    by (smt (verit) "*" \<open>0 < u\<close> dist_norm mem_ball norm_scaleR pos_less_divide_eq u xy)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    95
  then have "f x \<le> f ((1 - u) *\<^sub>R x + u *\<^sub>R y)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    96
    using assms(4) by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    97
  ultimately show False
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    98
    using mult_strict_left_mono[OF y \<open>u>0\<close>]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
    99
    unfolding left_diff_distrib
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   100
    by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   101
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   102
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   103
lemma convex_ball [iff]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   104
  fixes x :: "'a::real_normed_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   105
  shows "convex (ball x e)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   106
proof (auto simp: convex_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   107
  fix y z
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   108
  assume yz: "dist x y < e" "dist x z < e"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   109
  fix u v :: real
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   110
  assume uv: "0 \<le> u" "0 \<le> v" "u + v = 1"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   111
  have "dist x (u *\<^sub>R y + v *\<^sub>R z) \<le> u * dist x y + v * dist x z"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   112
    using uv yz
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   113
    using convex_on_dist [of "ball x e" x, unfolded convex_on_def,
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   114
      THEN bspec[where x=y], THEN bspec[where x=z]]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   115
    by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   116
  then show "dist x (u *\<^sub>R y + v *\<^sub>R z) < e"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   117
    using convex_bound_lt[OF yz uv] by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   118
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   119
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   120
lemma convex_cball [iff]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   121
  fixes x :: "'a::real_normed_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   122
  shows "convex (cball x e)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   123
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   124
  {
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   125
    fix y z
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   126
    assume yz: "dist x y \<le> e" "dist x z \<le> e"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   127
    fix u v :: real
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   128
    assume uv: "0 \<le> u" "0 \<le> v" "u + v = 1"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   129
    have "dist x (u *\<^sub>R y + v *\<^sub>R z) \<le> u * dist x y + v * dist x z"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   130
      using uv yz
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   131
      using convex_on_dist [of "cball x e" x, unfolded convex_on_def,
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   132
        THEN bspec[where x=y], THEN bspec[where x=z]]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   133
      by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   134
    then have "dist x (u *\<^sub>R y + v *\<^sub>R z) \<le> e"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   135
      using convex_bound_le[OF yz uv] by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   136
  }
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   137
  then show ?thesis by (auto simp: convex_def Ball_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   138
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   139
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   140
lemma connected_ball [iff]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   141
  fixes x :: "'a::real_normed_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   142
  shows "connected (ball x e)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   143
  using convex_connected convex_ball by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   144
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   145
lemma connected_cball [iff]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   146
  fixes x :: "'a::real_normed_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   147
  shows "connected (cball x e)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   148
  using convex_connected convex_cball by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   149
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   150
lemma bounded_convex_hull:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   151
  fixes s :: "'a::real_normed_vector set"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   152
  assumes "bounded s"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   153
  shows "bounded (convex hull s)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   154
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   155
  from assms obtain B where B: "\<forall>x\<in>s. norm x \<le> B"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   156
    unfolding bounded_iff by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   157
  show ?thesis
71169
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
   158
    by (simp add: bounded_subset[OF bounded_cball, of _ 0 B] B subsetI subset_hull)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   159
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   160
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   161
lemma finite_imp_bounded_convex_hull:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   162
  fixes s :: "'a::real_normed_vector set"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   163
  shows "finite s \<Longrightarrow> bounded (convex hull s)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   164
  using bounded_convex_hull finite_imp_bounded
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   165
  by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   166
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   167
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   168
subsection \<open>Midpoint\<close>
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   169
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   170
definition\<^marker>\<open>tag important\<close> midpoint :: "'a::real_vector \<Rightarrow> 'a \<Rightarrow> 'a"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   171
  where "midpoint a b = (inverse (2::real)) *\<^sub>R (a + b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   172
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   173
lemma midpoint_idem [simp]: "midpoint x x = x"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   174
  unfolding midpoint_def  by simp
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   175
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   176
lemma midpoint_sym: "midpoint a b = midpoint b a"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   177
  unfolding midpoint_def by (auto simp add: scaleR_right_distrib)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   178
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   179
lemma midpoint_eq_iff: "midpoint a b = c \<longleftrightarrow> a + b = c + c"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   180
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   181
  have "midpoint a b = c \<longleftrightarrow> scaleR 2 (midpoint a b) = scaleR 2 c"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   182
    by simp
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   183
  then show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   184
    unfolding midpoint_def scaleR_2 [symmetric] by simp
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   185
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   186
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   187
lemma
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   188
  fixes a::real
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   189
  assumes "a \<le> b" shows ge_midpoint_1: "a \<le> midpoint a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   190
                    and le_midpoint_1: "midpoint a b \<le> b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   191
  by (simp_all add: midpoint_def assms)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   192
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   193
lemma dist_midpoint:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   194
  fixes a b :: "'a::real_normed_vector" shows
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   195
  "dist a (midpoint a b) = (dist a b) / 2" (is ?t1)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   196
  "dist b (midpoint a b) = (dist a b) / 2" (is ?t2)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   197
  "dist (midpoint a b) a = (dist a b) / 2" (is ?t3)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   198
  "dist (midpoint a b) b = (dist a b) / 2" (is ?t4)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   199
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   200
  have *: "\<And>x y::'a. 2 *\<^sub>R x = - y \<Longrightarrow> norm x = (norm y) / 2"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   201
    unfolding equation_minus_iff by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   202
  have **: "\<And>x y::'a. 2 *\<^sub>R x =   y \<Longrightarrow> norm x = (norm y) / 2"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   203
    by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   204
  note scaleR_right_distrib [simp]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   205
  show ?t1
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   206
    unfolding midpoint_def dist_norm
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   207
    apply (rule **)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   208
    apply (simp add: scaleR_right_diff_distrib)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   209
    apply (simp add: scaleR_2)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   210
    done
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   211
  show ?t2
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   212
    unfolding midpoint_def dist_norm
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   213
    apply (rule *)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   214
    apply (simp add: scaleR_right_diff_distrib)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   215
    apply (simp add: scaleR_2)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   216
    done
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   217
  show ?t3
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   218
    unfolding midpoint_def dist_norm
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   219
    apply (rule *)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   220
    apply (simp add: scaleR_right_diff_distrib)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   221
    apply (simp add: scaleR_2)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   222
    done
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   223
  show ?t4
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   224
    unfolding midpoint_def dist_norm
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   225
    apply (rule **)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   226
    apply (simp add: scaleR_right_diff_distrib)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   227
    apply (simp add: scaleR_2)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   228
    done
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   229
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   230
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   231
lemma midpoint_eq_endpoint [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   232
  "midpoint a b = a \<longleftrightarrow> a = b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   233
  "midpoint a b = b \<longleftrightarrow> a = b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   234
  unfolding midpoint_eq_iff by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   235
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   236
lemma midpoint_plus_self [simp]: "midpoint a b + midpoint a b = a + b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   237
  using midpoint_eq_iff by metis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   238
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   239
lemma midpoint_linear_image:
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   240
  "linear f \<Longrightarrow> midpoint(f a)(f b) = f(midpoint a b)"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   241
  by (simp add: linear_iff midpoint_def)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   242
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   243
71169
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
   244
subsection \<open>Open and closed segments\<close>
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   245
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   246
definition\<^marker>\<open>tag important\<close> closed_segment :: "'a::real_vector \<Rightarrow> 'a \<Rightarrow> 'a set"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   247
  where "closed_segment a b = {(1 - u) *\<^sub>R a + u *\<^sub>R b | u::real. 0 \<le> u \<and> u \<le> 1}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   248
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   249
definition\<^marker>\<open>tag important\<close> open_segment :: "'a::real_vector \<Rightarrow> 'a \<Rightarrow> 'a set" where
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   250
  "open_segment a b \<equiv> closed_segment a b - {a,b}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   251
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   252
lemmas segment = open_segment_def closed_segment_def
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   253
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   254
lemma in_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   255
    "x \<in> closed_segment a b \<longleftrightarrow> (\<exists>u. 0 \<le> u \<and> u \<le> 1 \<and> x = (1 - u) *\<^sub>R a + u *\<^sub>R b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   256
    "x \<in> open_segment a b \<longleftrightarrow> a \<noteq> b \<and> (\<exists>u. 0 < u \<and> u < 1 \<and> x = (1 - u) *\<^sub>R a + u *\<^sub>R b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   257
  using less_eq_real_def by (auto simp: segment algebra_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   258
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   259
lemma closed_segment_linear_image:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   260
  "closed_segment (f a) (f b) = f ` (closed_segment a b)" if "linear f"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   261
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   262
  interpret linear f by fact
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   263
  show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   264
    by (force simp add: in_segment add scale)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   265
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   266
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   267
lemma open_segment_linear_image:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   268
    "\<lbrakk>linear f; inj f\<rbrakk> \<Longrightarrow> open_segment (f a) (f b) = f ` (open_segment a b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   269
  by (force simp: open_segment_def closed_segment_linear_image inj_on_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   270
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   271
lemma closed_segment_translation:
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   272
    "closed_segment (c + a) (c + b) = (\<lambda>x. c + x) ` (closed_segment a b)" (is "?L = _ ` ?R")
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   273
proof -
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   274
  have "\<And>x. x \<in> ?L \<Longrightarrow> x - c \<in> ?R" "\<And>x. \<lbrakk>x \<in> ?R\<rbrakk> \<Longrightarrow> c + x \<in> ?L"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   275
    by (auto simp: in_segment algebra_simps)
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   276
  then show ?thesis by force
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   277
qed
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   278
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   279
lemma open_segment_translation:
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   280
  "open_segment (c + a) (c + b) = image (\<lambda>x. c + x) (open_segment a b)"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   281
  by (simp add: open_segment_def closed_segment_translation translation_diff)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   282
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   283
lemma closed_segment_of_real:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   284
    "closed_segment (of_real x) (of_real y) = of_real ` closed_segment x y"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   285
  by (simp add: closed_segment_linear_image linearI scaleR_conv_of_real)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   286
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   287
lemma open_segment_of_real:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   288
    "open_segment (of_real x) (of_real y) = of_real ` open_segment x y"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   289
  by (simp add: closed_segment_of_real image_set_diff inj_of_real open_segment_def)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   290
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   291
lemma closed_segment_Reals:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   292
    "\<lbrakk>x \<in> Reals; y \<in> Reals\<rbrakk> \<Longrightarrow> closed_segment x y = of_real ` closed_segment (Re x) (Re y)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   293
  by (metis closed_segment_of_real of_real_Re)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   294
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   295
lemma open_segment_Reals:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   296
    "\<lbrakk>x \<in> Reals; y \<in> Reals\<rbrakk> \<Longrightarrow> open_segment x y = of_real ` open_segment (Re x) (Re y)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   297
  by (metis open_segment_of_real of_real_Re)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   298
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   299
lemma open_segment_PairD:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   300
    "(x, x') \<in> open_segment (a, a') (b, b')
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   301
     \<Longrightarrow> (x \<in> open_segment a b \<or> a = b) \<and> (x' \<in> open_segment a' b' \<or> a' = b')"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   302
  by (auto simp: in_segment)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   303
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   304
lemma closed_segment_PairD:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   305
  "(x, x') \<in> closed_segment (a, a') (b, b') \<Longrightarrow> x \<in> closed_segment a b \<and> x' \<in> closed_segment a' b'"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   306
  by (auto simp: closed_segment_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   307
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   308
lemma closed_segment_translation_eq [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   309
    "d + x \<in> closed_segment (d + a) (d + b) \<longleftrightarrow> x \<in> closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   310
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   311
  have *: "\<And>d x a b. x \<in> closed_segment a b \<Longrightarrow> d + x \<in> closed_segment (d + a) (d + b)"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   312
    using closed_segment_translation by blast
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   313
  show ?thesis
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   314
    using * [where d = "-d"] * by fastforce
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   315
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   316
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   317
lemma open_segment_translation_eq [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   318
    "d + x \<in> open_segment (d + a) (d + b) \<longleftrightarrow> x \<in> open_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   319
  by (simp add: open_segment_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   320
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   321
lemma of_real_closed_segment [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   322
  "of_real x \<in> closed_segment (of_real a) (of_real b) \<longleftrightarrow> x \<in> closed_segment a b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   323
  by (simp add: closed_segment_of_real image_iff)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   324
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   325
lemma of_real_open_segment [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   326
  "of_real x \<in> open_segment (of_real a) (of_real b) \<longleftrightarrow> x \<in> open_segment a b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   327
  by (simp add: image_iff open_segment_of_real)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   328
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   329
lemma convex_contains_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   330
  "convex S \<longleftrightarrow> (\<forall>a\<in>S. \<forall>b\<in>S. closed_segment a b \<subseteq> S)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   331
  unfolding convex_alt closed_segment_def by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   332
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   333
lemma closed_segment_in_Reals:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   334
   "\<lbrakk>x \<in> closed_segment a b; a \<in> Reals; b \<in> Reals\<rbrakk> \<Longrightarrow> x \<in> Reals"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   335
  by (meson subsetD convex_Reals convex_contains_segment)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   336
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   337
lemma open_segment_in_Reals:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   338
   "\<lbrakk>x \<in> open_segment a b; a \<in> Reals; b \<in> Reals\<rbrakk> \<Longrightarrow> x \<in> Reals"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   339
  by (metis Diff_iff closed_segment_in_Reals open_segment_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   340
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   341
lemma closed_segment_subset: "\<lbrakk>x \<in> S; y \<in> S; convex S\<rbrakk> \<Longrightarrow> closed_segment x y \<subseteq> S"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   342
  by (simp add: convex_contains_segment)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   343
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   344
lemma closed_segment_subset_convex_hull:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   345
    "\<lbrakk>x \<in> convex hull S; y \<in> convex hull S\<rbrakk> \<Longrightarrow> closed_segment x y \<subseteq> convex hull S"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   346
  using convex_contains_segment by blast
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   347
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   348
lemma segment_convex_hull:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   349
  "closed_segment a b = convex hull {a,b}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   350
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   351
  have *: "\<And>x. {x} \<noteq> {}" by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   352
  show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   353
    unfolding segment convex_hull_insert[OF *] convex_hull_singleton
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   354
    by (safe; rule_tac x="1 - u" in exI; force)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   355
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   356
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   357
lemma open_closed_segment: "u \<in> open_segment w z \<Longrightarrow> u \<in> closed_segment w z"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   358
  by (auto simp add: closed_segment_def open_segment_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   359
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   360
lemma segment_open_subset_closed:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   361
   "open_segment a b \<subseteq> closed_segment a b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   362
  by (simp add: open_closed_segment subsetI)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   363
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   364
lemma bounded_closed_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   365
  fixes a :: "'a::real_normed_vector" shows "bounded (closed_segment a b)"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   366
  by (simp add: bounded_convex_hull segment_convex_hull)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   367
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   368
lemma bounded_open_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   369
    fixes a :: "'a::real_normed_vector" shows "bounded (open_segment a b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   370
  by (rule bounded_subset [OF bounded_closed_segment segment_open_subset_closed])
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   371
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   372
lemmas bounded_segment = bounded_closed_segment open_closed_segment
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   373
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   374
lemma ends_in_segment [iff]: "a \<in> closed_segment a b" "b \<in> closed_segment a b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   375
  by (simp_all add: hull_inc segment_convex_hull)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   376
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   377
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   378
lemma eventually_closed_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   379
  fixes x0::"'a::real_normed_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   380
  assumes "open X0" "x0 \<in> X0"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   381
  shows "\<forall>\<^sub>F x in at x0 within U. closed_segment x0 x \<subseteq> X0"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   382
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   383
  from openE[OF assms]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   384
  obtain e where e: "0 < e" "ball x0 e \<subseteq> X0" .
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   385
  then have "\<forall>\<^sub>F x in at x0 within U. x \<in> ball x0 e"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   386
    by (auto simp: dist_commute eventually_at)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   387
  then show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   388
  proof eventually_elim
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   389
    case (elim x)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   390
    have "x0 \<in> ball x0 e" using \<open>e > 0\<close> by simp
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   391
    then have "closed_segment x0 x \<subseteq> ball x0 e"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   392
      using closed_segment_subset elim by blast 
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   393
    then show ?case
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   394
      using e(2) by auto 
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   395
  qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   396
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   397
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   398
lemma closed_segment_commute: "closed_segment a b = closed_segment b a"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   399
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   400
  have "{a, b} = {b, a}" by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   401
  thus ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   402
    by (simp add: segment_convex_hull)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   403
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   404
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   405
lemma segment_bound1:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   406
  assumes "x \<in> closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   407
  shows "norm (x - a) \<le> norm (b - a)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   408
proof -
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   409
  obtain u where u: "x = (1 - u) *\<^sub>R a + u *\<^sub>R b" "0 \<le> u" "u \<le> 1"
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   410
    using assms by (auto simp add: closed_segment_def)
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   411
  then have "norm (u *\<^sub>R b - u *\<^sub>R a) \<le> norm (b - a)"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   412
    by (simp add: mult_left_le_one_le flip: scaleR_diff_right)
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   413
  with u show ?thesis
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   414
    by (metis add_diff_cancel_left scaleR_collapse)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   415
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   416
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   417
lemma segment_bound:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   418
  assumes "x \<in> closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   419
  shows "norm (x - a) \<le> norm (b - a)" "norm (x - b) \<le> norm (b - a)"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   420
  by (metis assms closed_segment_commute dist_commute dist_norm segment_bound1)+
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   421
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   422
lemma open_segment_bound1:
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   423
  assumes "x \<in> open_segment a b"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   424
  shows "norm (x - a) < norm (b - a)"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   425
proof -
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   426
  obtain u where u: "x = (1 - u) *\<^sub>R a + u *\<^sub>R b" "0 < u" "u < 1"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   427
    by (meson assms in_segment)
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   428
  then have "norm (u *\<^sub>R b - u *\<^sub>R a) < norm (b - a)"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   429
    using assms in_segment(2) less_eq_real_def by (fastforce simp flip: scaleR_diff_right)
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   430
  with u show ?thesis
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   431
    by (metis add_diff_cancel_left scaleR_collapse)
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   432
qed
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   433
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   434
lemma open_segment_commute: "open_segment a b = open_segment b a"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   435
  by (simp add: closed_segment_commute insert_commute open_segment_def)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   436
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   437
lemma closed_segment_idem [simp]: "closed_segment a a = {a}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   438
  unfolding segment by (auto simp add: algebra_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   439
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   440
lemma open_segment_idem [simp]: "open_segment a a = {}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   441
  by (simp add: open_segment_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   442
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   443
lemma closed_segment_eq_open: "closed_segment a b = open_segment a b \<union> {a,b}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   444
  using open_segment_def by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   445
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   446
lemma convex_contains_open_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   447
  "convex s \<longleftrightarrow> (\<forall>a\<in>s. \<forall>b\<in>s. open_segment a b \<subseteq> s)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   448
  by (simp add: convex_contains_segment closed_segment_eq_open)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   449
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   450
lemma closed_segment_eq_real_ivl1:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   451
  fixes a b::real
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   452
  assumes "a \<le> b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   453
  shows "closed_segment a b = {a .. b}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   454
proof safe
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   455
  fix x
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   456
  assume "x \<in> closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   457
  then obtain u where u: "0 \<le> u" "u \<le> 1" and x_def: "x = (1 - u) * a + u * b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   458
    by (auto simp: closed_segment_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   459
  have "u * a \<le> u * b" "(1 - u) * a \<le> (1 - u) * b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   460
    by (auto intro!: mult_left_mono u assms)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   461
  then show "x \<in> {a .. b}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   462
    unfolding x_def by (auto simp: algebra_simps)
71169
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
   463
next
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
   464
  show "\<And>x. x \<in> {a..b} \<Longrightarrow> x \<in> closed_segment a b"
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
   465
    by (force simp: closed_segment_def divide_simps algebra_simps
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
   466
              intro: exI[where x="(x - a) / (b - a)" for x])
df1d96114754 Fixed a few messy proofs and adjusted inconsistent section headings
paulson <lp15@cam.ac.uk>
parents: 71028
diff changeset
   467
qed 
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   468
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   469
lemma closed_segment_eq_real_ivl:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   470
  fixes a b::real
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   471
  shows "closed_segment a b = (if a \<le> b then {a .. b} else {b .. a})"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   472
  by (metis closed_segment_commute closed_segment_eq_real_ivl1 nle_le)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   473
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   474
lemma open_segment_eq_real_ivl:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   475
  fixes a b::real
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   476
  shows "open_segment a b = (if a \<le> b then {a<..<b} else {b<..<a})"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   477
by (auto simp: closed_segment_eq_real_ivl open_segment_def split: if_split_asm)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   478
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   479
lemma closed_segment_real_eq:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   480
  fixes u::real shows "closed_segment u v = (\<lambda>x. (v - u) * x + u) ` {0..1}"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   481
  by (simp add: closed_segment_eq_real_ivl image_affinity_atLeastAtMost)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   482
71189
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   483
lemma closed_segment_same_Re:
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   484
  assumes "Re a = Re b"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   485
  shows   "closed_segment a b = {z. Re z = Re a \<and> Im z \<in> closed_segment (Im a) (Im b)}"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   486
proof safe
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   487
  fix z assume "z \<in> closed_segment a b"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   488
  then obtain u where u: "u \<in> {0..1}" "z = a + of_real u * (b - a)"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   489
    by (auto simp: closed_segment_def scaleR_conv_of_real algebra_simps)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   490
  from assms show "Re z = Re a" by (auto simp: u)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   491
  from u(1) show "Im z \<in> closed_segment (Im a) (Im b)"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   492
    by (force simp: u closed_segment_def algebra_simps)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   493
next
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   494
  fix z assume [simp]: "Re z = Re a" and "Im z \<in> closed_segment (Im a) (Im b)"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   495
  then obtain u where u: "u \<in> {0..1}" "Im z = Im a + of_real u * (Im b - Im a)"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   496
    by (auto simp: closed_segment_def scaleR_conv_of_real algebra_simps)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   497
  from u(1) show "z \<in> closed_segment a b" using assms
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   498
    by (force simp: u closed_segment_def algebra_simps scaleR_conv_of_real complex_eq_iff)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   499
qed
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   500
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   501
lemma closed_segment_same_Im:
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   502
  assumes "Im a = Im b"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   503
  shows   "closed_segment a b = {z. Im z = Im a \<and> Re z \<in> closed_segment (Re a) (Re b)}"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   504
proof safe
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   505
  fix z assume "z \<in> closed_segment a b"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   506
  then obtain u where u: "u \<in> {0..1}" "z = a + of_real u * (b - a)"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   507
    by (auto simp: closed_segment_def scaleR_conv_of_real algebra_simps)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   508
  from assms show "Im z = Im a" by (auto simp: u)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   509
  from u(1) show "Re z \<in> closed_segment (Re a) (Re b)"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   510
    by (force simp: u closed_segment_def algebra_simps)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   511
next
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   512
  fix z assume [simp]: "Im z = Im a" and "Re z \<in> closed_segment (Re a) (Re b)"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   513
  then obtain u where u: "u \<in> {0..1}" "Re z = Re a + of_real u * (Re b - Re a)"
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   514
    by (auto simp: closed_segment_def scaleR_conv_of_real algebra_simps)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   515
  from u(1) show "z \<in> closed_segment a b" using assms
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   516
    by (force simp: u closed_segment_def algebra_simps scaleR_conv_of_real complex_eq_iff)
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   517
qed
954ee5acaae0 Split off new HOL-Complex_Analysis session from HOL-Analysis
Manuel Eberl <eberlm@in.tum.de>
parents: 71169
diff changeset
   518
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   519
lemma dist_in_closed_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   520
  fixes a :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   521
  assumes "x \<in> closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   522
    shows "dist x a \<le> dist a b \<and> dist x b \<le> dist a b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   523
  by (metis assms dist_commute dist_norm segment_bound(2) segment_bound1)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   524
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   525
lemma dist_in_open_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   526
  fixes a :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   527
  assumes "x \<in> open_segment a b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   528
  shows "dist x a < dist a b \<and> dist x b < dist a b"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   529
  by (metis assms dist_commute dist_norm open_segment_bound1 open_segment_commute)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   530
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   531
lemma dist_decreases_open_segment_0:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   532
  fixes x :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   533
  assumes "x \<in> open_segment 0 b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   534
    shows "dist c x < dist c 0 \<or> dist c x < dist c b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   535
proof (rule ccontr, clarsimp simp: not_less)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   536
  obtain u where u: "0 \<noteq> b" "0 < u" "u < 1" and x: "x = u *\<^sub>R b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   537
    using assms by (auto simp: in_segment)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   538
  have xb: "x \<bullet> b < b \<bullet> b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   539
    using u x by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   540
  assume "norm c \<le> dist c x"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   541
  then have "c \<bullet> c \<le> (c - x) \<bullet> (c - x)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   542
    by (simp add: dist_norm norm_le)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   543
  moreover have "0 < x \<bullet> b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   544
    using u x by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   545
  ultimately have less: "c \<bullet> b < x \<bullet> b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   546
    by (simp add: x algebra_simps inner_commute u)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   547
  assume "dist c b \<le> dist c x"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   548
  then have "(c - b) \<bullet> (c - b) \<le> (c - x) \<bullet> (c - x)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   549
    by (simp add: dist_norm norm_le)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   550
  then have "(b \<bullet> b) * (1 - u*u) \<le> 2 * (b \<bullet> c) * (1-u)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   551
    by (simp add: x algebra_simps inner_commute)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   552
  then have "(1+u) * (b \<bullet> b) * (1-u) \<le> 2 * (b \<bullet> c) * (1-u)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   553
    by (simp add: algebra_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   554
  then have "(1+u) * (b \<bullet> b) \<le> 2 * (b \<bullet> c)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   555
    using \<open>u < 1\<close> by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   556
  with xb have "c \<bullet> b \<ge> x \<bullet> b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   557
    by (auto simp: x algebra_simps inner_commute)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   558
  with less show False by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   559
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   560
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   561
proposition dist_decreases_open_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   562
  fixes a :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   563
  assumes "x \<in> open_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   564
    shows "dist c x < dist c a \<or> dist c x < dist c b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   565
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   566
  have *: "x - a \<in> open_segment 0 (b - a)" using assms
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   567
    by (metis diff_self open_segment_translation_eq uminus_add_conv_diff)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   568
  show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   569
    using dist_decreases_open_segment_0 [OF *, of "c-a"] assms
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   570
    by (simp add: dist_norm)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   571
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   572
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   573
corollary open_segment_furthest_le:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   574
  fixes a b x y :: "'a::euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   575
  assumes "x \<in> open_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   576
  shows "norm (y - x) < norm (y - a) \<or>  norm (y - x) < norm (y - b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   577
  by (metis assms dist_decreases_open_segment dist_norm)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   578
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   579
corollary dist_decreases_closed_segment:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   580
  fixes a :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   581
  assumes "x \<in> closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   582
    shows "dist c x \<le> dist c a \<or> dist c x \<le> dist c b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   583
  by (smt (verit, ccfv_threshold) Un_iff assms closed_segment_eq_open dist_norm empty_iff insertE open_segment_furthest_le)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   584
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   585
corollary segment_furthest_le:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   586
  fixes a b x y :: "'a::euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   587
  assumes "x \<in> closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   588
  shows "norm (y - x) \<le> norm (y - a) \<or>  norm (y - x) \<le> norm (y - b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   589
  by (metis assms dist_decreases_closed_segment dist_norm)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   590
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   591
lemma convex_intermediate_ball:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   592
  fixes a :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   593
  shows "\<lbrakk>ball a r \<subseteq> T; T \<subseteq> cball a r\<rbrakk> \<Longrightarrow> convex T"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   594
  by (smt (verit) convex_contains_open_segment dist_decreases_open_segment mem_ball mem_cball subset_eq)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   595
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   596
lemma csegment_midpoint_subset: "closed_segment (midpoint a b) b \<subseteq> closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   597
  apply (clarsimp simp: midpoint_def in_segment)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   598
  apply (rule_tac x="(1 + u) / 2" in exI)
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   599
  apply (simp add: algebra_simps add_divide_distrib diff_divide_distrib)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   600
  by (metis field_sum_of_halves scaleR_left.add)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   601
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   602
lemma notin_segment_midpoint:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   603
  fixes a :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   604
  shows "a \<noteq> b \<Longrightarrow> a \<notin> closed_segment (midpoint a b) b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   605
  by (auto simp: dist_midpoint dest!: dist_in_closed_segment)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   606
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   607
subsubsection\<open>More lemmas, especially for working with the underlying formula\<close>
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   608
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   609
lemma segment_eq_compose:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   610
  fixes a :: "'a :: real_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   611
  shows "(\<lambda>u. (1 - u) *\<^sub>R a + u *\<^sub>R b) = (\<lambda>x. a + x) o (\<lambda>u. u *\<^sub>R (b - a))"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   612
    by (simp add: o_def algebra_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   613
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   614
lemma segment_degen_1:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   615
  fixes a :: "'a :: real_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   616
  shows "(1 - u) *\<^sub>R a + u *\<^sub>R b = b \<longleftrightarrow> a=b \<or> u=1"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   617
  by (smt (verit, best) add_right_cancel scaleR_cancel_left scaleR_collapse)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   618
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   619
lemma segment_degen_0:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   620
    fixes a :: "'a :: real_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   621
    shows "(1 - u) *\<^sub>R a + u *\<^sub>R b = a \<longleftrightarrow> a=b \<or> u=0"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   622
  using segment_degen_1 [of "1-u" b a] by (auto simp: algebra_simps)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   623
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   624
lemma add_scaleR_degen:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   625
  fixes a b ::"'a::real_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   626
  assumes  "(u *\<^sub>R b + v *\<^sub>R a) = (u *\<^sub>R a + v *\<^sub>R b)"  "u \<noteq> v"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   627
  shows "a=b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   628
  by (smt (verit) add_diff_cancel_left' add_diff_eq assms scaleR_cancel_left scaleR_left.diff)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   629
  
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   630
lemma closed_segment_image_interval:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   631
     "closed_segment a b = (\<lambda>u. (1 - u) *\<^sub>R a + u *\<^sub>R b) ` {0..1}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   632
  by (auto simp: set_eq_iff image_iff closed_segment_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   633
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   634
lemma open_segment_image_interval:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   635
     "open_segment a b = (if a=b then {} else (\<lambda>u. (1 - u) *\<^sub>R a + u *\<^sub>R b) ` {0<..<1})"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   636
  by (auto simp:  open_segment_def closed_segment_def segment_degen_0 segment_degen_1)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   637
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   638
lemmas segment_image_interval = closed_segment_image_interval open_segment_image_interval
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   639
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   640
lemma closed_segment_neq_empty [simp]: "closed_segment a b \<noteq> {}"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   641
  by auto
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   642
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   643
lemma open_segment_eq_empty [simp]: "open_segment a b = {} \<longleftrightarrow> a = b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   644
  by (simp add: segment_image_interval(2))
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   645
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   646
lemma open_segment_eq_empty' [simp]: "{} = open_segment a b \<longleftrightarrow> a = b"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   647
  using open_segment_eq_empty by blast
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   648
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   649
lemmas segment_eq_empty = closed_segment_neq_empty open_segment_eq_empty
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   650
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   651
lemma inj_segment:
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   652
  fixes a :: "'a :: real_vector"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   653
  assumes "a \<noteq> b"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   654
    shows "inj_on (\<lambda>u. (1 - u) *\<^sub>R a + u *\<^sub>R b) I"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   655
proof
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   656
  fix x y
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   657
  assume "(1 - x) *\<^sub>R a + x *\<^sub>R b = (1 - y) *\<^sub>R a + y *\<^sub>R b"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   658
  then have "x *\<^sub>R (b - a) = y *\<^sub>R (b - a)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   659
    by (simp add: algebra_simps)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   660
  with assms show "x = y"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   661
    by (simp add: real_vector.scale_right_imp_eq)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   662
qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   663
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   664
lemma finite_closed_segment [simp]: "finite(closed_segment a b) \<longleftrightarrow> a = b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   665
  using infinite_Icc [OF zero_less_one] finite_imageD [OF _ inj_segment [of a b]]
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   666
  unfolding segment_image_interval
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   667
  by (smt (verit, del_insts) finite.emptyI finite_insert finite_subset image_subset_iff insertCI segment_degen_0)
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   668
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   669
lemma finite_open_segment [simp]: "finite(open_segment a b) \<longleftrightarrow> a = b"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   670
  by (auto simp: open_segment_def)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   671
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   672
lemmas finite_segment = finite_closed_segment finite_open_segment
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   673
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   674
lemma closed_segment_eq_sing: "closed_segment a b = {c} \<longleftrightarrow> a = c \<and> b = c"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   675
  by auto
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   676
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   677
lemma open_segment_eq_sing: "open_segment a b \<noteq> {c}"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   678
  by (metis finite_insert finite_open_segment insert_not_empty open_segment_image_interval)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   679
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   680
lemmas segment_eq_sing = closed_segment_eq_sing open_segment_eq_sing
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   681
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   682
lemma compact_segment [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   683
  fixes a :: "'a::real_normed_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   684
  shows "compact (closed_segment a b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   685
  by (auto simp: segment_image_interval intro!: compact_continuous_image continuous_intros)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   686
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   687
lemma closed_segment [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   688
  fixes a :: "'a::real_normed_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   689
  shows "closed (closed_segment a b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   690
  by (simp add: compact_imp_closed)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   691
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   692
lemma closure_closed_segment [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   693
  fixes a :: "'a::real_normed_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   694
  shows "closure(closed_segment a b) = closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   695
  by simp
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   696
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   697
lemma open_segment_bound:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   698
  assumes "x \<in> open_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   699
  shows "norm (x - a) < norm (b - a)" "norm (x - b) < norm (b - a)"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   700
  by (metis assms norm_minus_commute open_segment_bound1 open_segment_commute)+
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   701
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   702
lemma closure_open_segment [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   703
  "closure (open_segment a b) = (if a = b then {} else closed_segment a b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   704
    for a :: "'a::euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   705
proof (cases "a = b")
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   706
  case True
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   707
  then show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   708
    by simp
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   709
next
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   710
  case False
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   711
  have "closure ((\<lambda>u. u *\<^sub>R (b - a)) ` {0<..<1}) = (\<lambda>u. u *\<^sub>R (b - a)) ` closure {0<..<1}"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   712
  proof (rule closure_injective_linear_image [symmetric])
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   713
  qed (use False in \<open>auto intro!: injI\<close>)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   714
  then have "closure
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   715
     ((\<lambda>u. (1 - u) *\<^sub>R a + u *\<^sub>R b) ` {0<..<1}) = (\<lambda>x. (1 - x) *\<^sub>R a + x *\<^sub>R b) ` closure {0<..<1}"
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   716
    using closure_translation [of a "((\<lambda>x. x *\<^sub>R b - x *\<^sub>R a) ` {0<..<1})"]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   717
    by (simp add: segment_eq_compose field_simps scaleR_diff_left scaleR_diff_right image_image)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   718
  then show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   719
    by (simp add: segment_image_interval closure_greaterThanLessThan [symmetric] del: closure_greaterThanLessThan)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   720
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   721
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   722
lemma closed_open_segment_iff [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   723
    fixes a :: "'a::euclidean_space"  shows "closed(open_segment a b) \<longleftrightarrow> a = b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   724
  by (metis open_segment_def DiffE closure_eq closure_open_segment ends_in_segment(1) insert_iff segment_image_interval(2))
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   725
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   726
lemma compact_open_segment_iff [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   727
    fixes a :: "'a::euclidean_space"  shows "compact(open_segment a b) \<longleftrightarrow> a = b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   728
  by (simp add: bounded_open_segment compact_eq_bounded_closed)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   729
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   730
lemma convex_closed_segment [iff]: "convex (closed_segment a b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   731
  unfolding segment_convex_hull by(rule convex_convex_hull)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   732
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   733
lemma convex_open_segment [iff]: "convex (open_segment a b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   734
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   735
  have "convex ((\<lambda>u. u *\<^sub>R (b - a)) ` {0<..<1})"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   736
    by (rule convex_linear_image) auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   737
  then have "convex ((+) a ` (\<lambda>u. u *\<^sub>R (b - a)) ` {0<..<1})"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   738
    by (rule convex_translation)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   739
  then show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   740
    by (simp add: image_image open_segment_image_interval segment_eq_compose field_simps scaleR_diff_left scaleR_diff_right)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   741
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   742
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   743
lemmas convex_segment = convex_closed_segment convex_open_segment
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   744
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   745
lemma subset_closed_segment:
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   746
    "closed_segment a b \<subseteq> closed_segment c d \<longleftrightarrow>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   747
     a \<in> closed_segment c d \<and> b \<in> closed_segment c d"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   748
  using closed_segment_subset convex_closed_segment ends_in_segment in_mono by blast
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   749
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   750
lemma subset_co_segment:
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   751
  "closed_segment a b \<subseteq> open_segment c d \<longleftrightarrow>
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   752
     a \<in> open_segment c d \<and> b \<in> open_segment c d"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   753
  using closed_segment_subset by blast
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   754
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   755
lemma subset_open_segment:
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   756
  fixes a :: "'a::euclidean_space"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   757
  shows "open_segment a b \<subseteq> open_segment c d \<longleftrightarrow>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   758
         a = b \<or> a \<in> closed_segment c d \<and> b \<in> closed_segment c d"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   759
        (is "?lhs = ?rhs")
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   760
proof (cases "a = b")
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   761
  case True then show ?thesis by simp
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   762
next
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   763
  case False show ?thesis
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   764
  proof
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   765
    assume rhs: ?rhs
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   766
    with \<open>a \<noteq> b\<close> have "c \<noteq> d"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   767
      using closed_segment_idem singleton_iff by auto
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   768
    have "\<exists>uc. (1 - u) *\<^sub>R ((1 - ua) *\<^sub>R c + ua *\<^sub>R d) + u *\<^sub>R ((1 - ub) *\<^sub>R c + ub *\<^sub>R d) =
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   769
               (1 - uc) *\<^sub>R c + uc *\<^sub>R d \<and> 0 < uc \<and> uc < 1"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   770
        if neq: "(1 - ua) *\<^sub>R c + ua *\<^sub>R d \<noteq> (1 - ub) *\<^sub>R c + ub *\<^sub>R d" "c \<noteq> d"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   771
           and "a = (1 - ua) *\<^sub>R c + ua *\<^sub>R d" "b = (1 - ub) *\<^sub>R c + ub *\<^sub>R d"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   772
           and u: "0 < u" "u < 1" and uab: "0 \<le> ua" "ua \<le> 1" "0 \<le> ub" "ub \<le> 1"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   773
        for u ua ub
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   774
    proof -
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   775
      have "ua \<noteq> ub"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   776
        using neq by auto
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   777
      moreover have "(u - 1) * ua \<le> 0" using u uab
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   778
        by (simp add: mult_nonpos_nonneg)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   779
      ultimately have lt: "(u - 1) * ua < u * ub" using u uab
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   780
        by (metis antisym_conv diff_ge_0_iff_ge le_less_trans mult_eq_0_iff mult_le_0_iff not_less)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   781
      have "p * ua + q * ub < p+q" if p: "0 < p" and  q: "0 < q" for p q
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   782
      proof -
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   783
        have "\<not> p \<le> 0" "\<not> q \<le> 0"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   784
          using p q not_less by blast+
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   785
        then show ?thesis
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   786
          by (smt (verit) \<open>ua \<noteq> ub\<close> mult_cancel_left1 mult_left_le uab(2) uab(4))
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   787
      qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   788
      then have "(1 - u) * ua + u * ub < 1" using u \<open>ua \<noteq> ub\<close>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   789
        by (metis diff_add_cancel diff_gt_0_iff_gt)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   790
      with lt show ?thesis
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   791
        by (rule_tac x="ua + u*(ub-ua)" in exI) (simp add: algebra_simps)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   792
    qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   793
    with rhs \<open>a \<noteq> b\<close> \<open>c \<noteq> d\<close> show ?lhs
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   794
      unfolding open_segment_image_interval closed_segment_def
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   795
      by (fastforce simp add:)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   796
  next
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   797
    assume lhs: ?lhs
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   798
    with \<open>a \<noteq> b\<close> have "c \<noteq> d"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   799
      by (meson finite_open_segment rev_finite_subset)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   800
    have "closure (open_segment a b) \<subseteq> closure (open_segment c d)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   801
      using lhs closure_mono by blast
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   802
    then have "closed_segment a b \<subseteq> closed_segment c d"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   803
      by (simp add: \<open>a \<noteq> b\<close> \<open>c \<noteq> d\<close>)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   804
    then show ?rhs
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   805
      by (force simp: \<open>a \<noteq> b\<close>)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   806
  qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   807
qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   808
77140
9a60c1759543 Lots more new material thanks to Manuel Eberl
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
   809
lemma closed_segment_same_fst:
9a60c1759543 Lots more new material thanks to Manuel Eberl
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
   810
  "fst a = fst b \<Longrightarrow> closed_segment a b = {fst a} \<times> closed_segment (snd a) (snd b)"
9a60c1759543 Lots more new material thanks to Manuel Eberl
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
   811
  by (auto simp: closed_segment_def scaleR_prod_def)
9a60c1759543 Lots more new material thanks to Manuel Eberl
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
   812
9a60c1759543 Lots more new material thanks to Manuel Eberl
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
   813
lemma closed_segment_same_snd:
9a60c1759543 Lots more new material thanks to Manuel Eberl
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
   814
  "snd a = snd b \<Longrightarrow> closed_segment a b = closed_segment (fst a) (fst b) \<times> {snd a}"
9a60c1759543 Lots more new material thanks to Manuel Eberl
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
   815
  by (auto simp: closed_segment_def scaleR_prod_def)
9a60c1759543 Lots more new material thanks to Manuel Eberl
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
   816
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   817
lemma subset_oc_segment:
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   818
  fixes a :: "'a::euclidean_space"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   819
  shows "open_segment a b \<subseteq> closed_segment c d \<longleftrightarrow>
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   820
         a = b \<or> a \<in> closed_segment c d \<and> b \<in> closed_segment c d" 
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   821
    (is "?lhs = ?rhs")
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   822
proof
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   823
  show "?lhs \<Longrightarrow> ?rhs"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   824
    by (metis closure_closed_segment closure_mono closure_open_segment subset_closed_segment)
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   825
  show "?rhs \<Longrightarrow> ?lhs"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   826
    by (meson dual_order.trans segment_open_subset_closed subset_open_segment)
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   827
qed
71230
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   828
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   829
lemmas subset_segment = subset_closed_segment subset_co_segment subset_oc_segment subset_open_segment
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   830
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   831
lemma dist_half_times2:
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   832
  fixes a :: "'a :: real_normed_vector"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   833
  shows "dist ((1 / 2) *\<^sub>R (a + b)) x * 2 = dist (a+b) (2 *\<^sub>R x)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   834
proof -
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   835
  have "norm ((1 / 2) *\<^sub>R (a + b) - x) * 2 = norm (2 *\<^sub>R ((1 / 2) *\<^sub>R (a + b) - x))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   836
    by simp
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   837
  also have "... = norm ((a + b) - 2 *\<^sub>R x)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   838
    by (simp add: real_vector.scale_right_diff_distrib)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   839
  finally show ?thesis
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   840
    by (simp only: dist_norm)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   841
qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   842
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   843
lemma closed_segment_as_ball:
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   844
    "closed_segment a b = affine hull {a,b} \<inter> cball(inverse 2 *\<^sub>R (a + b))(norm(b - a) / 2)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   845
proof (cases "b = a")
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   846
  case True then show ?thesis by (auto simp: hull_inc)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   847
next
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   848
  case False
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   849
  then have *: "((\<exists>u v. x = u *\<^sub>R a + v *\<^sub>R b \<and> u + v = 1) \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   850
                  dist ((1 / 2) *\<^sub>R (a + b)) x * 2 \<le> norm (b - a)) =
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   851
                 (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and> 0 \<le> u \<and> u \<le> 1)" for x
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   852
  proof -
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   853
    have "((\<exists>u v. x = u *\<^sub>R a + v *\<^sub>R b \<and> u + v = 1) \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   854
                  dist ((1 / 2) *\<^sub>R (a + b)) x * 2 \<le> norm (b - a)) =
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   855
          ((\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b) \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   856
                  dist ((1 / 2) *\<^sub>R (a + b)) x * 2 \<le> norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   857
      unfolding eq_diff_eq [symmetric] by simp
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   858
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   859
                          norm ((a+b) - (2 *\<^sub>R x)) \<le> norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   860
      by (simp add: dist_half_times2) (simp add: dist_norm)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   861
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   862
            norm ((a+b) - (2 *\<^sub>R ((1 - u) *\<^sub>R a + u *\<^sub>R b))) \<le> norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   863
      by auto
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   864
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   865
                norm ((1 - u * 2) *\<^sub>R (b - a)) \<le> norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   866
      by (simp add: algebra_simps scaleR_2)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   867
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   868
                          \<bar>1 - u * 2\<bar> * norm (b - a) \<le> norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   869
      by simp
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   870
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and> \<bar>1 - u * 2\<bar> \<le> 1)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   871
      by (simp add: mult_le_cancel_right2 False)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   872
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and> 0 \<le> u \<and> u \<le> 1)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   873
      by auto
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   874
    finally show ?thesis .
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   875
  qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   876
  show ?thesis
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   877
    by (simp add: affine_hull_2 Set.set_eq_iff closed_segment_def *)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   878
qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   879
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   880
lemma open_segment_as_ball:
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   881
    "open_segment a b =
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   882
     affine hull {a,b} \<inter> ball(inverse 2 *\<^sub>R (a + b))(norm(b - a) / 2)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   883
proof (cases "b = a")
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   884
  case True then show ?thesis by (auto simp: hull_inc)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   885
next
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   886
  case False
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   887
  then have *: "((\<exists>u v. x = u *\<^sub>R a + v *\<^sub>R b \<and> u + v = 1) \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   888
                  dist ((1 / 2) *\<^sub>R (a + b)) x * 2 < norm (b - a)) =
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   889
                 (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and> 0 < u \<and> u < 1)" for x
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   890
  proof -
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   891
    have "((\<exists>u v. x = u *\<^sub>R a + v *\<^sub>R b \<and> u + v = 1) \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   892
                  dist ((1 / 2) *\<^sub>R (a + b)) x * 2 < norm (b - a)) =
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   893
          ((\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b) \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   894
                  dist ((1 / 2) *\<^sub>R (a + b)) x * 2 < norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   895
      unfolding eq_diff_eq [symmetric] by simp
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   896
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   897
                          norm ((a+b) - (2 *\<^sub>R x)) < norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   898
      by (simp add: dist_half_times2) (simp add: dist_norm)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   899
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   900
            norm ((a+b) - (2 *\<^sub>R ((1 - u) *\<^sub>R a + u *\<^sub>R b))) < norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   901
      by auto
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   902
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   903
                norm ((1 - u * 2) *\<^sub>R (b - a)) < norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   904
      by (simp add: algebra_simps scaleR_2)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   905
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and>
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   906
                          \<bar>1 - u * 2\<bar> * norm (b - a) < norm (b - a))"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   907
      by simp
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   908
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and> \<bar>1 - u * 2\<bar> < 1)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   909
      by (simp add: mult_le_cancel_right2 False)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   910
    also have "... = (\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and> 0 < u \<and> u < 1)"
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   911
      by auto
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   912
    finally show ?thesis .
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   913
  qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   914
  show ?thesis
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   915
    using False by (force simp: affine_hull_2 Set.set_eq_iff open_segment_image_interval *)
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   916
qed
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   917
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   918
lemmas segment_as_ball = closed_segment_as_ball open_segment_as_ball
095cf95d7725 moved segment lemmas where they belong
nipkow
parents: 71189
diff changeset
   919
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   920
lemma connected_segment [iff]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   921
  fixes x :: "'a :: real_normed_vector"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   922
  shows "connected (closed_segment x y)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   923
  by (simp add: convex_connected)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   924
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   925
lemma is_interval_closed_segment_1[intro, simp]: "is_interval (closed_segment a b)" for a b::real
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   926
  unfolding closed_segment_eq_real_ivl
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   927
  by (auto simp: is_interval_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   928
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   929
lemma IVT'_closed_segment_real:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   930
  fixes f :: "real \<Rightarrow> real"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   931
  assumes "y \<in> closed_segment (f a) (f b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   932
  assumes "continuous_on (closed_segment a b) f"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   933
  shows "\<exists>x \<in> closed_segment a b. f x = y"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   934
  using IVT'[of f a y b]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   935
    IVT'[of "-f" a "-y" b]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   936
    IVT'[of f b y a]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   937
    IVT'[of "-f" b "-y" a] assms
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   938
  by (cases "a \<le> b"; cases "f b \<ge> f a") (auto simp: closed_segment_eq_real_ivl continuous_on_minus)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   939
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   940
subsection \<open>Betweenness\<close>
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   941
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   942
definition\<^marker>\<open>tag important\<close> "between = (\<lambda>(a,b) x. x \<in> closed_segment a b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   943
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   944
lemma betweenI:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   945
  assumes "0 \<le> u" "u \<le> 1" "x = (1 - u) *\<^sub>R a + u *\<^sub>R b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   946
  shows "between (a, b) x"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   947
  using assms unfolding between_def closed_segment_def by auto
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   948
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   949
lemma betweenE:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   950
  assumes "between (a, b) x"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   951
  obtains u where "0 \<le> u" "u \<le> 1" "x = (1 - u) *\<^sub>R a + u *\<^sub>R b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   952
  using assms unfolding between_def closed_segment_def by auto
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   953
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   954
lemma between_implies_scaled_diff:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   955
  assumes "between (S, T) X" "between (S, T) Y" "S \<noteq> Y"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   956
  obtains c where "(X - Y) = c *\<^sub>R (S - Y)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   957
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   958
  from \<open>between (S, T) X\<close> obtain u\<^sub>X where X: "X = u\<^sub>X *\<^sub>R S + (1 - u\<^sub>X) *\<^sub>R T"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   959
    by (metis add.commute betweenE eq_diff_eq)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   960
  from \<open>between (S, T) Y\<close> obtain u\<^sub>Y where Y: "Y = u\<^sub>Y *\<^sub>R S + (1 - u\<^sub>Y) *\<^sub>R T"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   961
    by (metis add.commute betweenE eq_diff_eq)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   962
  have "X - Y = (u\<^sub>X - u\<^sub>Y) *\<^sub>R (S - T)"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
   963
    by (simp add: X Y scaleR_left.diff scaleR_right_diff_distrib)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   964
  moreover from Y have "S - Y = (1 - u\<^sub>Y) *\<^sub>R (S - T)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   965
    by (simp add: real_vector.scale_left_diff_distrib real_vector.scale_right_diff_distrib)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   966
  moreover note \<open>S \<noteq> Y\<close>
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   967
  ultimately have "(X - Y) = ((u\<^sub>X - u\<^sub>Y) / (1 - u\<^sub>Y)) *\<^sub>R (S - Y)" by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   968
  from this that show thesis by blast
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   969
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   970
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   971
lemma between_mem_segment: "between (a,b) x \<longleftrightarrow> x \<in> closed_segment a b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   972
  unfolding between_def by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   973
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   974
lemma between: "between (a, b) (x::'a::euclidean_space) \<longleftrightarrow> dist a b = (dist a x) + (dist x b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   975
proof (cases "a = b")
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   976
  case True
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   977
  then show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   978
    by (auto simp add: between_def dist_commute)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   979
next
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   980
  case False
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   981
  then have Fal: "norm (a - b) \<noteq> 0" and Fal2: "norm (a - b) > 0"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   982
    by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   983
  have *: "\<And>u. a - ((1 - u) *\<^sub>R a + u *\<^sub>R b) = u *\<^sub>R (a - b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   984
    by (auto simp add: algebra_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   985
  have "norm (a - x) *\<^sub>R (x - b) = norm (x - b) *\<^sub>R (a - x)" if "x = (1 - u) *\<^sub>R a + u *\<^sub>R b" "0 \<le> u" "u \<le> 1" for u
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   986
  proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   987
    have *: "a - x = u *\<^sub>R (a - b)" "x - b = (1 - u) *\<^sub>R (a - b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   988
      unfolding that(1) by (auto simp add:algebra_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   989
    show "norm (a - x) *\<^sub>R (x - b) = norm (x - b) *\<^sub>R (a - x)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   990
      unfolding norm_minus_commute[of x a] * using \<open>0 \<le> u\<close> \<open>u \<le> 1\<close>
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   991
      by simp
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   992
  qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   993
  moreover have "\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and> 0 \<le> u \<and> u \<le> 1" if "dist a b = dist a x + dist x b" 
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   994
  proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   995
    let ?\<beta> = "norm (a - x) / norm (a - b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   996
    show "\<exists>u. x = (1 - u) *\<^sub>R a + u *\<^sub>R b \<and> 0 \<le> u \<and> u \<le> 1"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   997
    proof (intro exI conjI)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   998
      show "?\<beta> \<le> 1"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
   999
        using Fal2 unfolding that[unfolded dist_norm] norm_ge_zero by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1000
      show "x = (1 - ?\<beta>) *\<^sub>R a + (?\<beta>) *\<^sub>R b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1001
      proof (subst euclidean_eq_iff; intro ballI)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1002
        fix i :: 'a
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1003
        assume i: "i \<in> Basis"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1004
        have "((1 - ?\<beta>) *\<^sub>R a + (?\<beta>) *\<^sub>R b) \<bullet> i 
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1005
              = ((norm (a - b) - norm (a - x)) * (a \<bullet> i) + norm (a - x) * (b \<bullet> i)) / norm (a - b)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1006
          using Fal by (auto simp add: field_simps inner_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1007
        also have "\<dots> = x\<bullet>i"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1008
          apply (rule divide_eq_imp[OF Fal])
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1009
          unfolding that[unfolded dist_norm]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1010
          using that[unfolded dist_triangle_eq] i
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1011
          apply (subst (asm) euclidean_eq_iff)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1012
           apply (auto simp add: field_simps inner_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1013
          done
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1014
        finally show "x \<bullet> i = ((1 - ?\<beta>) *\<^sub>R a + (?\<beta>) *\<^sub>R b) \<bullet> i"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1015
          by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1016
      qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1017
    qed (use Fal2 in auto)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1018
  qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1019
  ultimately show ?thesis
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1020
    by (force simp add: between_def closed_segment_def dist_triangle_eq)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1021
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1022
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1023
lemma between_midpoint:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1024
  fixes a :: "'a::euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1025
  shows "between (a,b) (midpoint a b)" (is ?t1)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1026
    and "between (b,a) (midpoint a b)" (is ?t2)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1027
proof -
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1028
  have *: "\<And>x y z. x = (1/2::real) *\<^sub>R z \<Longrightarrow> y = (1/2) *\<^sub>R z \<Longrightarrow> norm z = norm x + norm y"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1029
    by auto
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1030
  show ?t1 ?t2
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1031
    unfolding between midpoint_def dist_norm
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1032
    by (auto simp add: field_simps inner_simps euclidean_eq_iff[where 'a='a] intro!: *)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1033
qed
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1034
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1035
lemma between_mem_convex_hull:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1036
  "between (a,b) x \<longleftrightarrow> x \<in> convex hull {a,b}"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1037
  unfolding between_mem_segment segment_convex_hull ..
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1038
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1039
lemma between_triv_iff [simp]: "between (a,a) b \<longleftrightarrow> a=b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1040
  by (auto simp: between_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1041
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1042
lemma between_triv1 [simp]: "between (a,b) a"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1043
  by (auto simp: between_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1044
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1045
lemma between_triv2 [simp]: "between (a,b) b"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1046
  by (auto simp: between_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1047
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1048
lemma between_commute:
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
  1049
  "between (a,b) = between (b,a)"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
  1050
  by (auto simp: between_def closed_segment_commute)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1051
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1052
lemma between_antisym:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1053
  fixes a :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1054
  shows "\<lbrakk>between (b,c) a; between (a,c) b\<rbrakk> \<Longrightarrow> a = b"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
  1055
  by (auto simp: between dist_commute)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1056
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1057
lemma between_trans:
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
  1058
  fixes a :: "'a :: euclidean_space"
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
  1059
  shows "\<lbrakk>between (b,c) a; between (a,c) d\<rbrakk> \<Longrightarrow> between (b,c) d"
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1060
  using dist_triangle2 [of b c d] dist_triangle3 [of b d a]
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1061
  by (auto simp: between dist_commute)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1062
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1063
lemma between_norm:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1064
    fixes a :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1065
    shows "between (a,b) x \<longleftrightarrow> norm(x - a) *\<^sub>R (b - x) = norm(b - x) *\<^sub>R (x - a)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1066
  by (auto simp: between dist_triangle_eq norm_minus_commute algebra_simps)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1067
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1068
lemma between_swap:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1069
  fixes A B X Y :: "'a::euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1070
  assumes "between (A, B) X"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1071
  assumes "between (A, B) Y"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1072
  shows "between (X, B) Y \<longleftrightarrow> between (A, Y) X"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
  1073
  using assms by (auto simp add: between)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1074
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1075
lemma between_translation [simp]: "between (a + y,a + z) (a + x) \<longleftrightarrow> between (y,z) x"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1076
  by (auto simp: between_def)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1077
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1078
lemma between_trans_2:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1079
  fixes a :: "'a :: euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1080
  shows "\<lbrakk>between (b,c) a; between (a,b) d\<rbrakk> \<Longrightarrow> between (c,d) a"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1081
  by (metis between_commute between_swap between_trans)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1082
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1083
lemma between_scaleR_lift [simp]:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1084
  fixes v :: "'a::euclidean_space"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1085
  shows "between (a *\<^sub>R v, b *\<^sub>R v) (c *\<^sub>R v) \<longleftrightarrow> v = 0 \<or> between (a, b) c"
78477
37abfe400ae6 Removal of ugly old proofs
paulson <lp15@cam.ac.uk>
parents: 77140
diff changeset
  1086
  by (simp add: between dist_norm flip: scaleR_left_diff_distrib distrib_right)
71028
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1087
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1088
lemma between_1:
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1089
  fixes x::real
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1090
  shows "between (a,b) x \<longleftrightarrow> (a \<le> x \<and> x \<le> b) \<or> (b \<le> x \<and> x \<le> a)"
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1091
  by (auto simp: between_mem_segment closed_segment_eq_real_ivl)
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1092
c2465b429e6e Line_Segment is independent of Convex_Euclidean_Space
immler
parents:
diff changeset
  1093
end