2015-06-11 07:00:35 +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
|
|
|
|
|
|
|
|
|
|
Basic facts about the positive natural numbers.
|
|
|
|
|
|
|
|
|
|
Developed primarily for use in the construction of ℝ. For the most part, the only theorems here
|
|
|
|
|
are those needed for that construction.
|
|
|
|
|
-/
|
|
|
|
|
import data.rat.order data.nat
|
2015-07-24 15:56:18 +00:00
|
|
|
|
open nat rat subtype eq.ops
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
namespace pnat
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-07-24 15:56:18 +00:00
|
|
|
|
definition pnat := { n : ℕ | n > 0 }
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
notation `ℕ+` := pnat
|
|
|
|
|
|
2015-07-29 23:11:23 +00:00
|
|
|
|
definition pos (n : ℕ) (H : n > 0) : ℕ+ := tag n H
|
2015-07-24 15:56:18 +00:00
|
|
|
|
|
|
|
|
|
definition nat_of_pnat (p : ℕ+) : ℕ := elt_of p
|
2015-06-17 19:58:58 +00:00
|
|
|
|
reserve postfix `~`:std.prec.max_plus
|
|
|
|
|
local postfix ~ := nat_of_pnat
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-07-24 15:56:18 +00:00
|
|
|
|
theorem pnat_pos (p : ℕ+) : p~ > 0 := has_property p
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
protected definition add (p q : ℕ+) : ℕ+ :=
|
|
|
|
|
tag (p~ + q~) (add_pos (pnat_pos p) (pnat_pos q))
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
protected definition mul (p q : ℕ+) : ℕ+ :=
|
|
|
|
|
tag (p~ * q~) (mul_pos (pnat_pos p) (pnat_pos q))
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
protected definition le (p q : ℕ+) := p~ ≤ q~
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
protected definition lt (p q : ℕ+) := p~ < q~
|
|
|
|
|
|
2016-02-25 20:26:20 +00:00
|
|
|
|
definition pnat_has_add [instance] : has_add pnat :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
has_add.mk pnat.add
|
|
|
|
|
|
2016-02-25 20:26:20 +00:00
|
|
|
|
definition pnat_has_mul [instance] : has_mul pnat :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
has_mul.mk pnat.mul
|
|
|
|
|
|
2016-02-25 20:26:20 +00:00
|
|
|
|
definition pnat_has_le [instance] : has_le pnat :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
has_le.mk pnat.le
|
|
|
|
|
|
2016-02-25 20:26:20 +00:00
|
|
|
|
definition pnat_has_lt [instance] : has_lt pnat :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
has_lt.mk pnat.lt
|
|
|
|
|
|
2016-02-25 20:26:20 +00:00
|
|
|
|
definition pnat_has_one [instance] : has_one pnat :=
|
2015-10-12 03:29:31 +00:00
|
|
|
|
has_one.mk (pos (1:nat) dec_trivial)
|
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected lemma mul_def (p q : ℕ+) : p * q = tag (p~ * q~) (mul_pos (pnat_pos p) (pnat_pos q)) :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
rfl
|
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected lemma le_def (p q : ℕ+) : (p ≤ q) = (p~ ≤ q~) :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
rfl
|
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected lemma lt_def (p q : ℕ+) : (p < q) = (p~ < q~) :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
rfl
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
protected theorem pnat.eq {p q : ℕ+} : p~ = q~ → p = q :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
subtype.eq
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-07-24 15:56:18 +00:00
|
|
|
|
definition pnat_le_decidable [instance] (p q : ℕ+) : decidable (p ≤ q) :=
|
2015-10-23 02:18:14 +00:00
|
|
|
|
begin rewrite pnat.le_def, exact nat.decidable_le p~ q~ end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-07-24 15:56:18 +00:00
|
|
|
|
definition pnat_lt_decidable [instance] {p q : ℕ+} : decidable (p < q) :=
|
2015-10-23 02:18:14 +00:00
|
|
|
|
begin rewrite pnat.lt_def, exact nat.decidable_lt p~ q~ end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem le_trans {p q r : ℕ+} : p ≤ q → q ≤ r → p ≤ r :=
|
|
|
|
|
begin rewrite *pnat.le_def, apply nat.le_trans end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
definition max (p q : ℕ+) : ℕ+ :=
|
|
|
|
|
tag (max p~ q~) (lt_of_lt_of_le (!pnat_pos) (!le_max_right))
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem max_right (a b : ℕ+) : max a b ≥ b :=
|
|
|
|
|
begin change b ≤ max a b, rewrite pnat.le_def, apply le_max_right end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem max_left (a b : ℕ+) : max a b ≥ a :=
|
|
|
|
|
begin change a ≤ max a b, rewrite pnat.le_def, apply le_max_left end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem max_eq_right {a b : ℕ+} (H : a < b) : max a b = b :=
|
|
|
|
|
begin rewrite pnat.lt_def at H, exact pnat.eq (max_eq_right_of_lt H) end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem max_eq_left {a b : ℕ+} (H : ¬ a < b) : max a b = a :=
|
|
|
|
|
begin rewrite pnat.lt_def at H, exact pnat.eq (max_eq_left (le_of_not_gt H)) end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem le_of_lt {a b : ℕ+} : a < b → a ≤ b :=
|
|
|
|
|
begin rewrite [pnat.lt_def, pnat.le_def], apply nat.le_of_lt end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem not_lt_of_ge {a b : ℕ+} : a ≤ b → ¬ (b < a) :=
|
|
|
|
|
begin rewrite [pnat.lt_def, pnat.le_def], apply not_lt_of_ge end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem le_of_not_gt {a b : ℕ+} : ¬ a < b → b ≤ a :=
|
|
|
|
|
begin rewrite [pnat.lt_def, pnat.le_def], apply le_of_not_gt end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem eq_of_le_of_ge {a b : ℕ+} : a ≤ b → b ≤ a → a = b :=
|
|
|
|
|
begin rewrite [+pnat.le_def], intros H1 H2, exact pnat.eq (eq_of_le_of_ge H1 H2) end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem le_refl (a : ℕ+) : a ≤ a :=
|
|
|
|
|
begin rewrite pnat.le_def end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-07-24 15:56:18 +00:00
|
|
|
|
notation 2 := (tag 2 dec_trivial : ℕ+)
|
|
|
|
|
notation 3 := (tag 3 dec_trivial : ℕ+)
|
|
|
|
|
definition pone : ℕ+ := tag 1 dec_trivial
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
definition rat_of_pnat [reducible] (n : ℕ+) : ℚ :=
|
|
|
|
|
n~
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
theorem pnat.to_rat_of_nat (n : ℕ+) : rat_of_pnat n = of_nat n~ :=
|
|
|
|
|
rfl
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
-- these will come in rat
|
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
theorem rat_of_nat_nonneg (n : ℕ) : 0 ≤ of_nat n :=
|
|
|
|
|
trivial
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem rat_of_pnat_ge_one (n : ℕ+) : rat_of_pnat n ≥ 1 :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
of_nat_le_of_nat_of_le (pnat_pos n)
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem rat_of_pnat_is_pos (n : ℕ+) : rat_of_pnat n > 0 :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
of_nat_lt_of_nat_of_lt (pnat_pos n)
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem of_nat_le_of_nat_of_le {m n : ℕ} (H : m ≤ n) : of_nat m ≤ of_nat n :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
of_nat_le_of_nat_of_le H
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem of_nat_lt_of_nat_of_lt {m n : ℕ} (H : m < n) : of_nat m < of_nat n :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
of_nat_lt_of_nat_of_lt H
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem rat_of_pnat_le_of_pnat_le {m n : ℕ+} (H : m ≤ n) : rat_of_pnat m ≤ rat_of_pnat n :=
|
2015-10-23 02:18:14 +00:00
|
|
|
|
begin rewrite pnat.le_def at H, exact of_nat_le_of_nat_of_le H end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem rat_of_pnat_lt_of_pnat_lt {m n : ℕ+} (H : m < n) : rat_of_pnat m < rat_of_pnat n :=
|
2015-10-23 02:18:14 +00:00
|
|
|
|
begin rewrite pnat.lt_def at H, exact of_nat_lt_of_nat_of_lt H end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem pnat_le_of_rat_of_pnat_le {m n : ℕ+} (H : rat_of_pnat m ≤ rat_of_pnat n) : m ≤ n :=
|
2015-10-23 02:18:14 +00:00
|
|
|
|
begin rewrite pnat.le_def, exact le_of_of_nat_le_of_nat H end
|
2015-10-10 00:21:17 +00:00
|
|
|
|
|
|
|
|
|
definition inv (n : ℕ+) : ℚ :=
|
|
|
|
|
(1 : ℚ) / rat_of_pnat n
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
local postfix `⁻¹` := inv
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem inv_pos (n : ℕ+) : n⁻¹ > 0 := one_div_pos_of_pos !rat_of_pnat_is_pos
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem inv_le_one (n : ℕ+) : n⁻¹ ≤ (1 : ℚ) :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
|
|
|
|
unfold inv,
|
|
|
|
|
change 1 / rat_of_pnat n ≤ 1 / 1,
|
|
|
|
|
apply one_div_le_one_div_of_le,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply zero_lt_one,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply rat_of_pnat_ge_one
|
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem inv_lt_one_of_gt {n : ℕ+} (H : n~ > 1) : n⁻¹ < (1 : ℚ) :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
|
|
|
|
unfold inv,
|
|
|
|
|
change 1 / rat_of_pnat n < 1 / 1,
|
|
|
|
|
apply one_div_lt_one_div_of_lt,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply zero_lt_one,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
rewrite pnat.to_rat_of_nat,
|
|
|
|
|
apply (of_nat_lt_of_nat_of_lt H)
|
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem pone_inv : pone⁻¹ = 1 := rfl
|
|
|
|
|
|
|
|
|
|
theorem add_invs_nonneg (m n : ℕ+) : 0 ≤ m⁻¹ + n⁻¹ :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply le_of_lt,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply add_pos,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
repeat apply pnat.inv_pos
|
2015-10-10 00:21:17 +00:00
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem one_mul (n : ℕ+) : pone * n = n :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
|
|
|
|
apply pnat.eq,
|
|
|
|
|
unfold pone,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
rewrite [pnat.mul_def, ↑nat_of_pnat, one_mul]
|
2015-10-10 00:21:17 +00:00
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem pone_le (n : ℕ+) : pone ≤ n :=
|
2015-10-23 02:18:14 +00:00
|
|
|
|
begin rewrite pnat.le_def, exact succ_le_of_lt (pnat_pos n) end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-07-24 15:56:18 +00:00
|
|
|
|
theorem pnat_to_rat_mul (a b : ℕ+) : rat_of_pnat (a * b) = rat_of_pnat a * rat_of_pnat b := rfl
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
theorem mul_lt_mul_left {a b c : ℕ+} (H : a < b) : a * c < b * c :=
|
2015-10-23 02:18:14 +00:00
|
|
|
|
begin rewrite [pnat.lt_def at *], exact mul_lt_mul_of_pos_right H !pnat_pos end
|
2015-07-24 15:56:18 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
theorem one_lt_two : pone < 2 :=
|
2015-10-22 21:35:27 +00:00
|
|
|
|
!nat.le_refl
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem inv_two_mul_lt_inv (n : ℕ+) : (2 * n)⁻¹ < n⁻¹ :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
|
|
|
|
rewrite ↑inv,
|
|
|
|
|
apply one_div_lt_one_div_of_lt,
|
|
|
|
|
apply rat_of_pnat_is_pos,
|
|
|
|
|
have H : n~ < (2 * n)~, begin
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite -pnat.one_mul at {1},
|
|
|
|
|
rewrite -pnat.lt_def,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply mul_lt_mul_left,
|
|
|
|
|
apply one_lt_two
|
|
|
|
|
end,
|
|
|
|
|
apply of_nat_lt_of_nat_of_lt,
|
|
|
|
|
apply H
|
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem inv_two_mul_le_inv (n : ℕ+) : (2 * n)⁻¹ ≤ n⁻¹ := rat.le_of_lt !inv_two_mul_lt_inv
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem inv_ge_of_le {p q : ℕ+} (H : p ≤ q) : q⁻¹ ≤ p⁻¹ :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
one_div_le_one_div_of_le !rat_of_pnat_is_pos (rat_of_pnat_le_of_pnat_le H)
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem inv_gt_of_lt {p q : ℕ+} (H : p < q) : q⁻¹ < p⁻¹ :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
one_div_lt_one_div_of_lt !rat_of_pnat_is_pos (rat_of_pnat_lt_of_pnat_lt H)
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem ge_of_inv_le {p q : ℕ+} (H : p⁻¹ ≤ q⁻¹) : q ≤ p :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
pnat_le_of_rat_of_pnat_le (le_of_one_div_le_one_div !rat_of_pnat_is_pos H)
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem two_mul (p : ℕ+) : rat_of_pnat (2 * p) = (1 + 1) * rat_of_pnat p :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
by rewrite pnat_to_rat_mul
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-12-06 07:27:46 +00:00
|
|
|
|
protected theorem add_halves (p : ℕ+) : (2 * p)⁻¹ + (2 * p)⁻¹ = p⁻¹ :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
2015-12-06 07:27:46 +00:00
|
|
|
|
rewrite [↑inv, -(add_halves (1 / (rat_of_pnat p))), div_div_eq_div_mul],
|
2015-10-23 02:18:14 +00:00
|
|
|
|
have H : rat_of_pnat (2 * p) = rat_of_pnat p * (1 + 1), by rewrite [rat.mul_comm, two_mul],
|
2015-10-10 00:21:17 +00:00
|
|
|
|
rewrite *H
|
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem add_halves_double (m n : ℕ+) :
|
|
|
|
|
m⁻¹ + n⁻¹ = ((2 * m)⁻¹ + (2 * n)⁻¹) + ((2 * m)⁻¹ + (2 * n)⁻¹) :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
have hsimp [visible] : ∀ a b : ℚ, (a + a) + (b + b) = (a + b) + (a + b),
|
2015-10-23 02:18:14 +00:00
|
|
|
|
by intros; rewrite [rat.add_assoc, -(rat.add_assoc a b b), {_+b}rat.add_comm, -*rat.add_assoc],
|
2015-12-06 07:27:46 +00:00
|
|
|
|
by rewrite [-pnat.add_halves m, -pnat.add_halves n, hsimp]
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem inv_mul_eq_mul_inv {p q : ℕ+} : (p * q)⁻¹ = p⁻¹ * q⁻¹ :=
|
2015-12-06 07:27:46 +00:00
|
|
|
|
begin rewrite [↑inv, pnat_to_rat_mul, one_div_mul_one_div] end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem inv_mul_le_inv (p q : ℕ+) : (p * q)⁻¹ ≤ q⁻¹ :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite [pnat.inv_mul_eq_mul_inv, -{q⁻¹}rat.one_mul at {2}],
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply mul_le_mul,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply inv_le_one,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply le.refl,
|
|
|
|
|
apply le_of_lt,
|
|
|
|
|
apply pnat.inv_pos,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply rat.le_of_lt rat.zero_lt_one
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem pnat_mul_le_mul_left' (a b c : ℕ+) : a ≤ b → c * a ≤ c * b :=
|
|
|
|
|
begin
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite +pnat.le_def, intro H,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply mul_le_mul_of_nonneg_left H,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply le_of_lt,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply pnat_pos
|
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem mul_assoc (a b c : ℕ+) : a * b * c = a * (b * c) :=
|
2015-10-14 19:27:09 +00:00
|
|
|
|
pnat.eq !mul.assoc
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem mul_comm (a b : ℕ+) : a * b = b * a :=
|
2015-10-14 19:27:09 +00:00
|
|
|
|
pnat.eq !mul.comm
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem add_assoc (a b c : ℕ+) : a + b + c = a + (b + c) :=
|
2015-10-14 19:27:09 +00:00
|
|
|
|
pnat.eq !add.assoc
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem mul_le_mul_left (p q : ℕ+) : q ≤ p * q :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite [-pnat.one_mul at {1}, pnat.mul_comm, pnat.mul_comm p],
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply pnat_mul_le_mul_left',
|
|
|
|
|
apply pone_le
|
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem mul_le_mul_right (p q : ℕ+) : p ≤ p * q :=
|
|
|
|
|
by rewrite pnat.mul_comm; apply pnat.mul_le_mul_left
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
theorem pnat.lt_of_not_le {p q : ℕ+} : ¬ p ≤ q → q < p :=
|
2015-10-23 02:18:14 +00:00
|
|
|
|
begin rewrite [pnat.le_def, pnat.lt_def], apply lt_of_not_ge end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem inv_cancel_left (p : ℕ+) : rat_of_pnat p * p⁻¹ = (1 : ℚ) :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
mul_one_div_cancel (ne.symm (ne_of_lt !rat_of_pnat_is_pos))
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-10-23 02:18:14 +00:00
|
|
|
|
protected theorem inv_cancel_right (p : ℕ+) : p⁻¹ * rat_of_pnat p = (1 : ℚ) :=
|
|
|
|
|
by rewrite rat.mul_comm; apply pnat.inv_cancel_left
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem lt_add_left (p q : ℕ+) : p < p + q :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
|
|
|
|
have H : p~ < p~ + q~, begin
|
|
|
|
|
rewrite -nat.add_zero at {1},
|
|
|
|
|
apply nat.add_lt_add_left,
|
|
|
|
|
apply pnat_pos
|
|
|
|
|
end,
|
|
|
|
|
apply H
|
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
|
|
|
|
theorem inv_add_lt_left (p q : ℕ+) : (p + q)⁻¹ < p⁻¹ :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
by apply inv_gt_of_lt; apply lt_add_left
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem div_le_pnat (q : ℚ) (n : ℕ+) (H : q ≥ n⁻¹) : 1 / q ≤ rat_of_pnat n :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply div_le_of_le_mul,
|
|
|
|
|
apply lt_of_lt_of_le,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.inv_pos,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
rotate 1,
|
|
|
|
|
apply H,
|
|
|
|
|
apply le_mul_of_div_le,
|
|
|
|
|
apply rat_of_pnat_is_pos,
|
|
|
|
|
apply H
|
|
|
|
|
end
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-06-16 04:55:02 +00:00
|
|
|
|
theorem pnat_cancel' (n m : ℕ+) : (n * n * m)⁻¹ * (rat_of_pnat n * rat_of_pnat n) = m⁻¹ :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
assert hsimp : ∀ a b c : ℚ, (a * a * (b * b * c)) = (a * b) * (a * b) * c,
|
|
|
|
|
begin
|
|
|
|
|
intro a b c,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite[-*rat.mul_assoc],
|
2015-10-10 00:21:17 +00:00
|
|
|
|
exact (!mul.right_comm ▸ rfl),
|
|
|
|
|
end,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
by rewrite [rat.mul_comm, *pnat.inv_mul_eq_mul_inv, hsimp, *pnat.inv_cancel_left, *rat.one_mul]
|
2015-06-11 07:00:35 +00:00
|
|
|
|
|
2015-07-24 15:56:18 +00:00
|
|
|
|
definition pceil (a : ℚ) : ℕ+ := tag (ubound a) !ubound_pos
|
2015-06-16 06:55:06 +00:00
|
|
|
|
|
|
|
|
|
theorem pceil_helper {a : ℚ} {n : ℕ+} (H : pceil a ≤ n) (Ha : a > 0) : n⁻¹ ≤ 1 / a :=
|
2015-12-06 07:27:46 +00:00
|
|
|
|
le.trans (inv_ge_of_le H) (one_div_le_one_div_of_le Ha (ubound_ge a))
|
2015-06-16 06:55:06 +00:00
|
|
|
|
|
|
|
|
|
theorem inv_pceil_div (a b : ℚ) (Ha : a > 0) (Hb : b > 0) : (pceil (a / b))⁻¹ ≤ b / a :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
assert (pceil (a / b))⁻¹ ≤ 1 / (1 / (b / a)),
|
2015-08-03 19:02:03 +00:00
|
|
|
|
begin
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply one_div_le_one_div_of_le,
|
|
|
|
|
show 0 < 1 / (b / a), from
|
|
|
|
|
one_div_pos_of_pos (div_pos_of_pos_of_pos Hb Ha),
|
|
|
|
|
show 1 / (b / a) ≤ rat_of_pnat (pceil (a / b)),
|
|
|
|
|
begin
|
|
|
|
|
rewrite div_div_eq_mul_div,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
rewrite one_mul,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply ubound_ge
|
|
|
|
|
end
|
|
|
|
|
end,
|
|
|
|
|
begin
|
2015-10-13 20:16:19 +00:00
|
|
|
|
rewrite one_div_one_div at this,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
exact this
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem sep_by_inv {a b : ℚ} : a > b → ∃ N : ℕ+, a > (b + N⁻¹ + N⁻¹) :=
|
|
|
|
|
begin
|
|
|
|
|
change b < a → ∃ N : ℕ+, (b + N⁻¹ + N⁻¹) < a,
|
|
|
|
|
intro H,
|
|
|
|
|
apply exists.elim (exists_add_lt_and_pos_of_lt H),
|
|
|
|
|
intro c Hc,
|
|
|
|
|
existsi (pceil ((1 + 1 + 1) / c)),
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply lt.trans,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
rotate 1,
|
|
|
|
|
apply and.left Hc,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
rewrite rat.add_assoc,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply rat.add_lt_add_left,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
rewrite -(add_halves c) at {3},
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply add_lt_add,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
repeat (apply lt_of_le_of_lt;
|
2015-08-03 19:02:03 +00:00
|
|
|
|
apply inv_pceil_div;
|
|
|
|
|
apply dec_trivial;
|
|
|
|
|
apply and.right Hc;
|
|
|
|
|
apply div_lt_div_of_pos_of_lt_of_pos;
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply two_pos;
|
|
|
|
|
exact dec_trivial;
|
2015-08-03 19:02:03 +00:00
|
|
|
|
apply and.right Hc)
|
2015-10-10 00:21:17 +00:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem nonneg_of_ge_neg_invs (a : ℚ) : (∀ n : ℕ+, -n⁻¹ ≤ a) → 0 ≤ a :=
|
|
|
|
|
begin
|
|
|
|
|
intro H,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
apply le_of_not_gt,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
suppose a < 0,
|
|
|
|
|
have H2 : 0 < -a, from neg_pos_of_neg this,
|
2015-12-06 07:27:46 +00:00
|
|
|
|
(not_lt_of_ge !H) (iff.mp !lt_neg_iff_lt_neg (calc
|
2015-10-10 00:21:17 +00:00
|
|
|
|
(pceil (of_num 2 / -a))⁻¹ ≤ -a / of_num 2
|
|
|
|
|
: !inv_pceil_div dec_trivial H2
|
|
|
|
|
... < -a / 1
|
|
|
|
|
: div_lt_div_of_pos_of_lt_of_pos dec_trivial dec_trivial H2
|
|
|
|
|
... = -a : !div_one))
|
|
|
|
|
end
|
2015-08-03 19:02:03 +00:00
|
|
|
|
|
2015-09-11 03:00:18 +00:00
|
|
|
|
theorem pnat_bound {ε : ℚ} (Hε : ε > 0) : ∃ p : ℕ+, p⁻¹ ≤ ε :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
begin
|
|
|
|
|
existsi (pceil (1 / ε)),
|
|
|
|
|
rewrite -(one_div_one_div ε) at {2},
|
|
|
|
|
apply pceil_helper,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
apply pnat.le_refl,
|
2015-10-10 00:21:17 +00:00
|
|
|
|
apply one_div_pos_of_pos Hε
|
|
|
|
|
end
|
2015-09-11 03:00:18 +00:00
|
|
|
|
|
|
|
|
|
theorem p_add_fractions (n : ℕ+) : (2 * n)⁻¹ + (2 * 3 * n)⁻¹ + (3 * n)⁻¹ = n⁻¹ :=
|
2015-10-10 00:21:17 +00:00
|
|
|
|
assert T : 2⁻¹ + 2⁻¹ * 3⁻¹ + 3⁻¹ = 1, from dec_trivial,
|
2015-10-23 02:18:14 +00:00
|
|
|
|
by rewrite[*pnat.inv_mul_eq_mul_inv,-*right_distrib,T,rat.one_mul]
|
2015-09-11 03:00:18 +00:00
|
|
|
|
|
2015-10-10 00:21:17 +00:00
|
|
|
|
theorem rat_power_two_le (k : ℕ+) : rat_of_pnat k ≤ 2^k~ :=
|
|
|
|
|
!binary_nat_bound
|
2015-09-11 03:00:18 +00:00
|
|
|
|
|
2015-06-11 07:00:35 +00:00
|
|
|
|
end pnat
|