2015-09-13 01:45:47 +00:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2015 Jeremy Avigad. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
2015-09-21 00:51:28 +00:00
|
|
|
|
Authors: Jeremy Avigad, Robert Y. Lewis
|
2015-09-13 01:45:47 +00:00
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
Instantiates the reals as a Banach space.
|
2015-09-13 01:45:47 +00:00
|
|
|
|
-/
|
2016-01-15 04:57:27 +00:00
|
|
|
|
import .metric_space data.real.complete data.set .normed_space
|
2016-05-19 01:21:49 +00:00
|
|
|
|
open real classical analysis nat topology
|
2015-09-13 01:45:47 +00:00
|
|
|
|
noncomputable theory
|
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
/- sup and inf -/
|
2015-09-21 00:51:28 +00:00
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
-- Expresses completeness, sup, and inf in a manner that is less constructive, but more convenient,
|
|
|
|
|
-- than the way it is done in data.real.complete.
|
2015-09-13 01:45:47 +00:00
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
-- Issue: real.sup and real.inf conflict with sup and inf in lattice.
|
|
|
|
|
-- Perhaps put algebra sup and inf into a namespace?
|
2015-12-22 18:25:38 +00:00
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
namespace real
|
2015-09-13 01:45:47 +00:00
|
|
|
|
open set
|
|
|
|
|
|
|
|
|
|
private definition exists_is_sup {X : set ℝ} (H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → x ≤ b)) :
|
|
|
|
|
∃ y, is_sup X y :=
|
|
|
|
|
let x := some (and.left H), b := some (and.right H) in
|
|
|
|
|
exists_is_sup_of_inh_of_bdd X x (some_spec (and.left H)) b (some_spec (and.right H))
|
|
|
|
|
|
|
|
|
|
private definition sup_aux {X : set ℝ} (H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → x ≤ b)) :=
|
|
|
|
|
some (exists_is_sup H)
|
|
|
|
|
|
|
|
|
|
private definition sup_aux_spec {X : set ℝ} (H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → x ≤ b)) :
|
|
|
|
|
is_sup X (sup_aux H) :=
|
|
|
|
|
some_spec (exists_is_sup H)
|
|
|
|
|
|
|
|
|
|
definition sup (X : set ℝ) : ℝ :=
|
|
|
|
|
if H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → x ≤ b) then sup_aux H else 0
|
|
|
|
|
|
|
|
|
|
proposition le_sup {x : ℝ} {X : set ℝ} (Hx : x ∈ X) {b : ℝ} (Hb : ∀ x, x ∈ X → x ≤ b) :
|
|
|
|
|
x ≤ sup X :=
|
|
|
|
|
have H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → x ≤ b),
|
|
|
|
|
from and.intro (exists.intro x Hx) (exists.intro b Hb),
|
2016-02-29 21:15:48 +00:00
|
|
|
|
by rewrite [↑sup, dif_pos H]; exact and.left (sup_aux_spec H) x Hx
|
2015-09-13 01:45:47 +00:00
|
|
|
|
|
|
|
|
|
proposition sup_le {X : set ℝ} (HX : ∃ x, x ∈ X) {b : ℝ} (Hb : ∀ x, x ∈ X → x ≤ b) :
|
|
|
|
|
sup X ≤ b :=
|
|
|
|
|
have H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → x ≤ b),
|
|
|
|
|
from and.intro HX (exists.intro b Hb),
|
2016-02-29 21:15:48 +00:00
|
|
|
|
by rewrite [↑sup, dif_pos H]; exact and.right (sup_aux_spec H) b Hb
|
2015-09-13 01:45:47 +00:00
|
|
|
|
|
2015-09-21 00:51:28 +00:00
|
|
|
|
proposition exists_mem_and_lt_of_lt_sup {X : set ℝ} (HX : ∃ x, x ∈ X) {b : ℝ} (Hb : b < sup X) :
|
|
|
|
|
∃ x, x ∈ X ∧ b < x :=
|
|
|
|
|
have ¬ ∀ x, x ∈ X → x ≤ b, from assume H, not_le_of_gt Hb (sup_le HX H),
|
|
|
|
|
obtain x (Hx : ¬ (x ∈ X → x ≤ b)), from exists_not_of_not_forall this,
|
|
|
|
|
exists.intro x
|
|
|
|
|
(have x ∈ X ∧ ¬ x ≤ b, by rewrite [-not_implies_iff_and_not]; apply Hx,
|
|
|
|
|
and.intro (and.left this) (lt_of_not_ge (and.right this)))
|
|
|
|
|
|
2015-09-13 01:45:47 +00:00
|
|
|
|
private definition exists_is_inf {X : set ℝ} (H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → b ≤ x)) :
|
|
|
|
|
∃ y, is_inf X y :=
|
|
|
|
|
let x := some (and.left H), b := some (and.right H) in
|
|
|
|
|
exists_is_inf_of_inh_of_bdd X x (some_spec (and.left H)) b (some_spec (and.right H))
|
|
|
|
|
|
|
|
|
|
private definition inf_aux {X : set ℝ} (H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → b ≤ x)) :=
|
|
|
|
|
some (exists_is_inf H)
|
|
|
|
|
|
|
|
|
|
private definition inf_aux_spec {X : set ℝ} (H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → b ≤ x)) :
|
|
|
|
|
is_inf X (inf_aux H) :=
|
|
|
|
|
some_spec (exists_is_inf H)
|
|
|
|
|
|
|
|
|
|
definition inf (X : set ℝ) : ℝ :=
|
|
|
|
|
if H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → b ≤ x) then inf_aux H else 0
|
|
|
|
|
|
|
|
|
|
proposition inf_le {x : ℝ} {X : set ℝ} (Hx : x ∈ X) {b : ℝ} (Hb : ∀ x, x ∈ X → b ≤ x) :
|
|
|
|
|
inf X ≤ x :=
|
|
|
|
|
have H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → b ≤ x),
|
|
|
|
|
from and.intro (exists.intro x Hx) (exists.intro b Hb),
|
2016-02-29 21:15:48 +00:00
|
|
|
|
by rewrite [↑inf, dif_pos H]; exact and.left (inf_aux_spec H) x Hx
|
2015-09-13 01:45:47 +00:00
|
|
|
|
|
|
|
|
|
proposition le_inf {X : set ℝ} (HX : ∃ x, x ∈ X) {b : ℝ} (Hb : ∀ x, x ∈ X → b ≤ x) :
|
|
|
|
|
b ≤ inf X :=
|
|
|
|
|
have H : (∃ x, x ∈ X) ∧ (∃ b, ∀ x, x ∈ X → b ≤ x),
|
|
|
|
|
from and.intro HX (exists.intro b Hb),
|
2016-02-29 21:15:48 +00:00
|
|
|
|
by rewrite [↑inf, dif_pos H]; exact and.right (inf_aux_spec H) b Hb
|
2015-09-13 01:45:47 +00:00
|
|
|
|
|
2015-09-21 00:51:28 +00:00
|
|
|
|
proposition exists_mem_and_lt_of_inf_lt {X : set ℝ} (HX : ∃ x, x ∈ X) {b : ℝ} (Hb : inf X < b) :
|
|
|
|
|
∃ x, x ∈ X ∧ x < b :=
|
|
|
|
|
have ¬ ∀ x, x ∈ X → b ≤ x, from assume H, not_le_of_gt Hb (le_inf HX H),
|
|
|
|
|
obtain x (Hx : ¬ (x ∈ X → b ≤ x)), from exists_not_of_not_forall this,
|
|
|
|
|
exists.intro x
|
|
|
|
|
(have x ∈ X ∧ ¬ b ≤ x, by rewrite [-not_implies_iff_and_not]; apply Hx,
|
|
|
|
|
and.intro (and.left this) (lt_of_not_ge (and.right this)))
|
|
|
|
|
|
2015-10-16 19:32:44 +00:00
|
|
|
|
section
|
2016-02-26 01:42:44 +00:00
|
|
|
|
local attribute mem [reducible]
|
2015-09-21 00:51:28 +00:00
|
|
|
|
-- TODO: is there a better place to put this?
|
2016-01-04 00:41:01 +00:00
|
|
|
|
proposition image_neg_eq (X : set ℝ) : (λ x, -x) ' X = {x | -x ∈ X} :=
|
2015-09-21 00:51:28 +00:00
|
|
|
|
set.ext (take x, iff.intro
|
|
|
|
|
(assume H, obtain y [(Hy₁ : y ∈ X) (Hy₂ : -y = x)], from H,
|
|
|
|
|
show -x ∈ X, by rewrite [-Hy₂, neg_neg]; exact Hy₁)
|
|
|
|
|
(assume H : -x ∈ X, exists.intro (-x) (and.intro H !neg_neg)))
|
|
|
|
|
|
|
|
|
|
proposition sup_neg {X : set ℝ} (nonempty_X : ∃ x, x ∈ X) {b : ℝ} (Hb : ∀ x, x ∈ X → b ≤ x) :
|
|
|
|
|
sup {x | -x ∈ X} = - inf X :=
|
|
|
|
|
let negX := {x | -x ∈ X} in
|
|
|
|
|
have nonempty_negX : ∃ x, x ∈ negX, from
|
|
|
|
|
obtain x Hx, from nonempty_X,
|
|
|
|
|
have -(-x) ∈ X,
|
|
|
|
|
by rewrite neg_neg; apply Hx,
|
|
|
|
|
exists.intro (-x) this,
|
|
|
|
|
have H₁ : ∀ x, x ∈ negX → x ≤ - inf X, from
|
|
|
|
|
take x,
|
|
|
|
|
assume H,
|
|
|
|
|
have inf X ≤ -x,
|
|
|
|
|
from inf_le H Hb,
|
|
|
|
|
show x ≤ - inf X,
|
|
|
|
|
from le_neg_of_le_neg this,
|
|
|
|
|
have H₂ : ∀ x, x ∈ X → -sup negX ≤ x, from
|
|
|
|
|
take x,
|
|
|
|
|
assume H,
|
|
|
|
|
have -(-x) ∈ X, by rewrite neg_neg; apply H,
|
|
|
|
|
have -x ≤ sup negX, from le_sup this H₁,
|
|
|
|
|
show -sup negX ≤ x,
|
|
|
|
|
from !neg_le_of_neg_le this,
|
|
|
|
|
eq_of_le_of_ge
|
|
|
|
|
(show sup negX ≤ - inf X,
|
|
|
|
|
from sup_le nonempty_negX H₁)
|
|
|
|
|
(show -inf X ≤ sup negX,
|
|
|
|
|
from !neg_le_of_neg_le (le_inf nonempty_X H₂))
|
|
|
|
|
|
|
|
|
|
proposition inf_neg {X : set ℝ} (nonempty_X : ∃ x, x ∈ X) {b : ℝ} (Hb : ∀ x, x ∈ X → x ≤ b) :
|
|
|
|
|
inf {x | -x ∈ X} = - sup X :=
|
|
|
|
|
let negX := {x | -x ∈ X} in
|
|
|
|
|
have nonempty_negX : ∃ x, x ∈ negX, from
|
|
|
|
|
obtain x Hx, from nonempty_X,
|
|
|
|
|
have -(-x) ∈ X,
|
|
|
|
|
by rewrite neg_neg; apply Hx,
|
|
|
|
|
exists.intro (-x) this,
|
|
|
|
|
have Hb' : ∀ x, x ∈ negX → -b ≤ x,
|
|
|
|
|
from take x, assume H, !neg_le_of_neg_le (Hb _ H),
|
|
|
|
|
have HX : X = {x | -x ∈ negX},
|
|
|
|
|
from set.ext (take x, by rewrite [↑set_of, ↑mem, +neg_neg]),
|
|
|
|
|
show inf {x | -x ∈ X} = - sup X,
|
2016-02-29 19:28:20 +00:00
|
|
|
|
by rewrite [HX at {2}, sup_neg nonempty_negX Hb', neg_neg]
|
2015-10-16 19:32:44 +00:00
|
|
|
|
end
|
2016-01-15 04:57:27 +00:00
|
|
|
|
end real
|
|
|
|
|
|
|
|
|
|
/- the reals form a complete metric space -/
|
|
|
|
|
|
|
|
|
|
namespace analysis
|
|
|
|
|
|
|
|
|
|
theorem dist_eq_abs (x y : real) : dist x y = abs (x - y) := rfl
|
|
|
|
|
|
|
|
|
|
proposition converges_to_seq_real_intro {X : ℕ → ℝ} {y : ℝ}
|
|
|
|
|
(H : ∀ ⦃ε : ℝ⦄, ε > 0 → ∃ N : ℕ, ∀ {n}, n ≥ N → abs (X n - y) < ε) :
|
2016-05-19 01:21:49 +00:00
|
|
|
|
(X ⟶ y [at ∞]) := approaches_at_infty_intro H
|
2016-01-15 04:57:27 +00:00
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
proposition converges_to_seq_real_elim {X : ℕ → ℝ} {y : ℝ} (H : X ⟶ y [at ∞]) :
|
|
|
|
|
∀ ⦃ε : ℝ⦄, ε > 0 → ∃ N : ℕ, ∀ {n}, n ≥ N → abs (X n - y) < ε := approaches_at_infty_dest H
|
2016-01-15 04:57:27 +00:00
|
|
|
|
|
|
|
|
|
proposition converges_to_seq_real_intro' {X : ℕ → ℝ} {y : ℝ}
|
|
|
|
|
(H : ∀ ⦃ε : ℝ⦄, ε > 0 → ∃ N : ℕ, ∀ {n}, n ≥ N → abs (X n - y) ≤ ε) :
|
2016-05-19 01:21:49 +00:00
|
|
|
|
(X ⟶ y [at ∞]) :=
|
|
|
|
|
approaches_at_infty_intro' H
|
2016-01-15 04:57:27 +00:00
|
|
|
|
|
|
|
|
|
open pnat subtype
|
|
|
|
|
local postfix ⁻¹ := pnat.inv
|
|
|
|
|
|
|
|
|
|
private definition pnat.succ (n : ℕ) : ℕ+ := tag (succ n) !succ_pos
|
|
|
|
|
|
|
|
|
|
private definition r_seq_of (X : ℕ → ℝ) : r_seq := λ n, X (elt_of n)
|
|
|
|
|
|
|
|
|
|
private lemma rate_of_cauchy_aux {X : ℕ → ℝ} (H : cauchy X) :
|
|
|
|
|
∀ k : ℕ+, ∃ N : ℕ+, ∀ m n : ℕ+,
|
|
|
|
|
m ≥ N → n ≥ N → abs (X (elt_of m) - X (elt_of n)) ≤ of_rat k⁻¹ :=
|
|
|
|
|
take k : ℕ+,
|
|
|
|
|
have H1 : (k⁻¹ >[rat] (rat.of_num 0)), from !pnat.inv_pos,
|
|
|
|
|
have H2 : (of_rat k⁻¹ > of_rat (rat.of_num 0)), from !of_rat_lt_of_rat_of_lt H1,
|
|
|
|
|
obtain (N : ℕ) (H : ∀ m n, m ≥ N → n ≥ N → abs (X m - X n) < of_rat k⁻¹), from H _ H2,
|
|
|
|
|
exists.intro (pnat.succ N)
|
|
|
|
|
(take m n : ℕ+,
|
|
|
|
|
assume Hm : m ≥ (pnat.succ N),
|
|
|
|
|
assume Hn : n ≥ (pnat.succ N),
|
|
|
|
|
have Hm' : elt_of m ≥ N, begin apply le.trans, apply le_succ, apply Hm end,
|
|
|
|
|
have Hn' : elt_of n ≥ N, begin apply le.trans, apply le_succ, apply Hn end,
|
|
|
|
|
show abs (X (elt_of m) - X (elt_of n)) ≤ of_rat k⁻¹, from le_of_lt (H _ _ Hm' Hn'))
|
|
|
|
|
|
|
|
|
|
private definition rate_of_cauchy {X : ℕ → ℝ} (H : cauchy X) (k : ℕ+) : ℕ+ :=
|
|
|
|
|
some (rate_of_cauchy_aux H k)
|
|
|
|
|
|
|
|
|
|
private lemma cauchy_with_rate_of_cauchy {X : ℕ → ℝ} (H : cauchy X) :
|
|
|
|
|
cauchy_with_rate (r_seq_of X) (rate_of_cauchy H) :=
|
|
|
|
|
take k : ℕ+,
|
|
|
|
|
some_spec (rate_of_cauchy_aux H k)
|
|
|
|
|
|
|
|
|
|
private lemma converges_to_with_rate_of_cauchy {X : ℕ → ℝ} (H : cauchy X) :
|
|
|
|
|
∃ l Nb, converges_to_with_rate (r_seq_of X) l Nb :=
|
|
|
|
|
begin
|
|
|
|
|
apply exists.intro,
|
|
|
|
|
apply exists.intro,
|
|
|
|
|
apply converges_to_with_rate_of_cauchy_with_rate,
|
|
|
|
|
exact cauchy_with_rate_of_cauchy H
|
2015-09-21 00:51:28 +00:00
|
|
|
|
end
|
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
theorem converges_seq_of_cauchy {X : ℕ → ℝ} (H : cauchy X) : converges_seq X :=
|
|
|
|
|
obtain l Nb (conv : converges_to_with_rate (r_seq_of X) l Nb),
|
|
|
|
|
from converges_to_with_rate_of_cauchy H,
|
|
|
|
|
exists.intro l
|
2016-05-19 01:21:49 +00:00
|
|
|
|
(approaches_at_infty_intro
|
|
|
|
|
take ε : ℝ,
|
2016-01-15 04:57:27 +00:00
|
|
|
|
suppose ε > 0,
|
|
|
|
|
obtain (k' : ℕ) (Hn : 1 / succ k' < ε), from archimedean_small `ε > 0`,
|
|
|
|
|
let k : ℕ+ := tag (succ k') !succ_pos,
|
|
|
|
|
N : ℕ+ := Nb k in
|
|
|
|
|
have Hk : real.of_rat k⁻¹ < ε,
|
|
|
|
|
by rewrite [↑pnat.inv, of_rat_divide]; exact Hn,
|
|
|
|
|
exists.intro (elt_of N)
|
|
|
|
|
(take n : ℕ,
|
|
|
|
|
assume Hn : n ≥ elt_of N,
|
|
|
|
|
let n' : ℕ+ := tag n (nat.lt_of_lt_of_le (has_property N) Hn) in
|
|
|
|
|
have abs (X n - l) ≤ real.of_rat k⁻¹, by apply conv k n' Hn,
|
|
|
|
|
show abs (X n - l) < ε, from lt_of_le_of_lt this Hk))
|
|
|
|
|
|
|
|
|
|
end analysis
|
|
|
|
|
|
2016-02-25 22:30:00 +00:00
|
|
|
|
definition complete_metric_space_real [trans_instance] :
|
2016-01-15 04:57:27 +00:00
|
|
|
|
complete_metric_space ℝ :=
|
|
|
|
|
⦃complete_metric_space, metric_space_real,
|
|
|
|
|
complete := @analysis.converges_seq_of_cauchy
|
|
|
|
|
⦄
|
|
|
|
|
|
|
|
|
|
/- the real numbers can be viewed as a banach space -/
|
|
|
|
|
|
|
|
|
|
definition real_vector_space_real : real_vector_space ℝ :=
|
|
|
|
|
⦃ real_vector_space, real.discrete_linear_ordered_field,
|
|
|
|
|
smul := mul,
|
|
|
|
|
smul_left_distrib := left_distrib,
|
|
|
|
|
smul_right_distrib := right_distrib,
|
|
|
|
|
mul_smul := mul.assoc,
|
|
|
|
|
one_smul := one_mul
|
|
|
|
|
⦄
|
|
|
|
|
|
2016-02-25 22:30:00 +00:00
|
|
|
|
definition banach_space_real [trans_instance] : banach_space ℝ :=
|
2016-01-15 04:57:27 +00:00
|
|
|
|
⦃ banach_space, real_vector_space_real,
|
|
|
|
|
norm := abs,
|
|
|
|
|
norm_zero := abs_zero,
|
|
|
|
|
eq_zero_of_norm_eq_zero := λ a H, eq_zero_of_abs_eq_zero H,
|
|
|
|
|
norm_triangle := abs_add_le_abs_add_abs,
|
|
|
|
|
norm_smul := abs_mul,
|
|
|
|
|
complete := λ X H, analysis.complete ℝ H
|
|
|
|
|
⦄
|
|
|
|
|
|
2015-09-21 00:51:28 +00:00
|
|
|
|
/- limits under pointwise operations -/
|
|
|
|
|
|
|
|
|
|
section limit_operations
|
|
|
|
|
variables {X Y : ℕ → ℝ}
|
|
|
|
|
variables {x y : ℝ}
|
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
proposition mul_left_converges_to_seq (c : ℝ) (HX : X ⟶ x [at ∞]) :
|
|
|
|
|
(λ n, c * X n) ⟶ c * x [at ∞] :=
|
2016-01-15 04:57:27 +00:00
|
|
|
|
smul_converges_to_seq c HX
|
2015-09-21 00:51:28 +00:00
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
proposition mul_right_converges_to_seq (c : ℝ) (HX : X ⟶ x [at ∞]) :
|
|
|
|
|
(λ n, X n * c) ⟶ x * c [at ∞] :=
|
2015-09-21 00:51:28 +00:00
|
|
|
|
have (λ n, X n * c) = (λ n, c * X n), from funext (take x, !mul.comm),
|
2016-02-29 21:15:48 +00:00
|
|
|
|
by rewrite [this, mul.comm]; apply mul_left_converges_to_seq c HX
|
2015-09-21 00:51:28 +00:00
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
theorem converges_to_seq_squeeze (HX : X ⟶ x [at ∞]) (HY : Y ⟶ x [at ∞]) {Z : ℕ → ℝ} (HZX : ∀ n, X n ≤ Z n)
|
|
|
|
|
(HZY : ∀ n, Z n ≤ Y n) : Z ⟶ x [at ∞] :=
|
2016-02-01 20:40:21 +00:00
|
|
|
|
begin
|
2016-05-19 01:21:49 +00:00
|
|
|
|
apply approaches_at_infty_intro,
|
2016-02-01 20:40:21 +00:00
|
|
|
|
intros ε Hε,
|
|
|
|
|
have Hε4 : ε / 4 > 0, from div_pos_of_pos_of_pos Hε four_pos,
|
2016-05-19 01:21:49 +00:00
|
|
|
|
cases approaches_at_infty_dest HX Hε4 with N1 HN1,
|
|
|
|
|
cases approaches_at_infty_dest HY Hε4 with N2 HN2,
|
2016-02-01 20:40:21 +00:00
|
|
|
|
existsi max N1 N2,
|
|
|
|
|
intro n Hn,
|
|
|
|
|
have HXY : abs (Y n - X n) < ε / 2, begin
|
|
|
|
|
apply lt_of_le_of_lt,
|
|
|
|
|
apply abs_sub_le _ x,
|
|
|
|
|
have Hε24 : ε / 2 = ε / 4 + ε / 4, from eq.symm !add_quarters,
|
|
|
|
|
rewrite Hε24,
|
|
|
|
|
apply add_lt_add,
|
|
|
|
|
apply HN2,
|
|
|
|
|
apply ge.trans Hn !le_max_right,
|
|
|
|
|
rewrite abs_sub,
|
|
|
|
|
apply HN1,
|
|
|
|
|
apply ge.trans Hn !le_max_left
|
|
|
|
|
end,
|
|
|
|
|
have HZX : abs (Z n - X n) < ε / 2, begin
|
|
|
|
|
have HZXnp : Z n - X n ≥ 0, from sub_nonneg_of_le !HZX,
|
|
|
|
|
have HXYnp : Y n - X n ≥ 0, from sub_nonneg_of_le (le.trans !HZX !HZY),
|
|
|
|
|
rewrite [abs_of_nonneg HZXnp, abs_of_nonneg HXYnp at HXY],
|
|
|
|
|
note Hgt := lt_add_of_sub_lt_right HXY,
|
|
|
|
|
have Hlt : Z n < ε / 2 + X n, from calc
|
|
|
|
|
Z n ≤ Y n : HZY
|
|
|
|
|
... < ε / 2 + X n : Hgt,
|
|
|
|
|
apply sub_lt_right_of_lt_add Hlt
|
|
|
|
|
end,
|
|
|
|
|
have H : abs (Z n - x) < ε, begin
|
|
|
|
|
apply lt_of_le_of_lt,
|
|
|
|
|
apply abs_sub_le _ (X n),
|
|
|
|
|
apply lt.trans,
|
|
|
|
|
apply add_lt_add,
|
|
|
|
|
apply HZX,
|
|
|
|
|
apply HN1,
|
|
|
|
|
apply ge.trans Hn !le_max_left,
|
2016-02-01 20:51:29 +00:00
|
|
|
|
apply div_two_add_div_four_lt Hε
|
2016-02-01 20:40:21 +00:00
|
|
|
|
end,
|
|
|
|
|
exact H
|
|
|
|
|
end
|
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
proposition converges_to_seq_of_abs_sub_converges_to_seq (Habs : (λ n, abs (X n - x)) ⟶ 0 [at ∞]) :
|
|
|
|
|
X ⟶ x [at ∞] :=
|
2016-02-01 20:40:21 +00:00
|
|
|
|
begin
|
2016-05-19 01:21:49 +00:00
|
|
|
|
apply approaches_at_infty_intro,
|
2016-02-01 20:40:21 +00:00
|
|
|
|
intros ε Hε,
|
2016-05-19 01:21:49 +00:00
|
|
|
|
cases approaches_at_infty_dest Habs Hε with N HN,
|
2016-02-01 20:40:21 +00:00
|
|
|
|
existsi N,
|
|
|
|
|
intro n Hn,
|
|
|
|
|
have Hn' : abs (abs (X n - x) - 0) < ε, from HN Hn,
|
|
|
|
|
rewrite [sub_zero at Hn', abs_abs at Hn'],
|
|
|
|
|
exact Hn'
|
|
|
|
|
end
|
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
proposition abs_sub_converges_to_seq_of_converges_to_seq (HX : X ⟶ x [at ∞]) :
|
|
|
|
|
(λ n, abs (X n - x)) ⟶ 0 [at ∞] :=
|
2016-02-01 20:40:21 +00:00
|
|
|
|
begin
|
2016-05-19 01:21:49 +00:00
|
|
|
|
apply approaches_at_infty_intro,
|
2016-02-01 20:40:21 +00:00
|
|
|
|
intros ε Hε,
|
2016-05-19 01:21:49 +00:00
|
|
|
|
cases approaches_at_infty_dest HX Hε with N HN,
|
2016-02-01 20:40:21 +00:00
|
|
|
|
existsi N,
|
|
|
|
|
intro n Hn,
|
|
|
|
|
have Hn' : abs (abs (X n - x) - 0) < ε, by rewrite [sub_zero, abs_abs]; apply HN Hn,
|
|
|
|
|
exact Hn'
|
|
|
|
|
end
|
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
proposition mul_converges_to_seq (HX : X ⟶ x [at ∞]) (HY : Y ⟶ y [at ∞]) :
|
|
|
|
|
(λ n, X n * Y n) ⟶ x * y [at ∞] :=
|
2016-02-01 20:40:21 +00:00
|
|
|
|
have Hbd : ∃ K : ℝ, ∀ n : ℕ, abs (X n) ≤ K, begin
|
|
|
|
|
cases bounded_of_converges_seq HX with K HK,
|
|
|
|
|
existsi K + abs x,
|
|
|
|
|
intro n,
|
|
|
|
|
note Habs := le.trans (abs_abs_sub_abs_le_abs_sub (X n) x) !HK,
|
|
|
|
|
apply le_add_of_sub_right_le,
|
|
|
|
|
apply le.trans,
|
|
|
|
|
apply le_abs_self,
|
|
|
|
|
assumption
|
|
|
|
|
end,
|
2016-02-10 00:10:49 +00:00
|
|
|
|
obtain K HK, from Hbd,
|
2016-02-29 20:31:23 +00:00
|
|
|
|
have Habsle : ∀ n, abs (X n * Y n - x * y) ≤ K * abs (Y n - y) + abs y * abs (X n - x), begin
|
2016-02-01 20:40:21 +00:00
|
|
|
|
intro,
|
|
|
|
|
have Heq : X n * Y n - x * y = (X n * Y n - X n * y) + (X n * y - x * y), by
|
|
|
|
|
rewrite [-sub_add_cancel (X n * Y n) (X n * y) at {1}, sub_eq_add_neg, *add.assoc],
|
|
|
|
|
apply le.trans,
|
|
|
|
|
rewrite Heq,
|
|
|
|
|
apply abs_add_le_abs_add_abs,
|
|
|
|
|
apply add_le_add,
|
|
|
|
|
rewrite [-mul_sub_left_distrib, abs_mul],
|
|
|
|
|
apply mul_le_mul_of_nonneg_right,
|
|
|
|
|
apply HK,
|
|
|
|
|
apply abs_nonneg,
|
|
|
|
|
rewrite [-mul_sub_right_distrib, abs_mul, mul.comm],
|
|
|
|
|
apply le.refl
|
|
|
|
|
end,
|
2016-05-19 01:21:49 +00:00
|
|
|
|
have Hdifflim : (λ n, abs (X n * Y n - x * y)) ⟶ 0 [at ∞], begin
|
2016-02-01 20:40:21 +00:00
|
|
|
|
apply converges_to_seq_squeeze,
|
|
|
|
|
rotate 2,
|
|
|
|
|
intro, apply abs_nonneg,
|
|
|
|
|
apply Habsle,
|
2016-05-19 01:21:49 +00:00
|
|
|
|
apply approaches_constant,
|
2016-02-01 20:40:21 +00:00
|
|
|
|
rewrite -{0}zero_add,
|
|
|
|
|
apply add_converges_to_seq,
|
2016-02-04 21:15:42 +00:00
|
|
|
|
krewrite -(mul_zero K),
|
2016-02-01 20:40:21 +00:00
|
|
|
|
apply mul_left_converges_to_seq,
|
|
|
|
|
apply abs_sub_converges_to_seq_of_converges_to_seq,
|
|
|
|
|
exact HY,
|
2016-02-04 21:15:42 +00:00
|
|
|
|
krewrite -(mul_zero (abs y)),
|
2016-02-01 20:40:21 +00:00
|
|
|
|
apply mul_left_converges_to_seq,
|
|
|
|
|
apply abs_sub_converges_to_seq_of_converges_to_seq,
|
|
|
|
|
exact HX
|
|
|
|
|
end,
|
2016-02-10 00:10:49 +00:00
|
|
|
|
converges_to_seq_of_abs_sub_converges_to_seq Hdifflim
|
|
|
|
|
|
2016-02-01 20:40:21 +00:00
|
|
|
|
|
2015-09-21 00:51:28 +00:00
|
|
|
|
-- TODO: converges_to_seq_div, converges_to_seq_mul_left_iff, etc.
|
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
proposition abs_converges_to_seq_zero (HX : X ⟶ 0 [at ∞]) : (λ n, abs (X n)) ⟶ 0 [at ∞] :=
|
2016-01-15 04:57:27 +00:00
|
|
|
|
norm_converges_to_seq_zero HX
|
2015-09-21 00:51:28 +00:00
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
proposition converges_to_seq_zero_of_abs_converges_to_seq_zero (HX : (λ n, abs (X n)) ⟶ 0 [at ∞]) :
|
|
|
|
|
X ⟶ 0 [at ∞] :=
|
2016-01-15 04:57:27 +00:00
|
|
|
|
converges_to_seq_zero_of_norm_converges_to_seq_zero HX
|
2015-09-21 00:51:28 +00:00
|
|
|
|
|
|
|
|
|
proposition abs_converges_to_seq_zero_iff (X : ℕ → ℝ) :
|
2016-05-19 01:21:49 +00:00
|
|
|
|
((λ n, abs (X n)) ⟶ 0 [at ∞]) ↔ (X ⟶ 0 [at ∞]) :=
|
2015-09-21 00:51:28 +00:00
|
|
|
|
iff.intro converges_to_seq_zero_of_abs_converges_to_seq_zero abs_converges_to_seq_zero
|
|
|
|
|
|
|
|
|
|
-- TODO: products of two sequences, converges_seq, limit_seq
|
|
|
|
|
|
|
|
|
|
end limit_operations
|
|
|
|
|
|
2016-02-01 20:40:21 +00:00
|
|
|
|
/- properties of converges_to_at -/
|
|
|
|
|
|
|
|
|
|
section limit_operations_continuous
|
2016-02-17 18:48:19 +00:00
|
|
|
|
variables {f g h : ℝ → ℝ}
|
2016-02-01 20:40:21 +00:00
|
|
|
|
variables {a b x y : ℝ}
|
|
|
|
|
|
2016-05-19 01:21:49 +00:00
|
|
|
|
theorem mul_converges_to_at (Hf : f ⟶ a [at x]) (Hg : g ⟶ b [at x]) : (λ z, f z * g z) ⟶ a * b [at x] :=
|
2016-02-01 20:40:21 +00:00
|
|
|
|
begin
|
|
|
|
|
apply converges_to_at_of_all_conv_seqs,
|
|
|
|
|
intro X HX,
|
|
|
|
|
apply mul_converges_to_seq,
|
2016-05-19 01:21:49 +00:00
|
|
|
|
apply comp_approaches_at_infty Hf,
|
|
|
|
|
apply and.right (HX 0),
|
|
|
|
|
apply (set.filter.eventually_of_forall _ (λ n, and.left (HX n))),
|
|
|
|
|
apply comp_approaches_at_infty Hg,
|
|
|
|
|
apply and.right (HX 0),
|
|
|
|
|
apply (set.filter.eventually_of_forall _ (λ n, and.left (HX n)))
|
2016-02-01 20:40:21 +00:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
end limit_operations_continuous
|
|
|
|
|
|
2015-09-21 00:51:28 +00:00
|
|
|
|
/- monotone sequences -/
|
|
|
|
|
|
|
|
|
|
section monotone_sequences
|
2016-01-15 04:57:27 +00:00
|
|
|
|
open real set
|
2015-09-21 00:51:28 +00:00
|
|
|
|
variable {X : ℕ → ℝ}
|
|
|
|
|
|
|
|
|
|
proposition converges_to_seq_sup_of_nondecreasing (nondecX : nondecreasing X) {b : ℝ}
|
2016-05-19 01:21:49 +00:00
|
|
|
|
(Hb : ∀ i, X i ≤ b) : X ⟶ sup (X ' univ) [at ∞] :=
|
|
|
|
|
approaches_at_infty_intro
|
|
|
|
|
(let sX := sup (X ' univ) in
|
2015-09-21 00:51:28 +00:00
|
|
|
|
have Xle : ∀ i, X i ≤ sX, from
|
|
|
|
|
take i,
|
2016-01-04 00:41:01 +00:00
|
|
|
|
have ∀ x, x ∈ X ' univ → x ≤ b, from
|
2015-09-21 00:51:28 +00:00
|
|
|
|
(take x, assume H,
|
|
|
|
|
obtain i [H' (Hi : X i = x)], from H,
|
|
|
|
|
by rewrite -Hi; exact Hb i),
|
|
|
|
|
show X i ≤ sX, from le_sup (mem_image_of_mem X !mem_univ) this,
|
2016-01-04 00:41:01 +00:00
|
|
|
|
have exX : ∃ x, x ∈ X ' univ,
|
2015-09-21 00:51:28 +00:00
|
|
|
|
from exists.intro (X 0) (mem_image_of_mem X !mem_univ),
|
|
|
|
|
take ε, assume epos : ε > 0,
|
|
|
|
|
have sX - ε < sX, from !sub_lt_of_pos epos,
|
2016-01-04 00:41:01 +00:00
|
|
|
|
obtain x' [(H₁x' : x' ∈ X ' univ) (H₂x' : sX - ε < x')],
|
2015-09-21 00:51:28 +00:00
|
|
|
|
from exists_mem_and_lt_of_lt_sup exX this,
|
|
|
|
|
obtain i [H' (Hi : X i = x')], from H₁x',
|
|
|
|
|
have Hi' : ∀ j, j ≥ i → sX - ε < X j, from
|
2015-10-14 17:19:23 +00:00
|
|
|
|
take j, assume Hj, lt_of_lt_of_le (by rewrite Hi; apply H₂x') (nondecX Hj),
|
2015-09-21 00:51:28 +00:00
|
|
|
|
exists.intro i
|
|
|
|
|
(take j, assume Hj : j ≥ i,
|
|
|
|
|
have X j - sX ≤ 0, from sub_nonpos_of_le (Xle j),
|
2016-02-29 19:28:20 +00:00
|
|
|
|
have eq₁ : abs (X j - sX) = sX - X j, by rewrite [abs_of_nonpos this, neg_sub],
|
2015-10-14 17:19:23 +00:00
|
|
|
|
have sX - ε < X j, from lt_of_lt_of_le (by rewrite Hi; apply H₂x') (nondecX Hj),
|
2015-09-21 00:51:28 +00:00
|
|
|
|
have sX < X j + ε, from lt_add_of_sub_lt_right this,
|
|
|
|
|
have sX - X j < ε, from sub_lt_left_of_lt_add this,
|
2016-05-19 01:21:49 +00:00
|
|
|
|
show (abs (X j - sX)) < ε, by rewrite eq₁; exact this))
|
2015-09-21 00:51:28 +00:00
|
|
|
|
|
|
|
|
|
proposition converges_to_seq_inf_of_nonincreasing (nonincX : nonincreasing X) {b : ℝ}
|
2016-05-19 01:21:49 +00:00
|
|
|
|
(Hb : ∀ i, b ≤ X i) : X ⟶ inf (X ' univ) [at ∞] :=
|
2016-01-04 00:41:01 +00:00
|
|
|
|
have H₁ : ∃ x, x ∈ X ' univ, from exists.intro (X 0) (mem_image_of_mem X !mem_univ),
|
|
|
|
|
have H₂ : ∀ x, x ∈ X ' univ → b ≤ x, from
|
2015-09-21 00:51:28 +00:00
|
|
|
|
(take x, assume H,
|
|
|
|
|
obtain i [Hi₁ (Hi₂ : X i = x)], from H,
|
|
|
|
|
show b ≤ x, by rewrite -Hi₂; apply Hb i),
|
2016-01-04 00:41:01 +00:00
|
|
|
|
have H₃ : {x : ℝ | -x ∈ X ' univ} = {x : ℝ | x ∈ (λ n, -X n) ' univ}, from calc
|
|
|
|
|
{x : ℝ | -x ∈ X ' univ} = (λ y, -y) ' (X ' univ) : by rewrite image_neg_eq
|
2016-02-16 18:56:01 +00:00
|
|
|
|
... = {x : ℝ | x ∈ (λ n, -X n) ' univ} : image_comp,
|
2015-09-21 00:51:28 +00:00
|
|
|
|
have H₄ : ∀ i, - X i ≤ - b, from take i, neg_le_neg (Hb i),
|
2016-02-29 21:15:48 +00:00
|
|
|
|
begin
|
2016-05-19 01:21:49 +00:00
|
|
|
|
apply iff.mp !neg_converges_to_seq_iff,
|
2016-01-15 04:57:27 +00:00
|
|
|
|
-- need krewrite here
|
2016-05-19 01:21:49 +00:00
|
|
|
|
krewrite [-sup_neg H₁ H₂, H₃, -nondecreasing_neg_iff at nonincX],
|
2015-09-21 00:51:28 +00:00
|
|
|
|
apply converges_to_seq_sup_of_nondecreasing nonincX H₄
|
2015-09-13 01:45:47 +00:00
|
|
|
|
end
|
|
|
|
|
|
2015-09-21 00:51:28 +00:00
|
|
|
|
end monotone_sequences
|
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
/- x^n converges to 0 if abs x < 1 -/
|
|
|
|
|
|
2015-09-21 00:51:28 +00:00
|
|
|
|
section xn
|
|
|
|
|
open nat set
|
|
|
|
|
|
|
|
|
|
theorem pow_converges_to_seq_zero {x : ℝ} (H : abs x < 1) :
|
2016-05-19 01:21:49 +00:00
|
|
|
|
(λ n, x^n) ⟶ 0 [at ∞] :=
|
|
|
|
|
suffices H' : (λ n, (abs x)^n) ⟶ 0 [at ∞], from
|
2015-10-14 17:19:23 +00:00
|
|
|
|
have (λ n, (abs x)^n) = (λ n, abs (x^n)), from funext (take n, eq.symm !abs_pow),
|
2015-09-21 00:51:28 +00:00
|
|
|
|
by rewrite this at H'; exact converges_to_seq_zero_of_abs_converges_to_seq_zero H',
|
|
|
|
|
let aX := (λ n, (abs x)^n),
|
2016-01-15 04:57:27 +00:00
|
|
|
|
iaX := real.inf (aX ' univ),
|
2015-09-21 00:51:28 +00:00
|
|
|
|
asX := (λ n, (abs x)^(succ n)) in
|
|
|
|
|
have noninc_aX : nonincreasing aX, from
|
2016-02-29 02:55:48 +00:00
|
|
|
|
nonincreasing_of_forall_ge_succ
|
2015-09-21 00:51:28 +00:00
|
|
|
|
(take i,
|
2016-02-29 19:47:33 +00:00
|
|
|
|
have (abs x) * (abs x)^i ≤ 1 * (abs x)^i,
|
2015-09-21 00:51:28 +00:00
|
|
|
|
from mul_le_mul_of_nonneg_right (le_of_lt H) (!pow_nonneg_of_nonneg !abs_nonneg),
|
2016-02-29 19:47:33 +00:00
|
|
|
|
have (abs x) * (abs x)^i ≤ (abs x)^i, by krewrite one_mul at this; exact this,
|
2015-10-14 17:19:23 +00:00
|
|
|
|
show (abs x) ^ (succ i) ≤ (abs x)^i, by rewrite pow_succ; apply this),
|
2015-09-21 00:51:28 +00:00
|
|
|
|
have bdd_aX : ∀ i, 0 ≤ aX i, from take i, !pow_nonneg_of_nonneg !abs_nonneg,
|
2016-05-19 01:21:49 +00:00
|
|
|
|
have aXconv : aX ⟶ iaX [at ∞], proof converges_to_seq_inf_of_nonincreasing noninc_aX bdd_aX qed,
|
|
|
|
|
have asXconv : asX ⟶ iaX [at ∞], from tendsto_succ_at_infty aXconv,
|
|
|
|
|
have asXconv' : asX ⟶ (abs x) * iaX [at ∞], from mul_left_converges_to_seq (abs x) aXconv,
|
|
|
|
|
have iaX = (abs x) * iaX, from sorry, -- converges_to_seq_unique asXconv asXconv',
|
2016-02-29 19:47:33 +00:00
|
|
|
|
have iaX = 0, from eq_zero_of_mul_eq_self_left (ne_of_lt H) (eq.symm this),
|
2016-05-19 01:21:49 +00:00
|
|
|
|
show aX ⟶ 0 [at ∞], begin rewrite -this, exact aXconv end --from this ▸ aXconv
|
2015-09-21 00:51:28 +00:00
|
|
|
|
|
|
|
|
|
end xn
|
2015-09-16 20:44:28 +00:00
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
/- continuity on the reals -/
|
|
|
|
|
|
2015-09-17 20:22:46 +00:00
|
|
|
|
section continuous
|
2015-09-15 22:57:08 +00:00
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
theorem continuous_real_elim {f : ℝ → ℝ} (H : continuous f) :
|
|
|
|
|
∀ x : ℝ, ∀ ⦃ε : ℝ⦄, ε > 0 → ∃ δ : ℝ, δ > 0 ∧ ∀ x' : ℝ,
|
|
|
|
|
abs (x' - x) < δ → abs (f x' - f x) < ε :=
|
2016-02-10 00:10:49 +00:00
|
|
|
|
take x, continuous_at_elim (H x)
|
2016-01-15 04:57:27 +00:00
|
|
|
|
|
|
|
|
|
theorem continuous_real_intro {f : ℝ → ℝ}
|
|
|
|
|
(H : ∀ x : ℝ, ∀ ⦃ε : ℝ⦄, ε > 0 → ∃ δ : ℝ, δ > 0 ∧ ∀ x' : ℝ,
|
|
|
|
|
abs (x' - x) < δ → abs (f x' - f x) < ε) :
|
|
|
|
|
continuous f :=
|
2016-02-10 00:10:49 +00:00
|
|
|
|
take x, continuous_at_intro (H x)
|
2015-09-15 22:57:08 +00:00
|
|
|
|
|
2015-09-17 20:22:46 +00:00
|
|
|
|
theorem pos_on_nbhd_of_cts_of_pos {f : ℝ → ℝ} (Hf : continuous f) {b : ℝ} (Hb : f b > 0) :
|
2016-01-15 04:57:27 +00:00
|
|
|
|
∃ δ : ℝ, δ > 0 ∧ ∀ y, abs (y - b) < δ → f y > 0 :=
|
2015-09-17 20:22:46 +00:00
|
|
|
|
begin
|
2016-01-15 04:57:27 +00:00
|
|
|
|
let Hcont := continuous_real_elim Hf b Hb,
|
2015-09-17 20:22:46 +00:00
|
|
|
|
cases Hcont with δ Hδ,
|
|
|
|
|
existsi δ,
|
|
|
|
|
split,
|
|
|
|
|
exact and.left Hδ,
|
|
|
|
|
intro y Hy,
|
|
|
|
|
let Hy' := and.right Hδ y Hy,
|
2016-01-15 04:57:27 +00:00
|
|
|
|
note Hlt := sub_lt_of_abs_sub_lt_left Hy',
|
2015-09-17 20:22:46 +00:00
|
|
|
|
rewrite sub_self at Hlt,
|
|
|
|
|
assumption
|
|
|
|
|
end
|
2015-09-15 22:57:08 +00:00
|
|
|
|
|
2015-09-17 20:22:46 +00:00
|
|
|
|
theorem neg_on_nbhd_of_cts_of_neg {f : ℝ → ℝ} (Hf : continuous f) {b : ℝ} (Hb : f b < 0) :
|
2016-01-15 04:57:27 +00:00
|
|
|
|
∃ δ : ℝ, δ > 0 ∧ ∀ y, abs (y - b) < δ → f y < 0 :=
|
2015-09-15 22:57:08 +00:00
|
|
|
|
begin
|
2016-01-15 04:57:27 +00:00
|
|
|
|
let Hcont := continuous_real_elim Hf b (neg_pos_of_neg Hb),
|
2015-09-17 20:22:46 +00:00
|
|
|
|
cases Hcont with δ Hδ,
|
|
|
|
|
existsi δ,
|
|
|
|
|
split,
|
|
|
|
|
exact and.left Hδ,
|
|
|
|
|
intro y Hy,
|
|
|
|
|
let Hy' := and.right Hδ y Hy,
|
2016-01-15 04:57:27 +00:00
|
|
|
|
let Hlt := sub_lt_of_abs_sub_lt_right Hy',
|
|
|
|
|
note Hlt' := lt_add_of_sub_lt_left Hlt,
|
|
|
|
|
rewrite [add.comm at Hlt', -sub_eq_add_neg at Hlt', sub_self at Hlt'],
|
2015-09-17 20:22:46 +00:00
|
|
|
|
assumption
|
2015-09-15 22:57:08 +00:00
|
|
|
|
end
|
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
theorem continuous_neg_of_continuous {f : ℝ → ℝ} (Hcon : continuous f) : continuous (λ x, - f x) :=
|
2015-09-17 20:22:46 +00:00
|
|
|
|
begin
|
2016-01-15 04:57:27 +00:00
|
|
|
|
apply continuous_real_intro,
|
2015-09-17 20:22:46 +00:00
|
|
|
|
intros x ε Hε,
|
2016-01-15 04:57:27 +00:00
|
|
|
|
cases continuous_real_elim Hcon x Hε with δ Hδ,
|
2015-09-17 20:22:46 +00:00
|
|
|
|
cases Hδ with Hδ₁ Hδ₂,
|
|
|
|
|
existsi δ,
|
|
|
|
|
split,
|
|
|
|
|
assumption,
|
|
|
|
|
intros x' Hx',
|
|
|
|
|
let HD := Hδ₂ x' Hx',
|
|
|
|
|
rewrite [-abs_neg, neg_neg_sub_neg],
|
2015-10-14 17:19:23 +00:00
|
|
|
|
exact HD
|
2015-09-17 20:22:46 +00:00
|
|
|
|
end
|
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
theorem continuous_offset_of_continuous {f : ℝ → ℝ} (Hcon : continuous f) (a : ℝ) :
|
2015-09-17 20:22:46 +00:00
|
|
|
|
continuous (λ x, (f x) + a) :=
|
|
|
|
|
begin
|
2016-01-15 04:57:27 +00:00
|
|
|
|
apply continuous_real_intro,
|
2015-09-17 20:22:46 +00:00
|
|
|
|
intros x ε Hε,
|
2016-01-15 04:57:27 +00:00
|
|
|
|
cases continuous_real_elim Hcon x Hε with δ Hδ,
|
2015-09-17 20:22:46 +00:00
|
|
|
|
cases Hδ with Hδ₁ Hδ₂,
|
|
|
|
|
existsi δ,
|
|
|
|
|
split,
|
|
|
|
|
assumption,
|
|
|
|
|
intros x' Hx',
|
2015-12-06 07:27:46 +00:00
|
|
|
|
rewrite [add_sub_comm, sub_self, add_zero],
|
2015-09-17 20:22:46 +00:00
|
|
|
|
apply Hδ₂,
|
|
|
|
|
assumption
|
|
|
|
|
end
|
2015-09-16 20:44:28 +00:00
|
|
|
|
|
2016-02-01 20:40:21 +00:00
|
|
|
|
theorem continuous_mul_of_continuous {f g : ℝ → ℝ} (Hconf : continuous f) (Hcong : continuous g) :
|
|
|
|
|
continuous (λ x, f x * g x) :=
|
|
|
|
|
begin
|
|
|
|
|
intro x,
|
|
|
|
|
apply continuous_at_of_converges_to_at,
|
|
|
|
|
apply mul_converges_to_at,
|
|
|
|
|
all_goals apply converges_to_at_of_continuous_at,
|
|
|
|
|
apply Hconf,
|
|
|
|
|
apply Hcong
|
|
|
|
|
end
|
|
|
|
|
|
2016-01-15 04:57:27 +00:00
|
|
|
|
end continuous
|
2016-02-17 18:48:19 +00:00
|
|
|
|
|
|
|
|
|
-- this can be strengthened: Hle and Hge only need to hold around x
|
|
|
|
|
theorem converges_to_at_squeeze {M : Type} [Hm : metric_space M] {f g h : M → ℝ} {a : ℝ} {x : M}
|
|
|
|
|
(Hf : f ⟶ a at x) (Hh : h ⟶ a at x) (Hle : ∀ y : M, f y ≤ g y)
|
|
|
|
|
(Hge : ∀ y : M, g y ≤ h y) : g ⟶ a at x :=
|
|
|
|
|
begin
|
|
|
|
|
apply converges_to_at_of_all_conv_seqs,
|
|
|
|
|
intro X HX,
|
|
|
|
|
apply converges_to_seq_squeeze,
|
|
|
|
|
apply all_conv_seqs_of_converges_to_at Hf,
|
|
|
|
|
apply HX,
|
|
|
|
|
apply all_conv_seqs_of_converges_to_at Hh,
|
|
|
|
|
apply HX,
|
|
|
|
|
intro,
|
|
|
|
|
apply Hle,
|
|
|
|
|
intro,
|
|
|
|
|
apply Hge
|
|
|
|
|
end
|