2015-06-01 13:00:27 +00:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2015 Robert Y. Lewis. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
Author: Robert Y. Lewis
|
|
|
|
|
The real numbers, constructed as equivalence classes of Cauchy sequences of rationals.
|
|
|
|
|
This construction follows Bishop and Bridges (1985).
|
|
|
|
|
|
|
|
|
|
At this point, we no longer proceed constructively: this file makes heavy use of decidability
|
|
|
|
|
and excluded middle.
|
|
|
|
|
-/
|
2015-08-13 01:37:33 +00:00
|
|
|
|
import data.real.basic data.real.order data.rat data.nat
|
2015-10-13 19:07:36 +00:00
|
|
|
|
open rat
|
|
|
|
|
open nat
|
2015-12-06 07:27:46 +00:00
|
|
|
|
open eq.ops pnat classical
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
namespace rat_seq
|
2015-10-14 00:49:45 +00:00
|
|
|
|
local postfix ⁻¹ := pnat.inv
|
2015-06-01 13:00:27 +00:00
|
|
|
|
|
|
|
|
|
-----------------------------
|
|
|
|
|
-- Facts about absolute values of sequences, to define inverse
|
|
|
|
|
|
|
|
|
|
definition s_abs (s : seq) : seq := λ n, abs (s n)
|
|
|
|
|
|
2015-06-01 11:57:11 +00:00
|
|
|
|
theorem abs_reg_of_reg {s : seq} (Hs : regular s) : regular (s_abs s) :=
|
|
|
|
|
begin
|
|
|
|
|
intros,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply le.trans,
|
|
|
|
|
apply abs_abs_sub_abs_le_abs_sub,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply Hs
|
|
|
|
|
end
|
|
|
|
|
|
2015-06-01 13:00:27 +00:00
|
|
|
|
theorem abs_pos_of_nonzero {s : seq} (Hs : regular s) (Hnz : sep s zero) :
|
|
|
|
|
∃ N : ℕ+, ∀ m : ℕ+, m ≥ N → abs (s m) ≥ N⁻¹ :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
begin
|
|
|
|
|
rewrite [↑sep at Hnz, ↑s_lt at Hnz],
|
|
|
|
|
apply or.elim Hnz,
|
|
|
|
|
intro Hnz1,
|
|
|
|
|
have H' : pos (sneg s), begin
|
|
|
|
|
apply pos_of_pos_equiv,
|
|
|
|
|
rotate 2,
|
|
|
|
|
apply Hnz1,
|
|
|
|
|
rotate 1,
|
|
|
|
|
apply s_zero_add,
|
|
|
|
|
repeat (assumption | apply reg_add_reg | apply reg_neg_reg | apply zero_is_reg)
|
|
|
|
|
end,
|
2015-08-03 19:02:03 +00:00
|
|
|
|
cases bdd_away_of_pos (reg_neg_reg Hs) H' with [N, HN],
|
2015-06-01 11:57:11 +00:00
|
|
|
|
existsi N,
|
|
|
|
|
intro m Hm,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply le.trans,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply HN m Hm,
|
|
|
|
|
rewrite ↑sneg,
|
|
|
|
|
apply neg_le_abs_self,
|
|
|
|
|
intro Hnz2,
|
|
|
|
|
let H' := pos_of_pos_equiv (reg_add_reg Hs (reg_neg_reg zero_is_reg)) (s_add_zero s Hs) Hnz2,
|
|
|
|
|
let H'' := bdd_away_of_pos Hs H',
|
2015-08-03 19:02:03 +00:00
|
|
|
|
cases H'' with [N, HN],
|
2015-06-01 11:57:11 +00:00
|
|
|
|
existsi N,
|
|
|
|
|
intro m Hm,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply le.trans,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply HN m Hm,
|
|
|
|
|
apply le_abs_self
|
|
|
|
|
end
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
theorem abs_well_defined {s t : seq} (Hs : regular s) (Ht : regular t) (Heq : s ≡ t) :
|
|
|
|
|
s_abs s ≡ s_abs t :=
|
|
|
|
|
begin
|
|
|
|
|
rewrite [↑equiv at *],
|
|
|
|
|
intro n,
|
|
|
|
|
rewrite ↑s_abs,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply le.trans,
|
2015-09-11 03:00:18 +00:00
|
|
|
|
apply abs_abs_sub_abs_le_abs_sub,
|
|
|
|
|
apply Heq
|
|
|
|
|
end
|
|
|
|
|
|
2015-06-01 11:57:11 +00:00
|
|
|
|
theorem sep_zero_of_pos {s : seq} (Hs : regular s) (Hpos : pos s) : sep s zero :=
|
|
|
|
|
begin
|
|
|
|
|
apply or.inr,
|
|
|
|
|
apply pos_of_pos_equiv,
|
|
|
|
|
rotate 2,
|
|
|
|
|
apply Hpos,
|
|
|
|
|
apply Hs,
|
|
|
|
|
apply equiv.symm,
|
|
|
|
|
apply s_sub_zero Hs
|
|
|
|
|
end
|
|
|
|
|
|
2015-06-01 13:00:27 +00:00
|
|
|
|
------------------------
|
|
|
|
|
-- This section could be cleaned up.
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private noncomputable definition pb {s : seq} (Hs : regular s) (Hpos : pos s) :=
|
2015-06-01 13:00:27 +00:00
|
|
|
|
some (abs_pos_of_nonzero Hs (sep_zero_of_pos Hs Hpos))
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private noncomputable definition ps {s : seq} (Hs : regular s) (Hsep : sep s zero) :=
|
2015-06-01 13:00:27 +00:00
|
|
|
|
some (abs_pos_of_nonzero Hs Hsep)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem pb_spec {s : seq} (Hs : regular s) (Hpos : pos s) :
|
2015-06-01 13:00:27 +00:00
|
|
|
|
∀ m : ℕ+, m ≥ (pb Hs Hpos) → abs (s m) ≥ (pb Hs Hpos)⁻¹ :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
some_spec (abs_pos_of_nonzero Hs (sep_zero_of_pos Hs Hpos))
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem ps_spec {s : seq} (Hs : regular s) (Hsep : sep s zero) :
|
2015-06-01 11:57:11 +00:00
|
|
|
|
∀ m : ℕ+, m ≥ (ps Hs Hsep) → abs (s m) ≥ (ps Hs Hsep)⁻¹ :=
|
|
|
|
|
some_spec (abs_pos_of_nonzero Hs Hsep)
|
|
|
|
|
|
2015-07-29 04:56:35 +00:00
|
|
|
|
noncomputable definition s_inv {s : seq} (Hs : regular s) (n : ℕ+) : ℚ :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
if H : sep s zero then
|
2015-06-01 13:00:27 +00:00
|
|
|
|
(if n < (ps Hs H) then 1 / (s ((ps Hs H) * (ps Hs H) * (ps Hs H)))
|
|
|
|
|
else 1 / (s ((ps Hs H) * (ps Hs H) * n)))
|
2015-06-01 11:57:11 +00:00
|
|
|
|
else 0
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem peq {s : seq} (Hsep : sep s zero) (Hpos : pos s) (Hs : regular s) :
|
2015-06-01 13:00:27 +00:00
|
|
|
|
pb Hs Hpos = ps Hs Hsep := rfl
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem s_inv_of_sep_lt_p {s : seq} (Hs : regular s) (Hsep : sep s zero) {n : ℕ+}
|
2015-06-01 13:00:27 +00:00
|
|
|
|
(Hn : n < (ps Hs Hsep)) : s_inv Hs n = 1 / s ((ps Hs Hsep) * (ps Hs Hsep) * (ps Hs Hsep)) :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
begin
|
|
|
|
|
apply eq.trans,
|
|
|
|
|
apply dif_pos Hsep,
|
|
|
|
|
apply dif_pos Hn
|
|
|
|
|
end
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem s_inv_of_sep_gt_p {s : seq} (Hs : regular s) (Hsep : sep s zero) {n : ℕ+}
|
2015-06-01 13:00:27 +00:00
|
|
|
|
(Hn : n ≥ (ps Hs Hsep)) : s_inv Hs n = 1 / s ((ps Hs Hsep) * (ps Hs Hsep) * n) :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
begin
|
|
|
|
|
apply eq.trans,
|
|
|
|
|
apply dif_pos Hsep,
|
2015-06-16 04:55:02 +00:00
|
|
|
|
apply dif_neg (pnat.not_lt_of_ge Hn)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
end
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem s_inv_of_pos_lt_p {s : seq} (Hs : regular s) (Hpos : pos s) {n : ℕ+}
|
2015-06-01 13:00:27 +00:00
|
|
|
|
(Hn : n < (pb Hs Hpos)) : s_inv Hs n = 1 / s ((pb Hs Hpos) * (pb Hs Hpos) * (pb Hs Hpos)) :=
|
|
|
|
|
s_inv_of_sep_lt_p Hs (sep_zero_of_pos Hs Hpos) Hn
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem s_inv_of_pos_gt_p {s : seq} (Hs : regular s) (Hpos : pos s) {n : ℕ+}
|
2015-06-01 13:00:27 +00:00
|
|
|
|
(Hn : n ≥ (pb Hs Hpos)) : s_inv Hs n = 1 / s ((pb Hs Hpos) * (pb Hs Hpos) * n) :=
|
|
|
|
|
s_inv_of_sep_gt_p Hs (sep_zero_of_pos Hs Hpos) Hn
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem le_ps {s : seq} (Hs : regular s) (Hsep : sep s zero) (n : ℕ+) :
|
2015-06-16 04:55:02 +00:00
|
|
|
|
abs (s_inv Hs n) ≤ (rat_of_pnat (ps Hs Hsep)) :=
|
2015-06-01 13:00:27 +00:00
|
|
|
|
if Hn : n < ps Hs Hsep then
|
|
|
|
|
(begin
|
|
|
|
|
rewrite [(s_inv_of_sep_lt_p Hs Hsep Hn), abs_one_div],
|
|
|
|
|
apply div_le_pnat,
|
|
|
|
|
apply ps_spec,
|
|
|
|
|
apply pnat.mul_le_mul_left
|
|
|
|
|
end)
|
|
|
|
|
else
|
|
|
|
|
(begin
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite [(s_inv_of_sep_gt_p Hs Hsep (pnat.le_of_not_gt Hn)), abs_one_div],
|
2015-06-01 13:00:27 +00:00
|
|
|
|
apply div_le_pnat,
|
|
|
|
|
apply ps_spec,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite pnat.mul_assoc,
|
2015-06-01 13:00:27 +00:00
|
|
|
|
apply pnat.mul_le_mul_right
|
|
|
|
|
end)
|
|
|
|
|
|
2015-06-01 11:57:11 +00:00
|
|
|
|
theorem s_inv_zero : s_inv zero_is_reg = zero :=
|
|
|
|
|
funext (λ n, dif_neg (!not_sep_self))
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem s_inv_of_zero' {s : seq} (Hs : regular s) (Hz : ¬ sep s zero) (n : ℕ+) : s_inv Hs n = 0 :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
dif_neg Hz
|
|
|
|
|
|
|
|
|
|
theorem s_inv_of_zero {s : seq} (Hs : regular s) (Hz : ¬ sep s zero) : s_inv Hs = zero :=
|
|
|
|
|
begin
|
|
|
|
|
apply funext,
|
|
|
|
|
intro n,
|
|
|
|
|
apply s_inv_of_zero' Hs Hz n
|
|
|
|
|
end
|
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
private theorem s_ne_zero_of_ge_p {s : seq} (Hs : regular s) (Hsep : sep s zero) {n : ℕ+}
|
2015-06-01 13:00:27 +00:00
|
|
|
|
(Hn : n ≥ (ps Hs Hsep)) : s n ≠ 0 :=
|
|
|
|
|
begin
|
|
|
|
|
let Hps := ps_spec Hs Hsep,
|
|
|
|
|
apply ne_zero_of_abs_ne_zero,
|
|
|
|
|
apply ne_of_gt,
|
|
|
|
|
apply gt_of_ge_of_gt,
|
|
|
|
|
apply Hps,
|
|
|
|
|
apply Hn,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.inv_pos
|
2015-06-01 13:00:27 +00:00
|
|
|
|
end
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
|
|
|
|
theorem reg_inv_reg {s : seq} (Hs : regular s) (Hsep : sep s zero) : regular (s_inv Hs) :=
|
|
|
|
|
begin
|
|
|
|
|
rewrite ↑regular,
|
|
|
|
|
intros,
|
2015-06-10 02:46:30 +00:00
|
|
|
|
have Hsp : s ((ps Hs Hsep) * (ps Hs Hsep) * (ps Hs Hsep)) ≠ 0, from
|
2015-10-23 02:18:14 +00:00
|
|
|
|
s_ne_zero_of_ge_p Hs Hsep !pnat.mul_le_mul_left,
|
2015-06-10 02:46:30 +00:00
|
|
|
|
have Hspn : s ((ps Hs Hsep) * (ps Hs Hsep) * n) ≠ 0, from
|
2015-06-01 13:00:27 +00:00
|
|
|
|
s_ne_zero_of_ge_p Hs Hsep (show (ps Hs Hsep) * (ps Hs Hsep) * n ≥ ps Hs Hsep, by
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite pnat.mul_assoc; apply pnat.mul_le_mul_right),
|
2015-06-10 02:46:30 +00:00
|
|
|
|
have Hspm : s ((ps Hs Hsep) * (ps Hs Hsep) * m) ≠ 0, from
|
2015-06-01 13:00:27 +00:00
|
|
|
|
s_ne_zero_of_ge_p Hs Hsep (show (ps Hs Hsep) * (ps Hs Hsep) * m ≥ ps Hs Hsep, by
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite pnat.mul_assoc; apply pnat.mul_le_mul_right),
|
2015-08-03 19:02:03 +00:00
|
|
|
|
cases em (m < ps Hs Hsep) with [Hmlt, Hmlt],
|
|
|
|
|
cases em (n < ps Hs Hsep) with [Hnlt, Hnlt],
|
2015-06-01 11:57:11 +00:00
|
|
|
|
rewrite [(s_inv_of_sep_lt_p Hs Hsep Hmlt), (s_inv_of_sep_lt_p Hs Hsep Hnlt)],
|
2015-12-06 07:27:46 +00:00
|
|
|
|
rewrite [sub_self, abs_zero],
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply add_invs_nonneg,
|
2015-06-10 02:46:30 +00:00
|
|
|
|
rewrite [(s_inv_of_sep_lt_p Hs Hsep Hmlt),
|
2015-10-23 02:18:14 +00:00
|
|
|
|
(s_inv_of_sep_gt_p Hs Hsep (pnat.le_of_not_gt Hnlt))],
|
2015-08-27 17:29:19 +00:00
|
|
|
|
rewrite [(!div_sub_div Hsp Hspn), div_eq_mul_one_div, *abs_mul, *mul_one, *one_mul],
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply le.trans,
|
|
|
|
|
apply mul_le_mul,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply Hs,
|
2015-08-27 17:29:19 +00:00
|
|
|
|
rewrite [-(mul_one 1), -(!field.div_mul_div Hsp Hspn), abs_mul],
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply mul_le_mul,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
rewrite -(s_inv_of_sep_lt_p Hs Hsep Hmlt),
|
|
|
|
|
apply le_ps Hs Hsep,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite -(s_inv_of_sep_gt_p Hs Hsep (pnat.le_of_not_gt Hnlt)),
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply le_ps Hs Hsep,
|
|
|
|
|
apply abs_nonneg,
|
|
|
|
|
apply le_of_lt !rat_of_pnat_is_pos,
|
|
|
|
|
apply abs_nonneg,
|
|
|
|
|
apply add_invs_nonneg,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite [right_distrib, *pnat_cancel', add.comm],
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply add_le_add_right,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply inv_ge_of_le,
|
|
|
|
|
apply pnat.le_of_lt,
|
|
|
|
|
apply Hmlt,
|
2015-08-03 19:02:03 +00:00
|
|
|
|
cases em (n < ps Hs Hsep) with [Hnlt, Hnlt],
|
2015-06-01 13:00:27 +00:00
|
|
|
|
rewrite [(s_inv_of_sep_lt_p Hs Hsep Hnlt),
|
2015-10-23 02:18:14 +00:00
|
|
|
|
(s_inv_of_sep_gt_p Hs Hsep (pnat.le_of_not_gt Hmlt))],
|
2015-08-27 17:29:19 +00:00
|
|
|
|
rewrite [(!div_sub_div Hspm Hsp), div_eq_mul_one_div, *abs_mul, *mul_one, *one_mul],
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply le.trans,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply mul_le_mul,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply Hs,
|
2015-08-27 17:29:19 +00:00
|
|
|
|
rewrite [-(mul_one 1), -(!field.div_mul_div Hspm Hsp), abs_mul],
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply mul_le_mul,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite -(s_inv_of_sep_gt_p Hs Hsep (pnat.le_of_not_gt Hmlt)),
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply le_ps Hs Hsep,
|
|
|
|
|
rewrite -(s_inv_of_sep_lt_p Hs Hsep Hnlt),
|
|
|
|
|
apply le_ps Hs Hsep,
|
|
|
|
|
apply abs_nonneg,
|
|
|
|
|
apply le_of_lt !rat_of_pnat_is_pos,
|
|
|
|
|
apply abs_nonneg,
|
|
|
|
|
apply add_invs_nonneg,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite [right_distrib, *pnat_cancel', add.comm],
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply rat.add_le_add_left,
|
|
|
|
|
apply inv_ge_of_le,
|
|
|
|
|
apply pnat.le_of_lt,
|
|
|
|
|
apply Hnlt,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite [(s_inv_of_sep_gt_p Hs Hsep (pnat.le_of_not_gt Hnlt)),
|
|
|
|
|
(s_inv_of_sep_gt_p Hs Hsep (pnat.le_of_not_gt Hmlt))],
|
2015-08-27 17:29:19 +00:00
|
|
|
|
rewrite [(!div_sub_div Hspm Hspn), div_eq_mul_one_div, abs_mul, *one_mul, *mul_one],
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply le.trans,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply mul_le_mul,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply Hs,
|
2015-08-27 17:29:19 +00:00
|
|
|
|
rewrite [-(mul_one 1), -(!field.div_mul_div Hspm Hspn), abs_mul],
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply mul_le_mul,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite -(s_inv_of_sep_gt_p Hs Hsep (pnat.le_of_not_gt Hmlt)),
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply le_ps Hs Hsep,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite -(s_inv_of_sep_gt_p Hs Hsep (pnat.le_of_not_gt Hnlt)),
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply le_ps Hs Hsep,
|
|
|
|
|
apply abs_nonneg,
|
|
|
|
|
apply le_of_lt !rat_of_pnat_is_pos,
|
|
|
|
|
apply abs_nonneg,
|
|
|
|
|
apply add_invs_nonneg,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite [right_distrib, *pnat_cancel', add.comm],
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply le.refl
|
2015-06-01 11:57:11 +00:00
|
|
|
|
end
|
|
|
|
|
|
2015-06-01 13:00:27 +00:00
|
|
|
|
theorem s_inv_ne_zero {s : seq} (Hs : regular s) (Hsep : sep s zero) (n : ℕ+) : s_inv Hs n ≠ 0 :=
|
|
|
|
|
if H : n ≥ ps Hs Hsep then
|
|
|
|
|
(begin
|
|
|
|
|
rewrite (s_inv_of_sep_gt_p Hs Hsep H),
|
|
|
|
|
apply one_div_ne_zero,
|
|
|
|
|
apply s_ne_zero_of_ge_p,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.le_trans,
|
2015-06-01 13:00:27 +00:00
|
|
|
|
apply H,
|
|
|
|
|
apply pnat.mul_le_mul_left
|
|
|
|
|
end)
|
|
|
|
|
else
|
|
|
|
|
(begin
|
2015-10-13 19:07:36 +00:00
|
|
|
|
rewrite (s_inv_of_sep_lt_p Hs Hsep (pnat.lt_of_not_le H)),
|
2015-06-01 13:00:27 +00:00
|
|
|
|
apply one_div_ne_zero,
|
|
|
|
|
apply s_ne_zero_of_ge_p,
|
|
|
|
|
apply pnat.mul_le_mul_left
|
|
|
|
|
end)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-10-29 19:36:26 +00:00
|
|
|
|
protected theorem mul_inv {s : seq} (Hs : regular s) (Hsep : sep s zero) :
|
2015-10-23 12:54:32 +00:00
|
|
|
|
smul s (s_inv Hs) ≡ one :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
begin
|
|
|
|
|
let Rsi := reg_inv_reg Hs Hsep,
|
|
|
|
|
let Rssi := reg_mul_reg Hs Rsi,
|
|
|
|
|
apply eq_of_bdd Rssi one_is_reg,
|
|
|
|
|
intros,
|
|
|
|
|
existsi max (ps Hs Hsep) j,
|
|
|
|
|
intro n Hn,
|
2015-06-01 13:00:27 +00:00
|
|
|
|
have Hnz : s_inv Hs ((K₂ s (s_inv Hs)) * 2 * n) ≠ 0, from s_inv_ne_zero Hs Hsep _,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite [↑smul, ↑one, mul.comm, -(mul_one_div_cancel Hnz),
|
2015-12-06 07:27:46 +00:00
|
|
|
|
-mul_sub_left_distrib, abs_mul],
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply le.trans,
|
2015-10-13 19:07:36 +00:00
|
|
|
|
apply mul_le_mul_of_nonneg_right,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply canon_2_bound_right s,
|
|
|
|
|
apply Rsi,
|
|
|
|
|
apply abs_nonneg,
|
2015-06-01 13:00:27 +00:00
|
|
|
|
have Hp : (K₂ s (s_inv Hs)) * 2 * n ≥ ps Hs Hsep, begin
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.le_trans,
|
|
|
|
|
apply pnat.max_left,
|
2015-06-01 13:00:27 +00:00
|
|
|
|
rotate 1,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.le_trans,
|
2015-06-01 13:00:27 +00:00
|
|
|
|
apply Hn,
|
|
|
|
|
apply pnat.mul_le_mul_left
|
|
|
|
|
end,
|
|
|
|
|
have Hnz' : s (((ps Hs Hsep) * (ps Hs Hsep)) * ((K₂ s (s_inv Hs)) * 2 * n)) ≠ 0, from
|
2015-06-10 02:46:30 +00:00
|
|
|
|
s_ne_zero_of_ge_p Hs Hsep
|
|
|
|
|
(show ps Hs Hsep ≤ ((ps Hs Hsep) * (ps Hs Hsep)) * ((K₂ s (s_inv Hs)) * 2 * n),
|
2015-10-23 02:18:14 +00:00
|
|
|
|
by rewrite *pnat.mul_assoc; apply pnat.mul_le_mul_right),
|
2015-08-27 17:29:19 +00:00
|
|
|
|
rewrite [(s_inv_of_sep_gt_p Hs Hsep Hp), (division_ring.one_div_one_div Hnz')],
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply rat.le_trans,
|
2015-10-13 19:07:36 +00:00
|
|
|
|
apply mul_le_mul_of_nonneg_left,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply Hs,
|
|
|
|
|
apply le_of_lt,
|
|
|
|
|
apply rat_of_pnat_is_pos,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite [left_distrib, pnat.mul_comm ((ps Hs Hsep) * (ps Hs Hsep)), *pnat.mul_assoc,
|
|
|
|
|
*(@pnat.inv_mul_eq_mul_inv (K₂ s (s_inv Hs))), -*mul.assoc, *pnat.inv_cancel_left,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
*one_mul, -(pnat.add_halves j)],
|
2015-10-13 19:07:36 +00:00
|
|
|
|
apply add_le_add,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply inv_ge_of_le,
|
|
|
|
|
apply pnat_mul_le_mul_left',
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.le_trans,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
rotate 1,
|
|
|
|
|
apply Hn,
|
|
|
|
|
rotate_right 1,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.max_right,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply inv_ge_of_le,
|
|
|
|
|
apply pnat_mul_le_mul_left',
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.le_trans,
|
|
|
|
|
apply pnat.max_right,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
rotate 1,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.le_trans,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply Hn,
|
|
|
|
|
apply pnat.mul_le_mul_right
|
|
|
|
|
end
|
|
|
|
|
|
2015-10-29 19:36:26 +00:00
|
|
|
|
protected theorem inv_mul {s : seq} (Hs : regular s) (Hsep : sep s zero) :
|
2015-10-23 12:54:32 +00:00
|
|
|
|
smul (s_inv Hs) s ≡ one :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
begin
|
|
|
|
|
apply equiv.trans,
|
|
|
|
|
rotate 3,
|
|
|
|
|
apply s_mul_comm,
|
2015-10-23 12:54:32 +00:00
|
|
|
|
apply rat_seq.mul_inv,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
repeat (assumption | apply reg_mul_reg | apply reg_inv_reg | apply zero_is_reg)
|
|
|
|
|
end
|
|
|
|
|
|
2015-06-01 13:00:27 +00:00
|
|
|
|
theorem sep_of_equiv_sep {s t : seq} (Hs : regular s) (Ht : regular t) (Heq : s ≡ t)
|
|
|
|
|
(Hsep : sep s zero) : sep t zero :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
begin
|
|
|
|
|
apply or.elim Hsep,
|
|
|
|
|
intro Hslt,
|
|
|
|
|
apply or.inl,
|
|
|
|
|
rewrite ↑s_lt at *,
|
|
|
|
|
apply pos_of_pos_equiv,
|
|
|
|
|
rotate 2,
|
|
|
|
|
apply Hslt,
|
|
|
|
|
rotate_right 1,
|
|
|
|
|
apply add_well_defined,
|
|
|
|
|
rotate 4,
|
|
|
|
|
apply equiv.refl,
|
|
|
|
|
apply neg_well_defined,
|
|
|
|
|
apply Heq,
|
|
|
|
|
intro Hslt,
|
|
|
|
|
apply or.inr,
|
|
|
|
|
rewrite ↑s_lt at *,
|
|
|
|
|
apply pos_of_pos_equiv,
|
|
|
|
|
rotate 2,
|
|
|
|
|
apply Hslt,
|
|
|
|
|
rotate_right 1,
|
|
|
|
|
apply add_well_defined,
|
|
|
|
|
rotate 5,
|
|
|
|
|
apply equiv.refl,
|
|
|
|
|
repeat (assumption | apply reg_neg_reg | apply reg_add_reg | apply zero_is_reg)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem inv_unique {s t : seq} (Hs : regular s) (Ht : regular t) (Hsep : sep s zero)
|
|
|
|
|
(Heq : smul s t ≡ one) : s_inv Hs ≡ t :=
|
|
|
|
|
begin
|
|
|
|
|
apply equiv.trans,
|
|
|
|
|
rotate 3,
|
|
|
|
|
apply equiv.symm,
|
|
|
|
|
apply s_mul_one,
|
|
|
|
|
rotate 1,
|
|
|
|
|
apply equiv.trans,
|
|
|
|
|
rotate 3,
|
|
|
|
|
apply mul_well_defined,
|
|
|
|
|
rotate 4,
|
|
|
|
|
apply equiv.refl,
|
|
|
|
|
apply equiv.symm,
|
|
|
|
|
apply Heq,
|
|
|
|
|
apply equiv.trans,
|
|
|
|
|
rotate 3,
|
|
|
|
|
apply equiv.symm,
|
|
|
|
|
apply s_mul_assoc,
|
|
|
|
|
rotate 3,
|
|
|
|
|
apply equiv.trans,
|
|
|
|
|
rotate 3,
|
|
|
|
|
apply mul_well_defined,
|
|
|
|
|
rotate 4,
|
2015-10-23 12:54:32 +00:00
|
|
|
|
apply rat_seq.inv_mul,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
rotate 1,
|
|
|
|
|
apply equiv.refl,
|
|
|
|
|
apply s_one_mul,
|
|
|
|
|
repeat (assumption | apply reg_inv_reg | apply reg_mul_reg | apply one_is_reg)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem inv_well_defined {s t : seq} (Hs : regular s) (Ht : regular t) (Heq : s ≡ t) :
|
|
|
|
|
s_inv Hs ≡ s_inv Ht :=
|
|
|
|
|
if Hsep : sep s zero then
|
|
|
|
|
(begin
|
2015-12-10 18:37:55 +00:00
|
|
|
|
note Hsept := sep_of_equiv_sep Hs Ht Heq Hsep,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
have Hm : smul t (s_inv Hs) ≡ smul s (s_inv Hs), begin
|
|
|
|
|
apply mul_well_defined,
|
|
|
|
|
repeat (assumption | apply reg_inv_reg),
|
|
|
|
|
apply equiv.symm s t Heq,
|
|
|
|
|
apply equiv.refl
|
|
|
|
|
end,
|
|
|
|
|
apply equiv.symm,
|
|
|
|
|
apply inv_unique,
|
|
|
|
|
rotate 2,
|
|
|
|
|
apply equiv.trans,
|
|
|
|
|
rotate 3,
|
|
|
|
|
apply Hm,
|
2015-10-23 12:54:32 +00:00
|
|
|
|
apply rat_seq.mul_inv,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
repeat (assumption | apply reg_inv_reg | apply reg_mul_reg),
|
|
|
|
|
apply one_is_reg
|
|
|
|
|
end)
|
|
|
|
|
else
|
2015-10-13 19:07:36 +00:00
|
|
|
|
(assert H : s_inv Hs = zero, from funext (λ n, dif_neg Hsep),
|
2015-06-10 02:46:30 +00:00
|
|
|
|
have Hsept : ¬ sep t zero, from
|
2015-06-01 11:57:11 +00:00
|
|
|
|
assume H', Hsep (sep_of_equiv_sep Ht Hs (equiv.symm _ _ Heq) H'),
|
2015-10-13 19:07:36 +00:00
|
|
|
|
assert H' : s_inv Ht = zero, from funext (λ n, dif_neg Hsept),
|
|
|
|
|
by rewrite [H', H]; apply equiv.refl)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-06-10 02:46:30 +00:00
|
|
|
|
theorem s_neg_neg {s : seq} : sneg (sneg s) ≡ s :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
begin
|
|
|
|
|
rewrite [↑equiv, ↑sneg],
|
|
|
|
|
intro n,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
rewrite [neg_neg, sub_self, abs_zero],
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply add_invs_nonneg
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem s_neg_sub {s t : seq} (Hs : regular s) (Ht : regular t) :
|
2015-06-10 02:46:30 +00:00
|
|
|
|
sneg (sadd s (sneg t)) ≡ sadd t (sneg s) :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
begin
|
|
|
|
|
apply equiv.trans,
|
|
|
|
|
rotate 3,
|
|
|
|
|
apply s_neg_add_eq_s_add_neg,
|
|
|
|
|
apply equiv.trans,
|
|
|
|
|
rotate 3,
|
|
|
|
|
apply add_well_defined,
|
|
|
|
|
rotate 4,
|
|
|
|
|
apply equiv.refl,
|
|
|
|
|
apply s_neg_neg,
|
|
|
|
|
apply s_add_comm,
|
|
|
|
|
repeat (assumption | apply reg_add_reg | apply reg_neg_reg)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem s_le_total {s t : seq} (Hs : regular s) (Ht : regular t) : s_le s t ∨ s_le t s :=
|
|
|
|
|
if H : s_le s t then or.inl H else or.inr begin
|
|
|
|
|
rewrite [↑s_le at *],
|
|
|
|
|
have H' : ∃ n : ℕ+, -n⁻¹ > sadd t (sneg s) n, begin
|
|
|
|
|
apply by_contradiction,
|
|
|
|
|
intro Hex,
|
|
|
|
|
have Hex' : ∀ n : ℕ+, -n⁻¹ ≤ sadd t (sneg s) n, begin
|
|
|
|
|
intro m,
|
|
|
|
|
apply by_contradiction,
|
|
|
|
|
intro Hm,
|
2015-12-10 18:37:55 +00:00
|
|
|
|
note Hm' := lt_of_not_ge Hm,
|
|
|
|
|
note Hex'' := exists.intro m Hm',
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply Hex Hex''
|
|
|
|
|
end,
|
|
|
|
|
apply H Hex'
|
|
|
|
|
end,
|
|
|
|
|
eapply exists.elim H',
|
|
|
|
|
intro m Hm,
|
2015-12-10 18:37:55 +00:00
|
|
|
|
note Hm' := neg_lt_neg Hm,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
rewrite neg_neg at Hm',
|
|
|
|
|
apply s_nonneg_of_pos,
|
|
|
|
|
rotate 1,
|
|
|
|
|
apply pos_of_pos_equiv,
|
|
|
|
|
rotate 1,
|
|
|
|
|
apply s_neg_sub,
|
|
|
|
|
rotate 2,
|
|
|
|
|
rewrite [↑pos, ↑sneg],
|
|
|
|
|
existsi m,
|
|
|
|
|
apply Hm',
|
|
|
|
|
repeat (assumption | apply reg_add_reg | apply reg_neg_reg)
|
|
|
|
|
end
|
|
|
|
|
|
2015-06-10 02:46:30 +00:00
|
|
|
|
theorem s_le_of_not_lt {s t : seq} (Hle : ¬ s_lt s t) : s_le t s :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
begin
|
|
|
|
|
rewrite [↑s_le, ↑nonneg, ↑s_lt at Hle, ↑pos at Hle],
|
2015-07-24 15:56:18 +00:00
|
|
|
|
let Hle' := iff.mp forall_iff_not_exists Hle,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
intro n,
|
2015-10-13 19:07:36 +00:00
|
|
|
|
let Hn := neg_le_neg (le_of_not_gt (Hle' n)),
|
2015-08-03 19:02:03 +00:00
|
|
|
|
rewrite [↑sadd, ↑sneg, add_neg_eq_neg_add_rev],
|
2015-06-01 11:57:11 +00:00
|
|
|
|
apply Hn
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem sep_of_nequiv {s t : seq} (Hs : regular s) (Ht : regular t) (Hneq : ¬ equiv s t) :
|
|
|
|
|
sep s t :=
|
|
|
|
|
begin
|
|
|
|
|
rewrite ↑sep,
|
|
|
|
|
apply by_contradiction,
|
|
|
|
|
intro Hnor,
|
2015-09-11 03:00:18 +00:00
|
|
|
|
let Hand := iff.mp !not_or_iff_not_and_not Hnor,
|
2015-06-01 11:57:11 +00:00
|
|
|
|
let Hle1 := s_le_of_not_lt (and.left Hand),
|
|
|
|
|
let Hle2 := s_le_of_not_lt (and.right Hand),
|
|
|
|
|
apply Hneq (equiv_of_le_of_ge Hs Ht Hle2 Hle1)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem s_zero_inv_equiv_zero : s_inv zero_is_reg ≡ zero :=
|
|
|
|
|
by rewrite s_inv_zero; apply equiv.refl
|
|
|
|
|
|
|
|
|
|
theorem lt_or_equiv_of_le {s t : seq} (Hs : regular s) (Ht : regular t) (Hle : s_le s t) :
|
2015-06-10 02:46:30 +00:00
|
|
|
|
s_lt s t ∨ s ≡ t :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
if H : s ≡ t then or.inr H else
|
|
|
|
|
or.inl (lt_of_le_and_sep Hs Ht (and.intro Hle (sep_of_nequiv Hs Ht H)))
|
|
|
|
|
|
2015-06-10 02:46:30 +00:00
|
|
|
|
theorem s_le_of_equiv_le_left {s t u : seq} (Hs : regular s) (Ht : regular t) (Hu : regular u)
|
2015-06-09 05:39:28 +00:00
|
|
|
|
(Heq : s ≡ t) (Hle : s_le s u) : s_le t u :=
|
|
|
|
|
begin
|
|
|
|
|
rewrite ↑s_le at *,
|
|
|
|
|
apply nonneg_of_nonneg_equiv,
|
|
|
|
|
rotate 2,
|
|
|
|
|
apply add_well_defined,
|
|
|
|
|
rotate 4,
|
|
|
|
|
apply equiv.refl,
|
|
|
|
|
apply neg_well_defined,
|
|
|
|
|
apply Heq,
|
|
|
|
|
repeat (assumption | apply reg_add_reg | apply reg_neg_reg)
|
|
|
|
|
end
|
|
|
|
|
|
2015-06-10 02:46:30 +00:00
|
|
|
|
theorem s_le_of_equiv_le_right {s t u : seq} (Hs : regular s) (Ht : regular t) (Hu : regular u)
|
2015-06-09 05:39:28 +00:00
|
|
|
|
(Heq : t ≡ u) (Hle : s_le s t) : s_le s u :=
|
|
|
|
|
begin
|
|
|
|
|
rewrite ↑s_le at *,
|
|
|
|
|
apply nonneg_of_nonneg_equiv,
|
|
|
|
|
rotate 2,
|
|
|
|
|
apply add_well_defined,
|
|
|
|
|
rotate 4,
|
|
|
|
|
apply Heq,
|
|
|
|
|
apply equiv.refl,
|
|
|
|
|
repeat (assumption | apply reg_add_reg | apply reg_neg_reg)
|
|
|
|
|
end
|
|
|
|
|
|
2015-06-01 11:57:11 +00:00
|
|
|
|
-----------------------------
|
|
|
|
|
|
2015-07-29 04:56:35 +00:00
|
|
|
|
noncomputable definition r_inv (s : reg_seq) : reg_seq := reg_seq.mk (s_inv (reg_seq.is_reg s))
|
2015-06-10 02:46:30 +00:00
|
|
|
|
(if H : sep (reg_seq.sq s) zero then reg_inv_reg (reg_seq.is_reg s) H else
|
2015-10-29 19:36:26 +00:00
|
|
|
|
assert Hz : s_inv (reg_seq.is_reg s) = zero, from funext (λ n, dif_neg H),
|
2015-10-23 12:54:32 +00:00
|
|
|
|
by rewrite Hz; apply zero_is_reg)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-06-10 02:46:30 +00:00
|
|
|
|
theorem r_inv_zero : requiv (r_inv r_zero) r_zero :=
|
2015-06-01 11:57:11 +00:00
|
|
|
|
s_zero_inv_equiv_zero
|
2015-06-10 02:46:30 +00:00
|
|
|
|
|
2015-06-01 11:57:11 +00:00
|
|
|
|
theorem r_inv_well_defined {s t : reg_seq} (H : requiv s t) : requiv (r_inv s) (r_inv t) :=
|
|
|
|
|
inv_well_defined (reg_seq.is_reg s) (reg_seq.is_reg t) H
|
|
|
|
|
|
|
|
|
|
theorem r_le_total (s t : reg_seq) : r_le s t ∨ r_le t s :=
|
|
|
|
|
s_le_total (reg_seq.is_reg s) (reg_seq.is_reg t)
|
|
|
|
|
|
2015-06-10 02:46:30 +00:00
|
|
|
|
theorem r_mul_inv (s : reg_seq) (Hsep : r_sep s r_zero) : requiv (s * (r_inv s)) r_one :=
|
2015-10-23 12:54:32 +00:00
|
|
|
|
rat_seq.mul_inv (reg_seq.is_reg s) Hsep
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
|
|
|
|
theorem r_sep_of_nequiv (s t : reg_seq) (Hneq : ¬ requiv s t) : r_sep s t :=
|
|
|
|
|
sep_of_nequiv (reg_seq.is_reg s) (reg_seq.is_reg t) Hneq
|
|
|
|
|
|
|
|
|
|
theorem r_lt_or_equiv_of_le (s t : reg_seq) (Hle : r_le s t) : r_lt s t ∨ requiv s t :=
|
|
|
|
|
lt_or_equiv_of_le (reg_seq.is_reg s) (reg_seq.is_reg t) Hle
|
|
|
|
|
|
2015-06-09 05:39:28 +00:00
|
|
|
|
theorem r_le_of_equiv_le_left {s t u : reg_seq} (Heq : requiv s t) (Hle : r_le s u) : r_le t u :=
|
|
|
|
|
s_le_of_equiv_le_left (reg_seq.is_reg s) (reg_seq.is_reg t) (reg_seq.is_reg u) Heq Hle
|
|
|
|
|
|
|
|
|
|
theorem r_le_of_equiv_le_right {s t u : reg_seq} (Heq : requiv t u) (Hle : r_le s t) : r_le s u :=
|
|
|
|
|
s_le_of_equiv_le_right (reg_seq.is_reg s) (reg_seq.is_reg t) (reg_seq.is_reg u) Heq Hle
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
definition r_abs (s : reg_seq) : reg_seq :=
|
|
|
|
|
reg_seq.mk (s_abs (reg_seq.sq s)) (abs_reg_of_reg (reg_seq.is_reg s))
|
|
|
|
|
|
|
|
|
|
theorem r_abs_well_defined {s t : reg_seq} (H : requiv s t) : requiv (r_abs s) (r_abs t) :=
|
|
|
|
|
abs_well_defined (reg_seq.is_reg s) (reg_seq.is_reg t) H
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
end rat_seq
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
|
|
|
|
namespace real
|
2015-12-28 18:30:23 +00:00
|
|
|
|
open [class] rat_seq
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-10-29 19:36:26 +00:00
|
|
|
|
noncomputable protected definition inv (x : ℝ) : ℝ :=
|
2015-10-23 12:54:32 +00:00
|
|
|
|
quot.lift_on x (λ a, quot.mk (rat_seq.r_inv a))
|
2015-09-11 03:00:18 +00:00
|
|
|
|
(λ a b H, quot.sound (rat_seq.r_inv_well_defined H))
|
2015-10-13 19:07:36 +00:00
|
|
|
|
|
2015-10-14 00:49:45 +00:00
|
|
|
|
noncomputable definition real_has_inv [instance] [reducible] [priority real.prio] : has_inv real :=
|
2015-10-23 12:54:32 +00:00
|
|
|
|
has_inv.mk real.inv
|
2015-10-14 00:49:45 +00:00
|
|
|
|
|
2015-10-29 19:36:26 +00:00
|
|
|
|
noncomputable protected definition div (x y : ℝ) : ℝ :=
|
2015-10-23 12:54:32 +00:00
|
|
|
|
x * y⁻¹
|
2015-10-14 00:49:45 +00:00
|
|
|
|
|
2016-02-14 15:16:13 +00:00
|
|
|
|
noncomputable definition real_has_div : has_div real :=
|
2015-10-29 19:36:26 +00:00
|
|
|
|
has_div.mk real.div
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2016-02-14 15:16:13 +00:00
|
|
|
|
local attribute real_has_div [instance] [reducible] [priority real.prio]
|
|
|
|
|
|
2015-10-23 12:54:32 +00:00
|
|
|
|
protected theorem le_total (x y : ℝ) : x ≤ y ∨ y ≤ x :=
|
2015-09-11 03:00:18 +00:00
|
|
|
|
quot.induction_on₂ x y (λ s t, rat_seq.r_le_total s t)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-10-23 12:54:32 +00:00
|
|
|
|
protected theorem mul_inv_cancel' (x : ℝ) : x ≢ 0 → x * x⁻¹ = 1 :=
|
2015-09-11 03:00:18 +00:00
|
|
|
|
quot.induction_on x (λ s H, quot.sound (rat_seq.r_mul_inv s H))
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-10-23 12:54:32 +00:00
|
|
|
|
protected theorem inv_mul_cancel' (x : ℝ) : x ≢ 0 → x⁻¹ * x = 1 :=
|
|
|
|
|
by rewrite real.mul_comm; apply real.mul_inv_cancel'
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
|
|
|
|
theorem neq_of_sep {x y : ℝ} (H : x ≢ y) : ¬ x = y :=
|
|
|
|
|
assume Heq, !not_sep_self (Heq ▸ H)
|
|
|
|
|
|
|
|
|
|
theorem sep_of_neq {x y : ℝ} : ¬ x = y → x ≢ y :=
|
2015-09-11 03:00:18 +00:00
|
|
|
|
quot.induction_on₂ x y (λ s t H, rat_seq.r_sep_of_nequiv s t (assume Heq, H (quot.sound Heq)))
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
|
|
|
|
theorem sep_is_neq (x y : ℝ) : (x ≢ y) = (¬ x = y) :=
|
2015-06-10 02:46:30 +00:00
|
|
|
|
propext (iff.intro neq_of_sep sep_of_neq)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-10-29 19:36:26 +00:00
|
|
|
|
protected theorem mul_inv_cancel (x : ℝ) : x ≠ 0 → x * x⁻¹ = 1 :=
|
2015-10-23 12:54:32 +00:00
|
|
|
|
!sep_is_neq ▸ !real.mul_inv_cancel'
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-10-29 19:36:26 +00:00
|
|
|
|
protected theorem inv_mul_cancel (x : ℝ) : x ≠ 0 → x⁻¹ * x = 1 :=
|
2015-10-23 12:54:32 +00:00
|
|
|
|
!sep_is_neq ▸ !real.inv_mul_cancel'
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-10-23 12:54:32 +00:00
|
|
|
|
protected theorem inv_zero : (0 : ℝ)⁻¹ = 0 := quot.sound (rat_seq.r_inv_zero)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-10-23 12:54:32 +00:00
|
|
|
|
protected theorem lt_or_eq_of_le (x y : ℝ) : x ≤ y → x < y ∨ x = y :=
|
2015-09-11 03:00:18 +00:00
|
|
|
|
quot.induction_on₂ x y (λ s t H, or.elim (rat_seq.r_lt_or_equiv_of_le s t H)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
(assume H1, or.inl H1)
|
|
|
|
|
(assume H2, or.inr (quot.sound H2)))
|
|
|
|
|
|
2015-10-23 12:54:32 +00:00
|
|
|
|
protected theorem le_iff_lt_or_eq (x y : ℝ) : x ≤ y ↔ x < y ∨ x = y :=
|
|
|
|
|
iff.intro (real.lt_or_eq_of_le x y) (real.le_of_lt_or_eq x y)
|
2015-06-01 11:57:11 +00:00
|
|
|
|
|
2015-10-13 22:09:02 +00:00
|
|
|
|
noncomputable definition dec_lt : decidable_rel real.lt :=
|
2015-06-10 02:46:30 +00:00
|
|
|
|
begin
|
2015-06-01 11:57:11 +00:00
|
|
|
|
rewrite ↑decidable_rel,
|
|
|
|
|
intros,
|
|
|
|
|
apply prop_decidable
|
|
|
|
|
end
|
|
|
|
|
|
2015-10-13 22:09:02 +00:00
|
|
|
|
protected noncomputable definition discrete_linear_ordered_field [reducible] [trans_instance]:
|
2015-12-06 07:27:46 +00:00
|
|
|
|
discrete_linear_ordered_field ℝ :=
|
|
|
|
|
⦃ discrete_linear_ordered_field, real.comm_ring, real.ordered_ring,
|
2015-10-23 12:54:32 +00:00
|
|
|
|
le_total := real.le_total,
|
|
|
|
|
mul_inv_cancel := real.mul_inv_cancel,
|
|
|
|
|
inv_mul_cancel := real.inv_mul_cancel,
|
|
|
|
|
zero_lt_one := real.zero_lt_one,
|
|
|
|
|
inv_zero := real.inv_zero,
|
|
|
|
|
le_iff_lt_or_eq := real.le_iff_lt_or_eq,
|
|
|
|
|
decidable_lt := dec_lt
|
2015-06-01 11:57:11 +00:00
|
|
|
|
⦄
|
|
|
|
|
|
2015-09-13 00:04:57 +00:00
|
|
|
|
theorem of_rat_divide (x y : ℚ) : of_rat (x / y) = of_rat x / of_rat y :=
|
|
|
|
|
by_cases
|
2015-12-06 07:27:46 +00:00
|
|
|
|
(assume yz : y = 0, by krewrite [yz, div_zero, +of_rat_zero, div_zero])
|
2015-09-13 00:04:57 +00:00
|
|
|
|
(assume ynz : y ≠ 0,
|
|
|
|
|
have ynz' : of_rat y ≠ 0, from assume yz', ynz (of_rat.inj yz'),
|
2015-10-13 22:09:02 +00:00
|
|
|
|
!eq_div_of_mul_eq ynz' (by krewrite [-of_rat_mul, !div_mul_cancel ynz]))
|
2015-10-13 19:07:36 +00:00
|
|
|
|
|
|
|
|
|
open int
|
2015-09-13 00:04:57 +00:00
|
|
|
|
|
2015-10-29 19:36:26 +00:00
|
|
|
|
theorem of_int_div (x y : ℤ) (H : y ∣ x) : of_int (x / y) = of_int x / of_int y :=
|
2015-09-13 00:04:57 +00:00
|
|
|
|
by rewrite [of_int_eq, rat.of_int_div H, of_rat_divide]
|
|
|
|
|
|
2015-10-29 19:36:26 +00:00
|
|
|
|
theorem of_nat_div (x y : ℕ) (H : y ∣ x) : of_nat (x / y) = of_nat x / of_nat y :=
|
2015-09-13 00:04:57 +00:00
|
|
|
|
by rewrite [of_nat_eq, rat.of_nat_div H, of_rat_divide]
|
|
|
|
|
|
2015-09-13 01:16:55 +00:00
|
|
|
|
/- useful for proving equalities -/
|
|
|
|
|
|
|
|
|
|
theorem eq_zero_of_nonneg_of_forall_lt {x : ℝ} (xnonneg : x ≥ 0) (H : ∀ ε : ℝ, ε > 0 → x < ε) :
|
|
|
|
|
x = 0 :=
|
|
|
|
|
decidable.by_contradiction
|
|
|
|
|
(suppose x ≠ 0,
|
2015-10-13 19:07:36 +00:00
|
|
|
|
have x > 0, from lt_of_le_of_ne xnonneg (ne.symm this),
|
2015-09-13 01:16:55 +00:00
|
|
|
|
have x < x, from H x this,
|
|
|
|
|
show false, from !lt.irrefl this)
|
|
|
|
|
|
|
|
|
|
theorem eq_zero_of_nonneg_of_forall_le {x : ℝ} (xnonneg : x ≥ 0) (H : ∀ ε : ℝ, ε > 0 → x ≤ ε) :
|
|
|
|
|
x = 0 :=
|
|
|
|
|
have ∀ ε : ℝ, ε > 0 → x < ε, from
|
|
|
|
|
take ε, suppose ε > 0,
|
2015-10-13 19:07:36 +00:00
|
|
|
|
assert e2pos : ε / 2 > 0, from div_pos_of_pos_of_pos `ε > 0` two_pos,
|
|
|
|
|
assert ε / 2 < ε, from div_two_lt_of_pos `ε > 0`,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
begin apply lt_of_le_of_lt, apply H _ e2pos, apply this end,
|
2015-09-13 01:16:55 +00:00
|
|
|
|
eq_zero_of_nonneg_of_forall_lt xnonneg this
|
|
|
|
|
|
|
|
|
|
theorem eq_zero_of_forall_abs_le {x : ℝ} (H : ∀ ε : ℝ, ε > 0 → abs x ≤ ε) :
|
|
|
|
|
x = 0 :=
|
|
|
|
|
by_contradiction
|
|
|
|
|
(suppose x ≠ 0,
|
|
|
|
|
have abs x = 0, from eq_zero_of_nonneg_of_forall_le !abs_nonneg H,
|
|
|
|
|
show false, from `x ≠ 0` (eq_zero_of_abs_eq_zero this))
|
|
|
|
|
|
|
|
|
|
theorem eq_of_forall_abs_sub_le {x y : ℝ} (H : ∀ ε : ℝ, ε > 0 → abs (x - y) ≤ ε) :
|
|
|
|
|
x = y :=
|
|
|
|
|
have x - y = 0, from eq_zero_of_forall_abs_le H,
|
|
|
|
|
eq_of_sub_eq_zero this
|
2015-06-01 11:57:11 +00:00
|
|
|
|
end real
|