refactor(library/data/int/{basic,order}): protect theorem names
This commit is contained in:
parent
dc8858d764
commit
6dfaf1863c
6 changed files with 105 additions and 106 deletions
|
@ -153,7 +153,7 @@ or.elim (nat.lt_or_ge m (nat.succ n))
|
||||||
theorem gpow_add (a : A) : ∀i j : int, gpow a (i + j) = gpow a i * gpow a j
|
theorem gpow_add (a : A) : ∀i j : int, gpow a (i + j) = gpow a i * gpow a j
|
||||||
| (of_nat m) (of_nat n) := !pow_add
|
| (of_nat m) (of_nat n) := !pow_add
|
||||||
| (of_nat m) -[1+n] := !gpow_add_aux
|
| (of_nat m) -[1+n] := !gpow_add_aux
|
||||||
| -[1+m] (of_nat n) := by rewrite [int.add.comm, gpow_add_aux, ↑gpow, -*inv_pow, pow_inv_comm]
|
| -[1+m] (of_nat n) := by rewrite [add.comm, gpow_add_aux, ↑gpow, -*inv_pow, pow_inv_comm]
|
||||||
| -[1+m] -[1+n] :=
|
| -[1+m] -[1+n] :=
|
||||||
calc
|
calc
|
||||||
gpow a (-[1+m] + -[1+n]) = (a^(#nat nat.succ m + nat.succ n))⁻¹ : rfl
|
gpow a (-[1+m] + -[1+n]) = (a^(#nat nat.succ m + nat.succ n))⁻¹ : rfl
|
||||||
|
@ -161,7 +161,7 @@ theorem gpow_add (a : A) : ∀i j : int, gpow a (i + j) = gpow a i * gpow a j
|
||||||
... = gpow a (-[1+m]) * gpow a (-[1+n]) : rfl
|
... = gpow a (-[1+m]) * gpow a (-[1+n]) : rfl
|
||||||
|
|
||||||
theorem gpow_comm (a : A) (i j : ℤ) : gpow a i * gpow a j = gpow a j * gpow a i :=
|
theorem gpow_comm (a : A) (i j : ℤ) : gpow a i * gpow a j = gpow a j * gpow a i :=
|
||||||
by rewrite [-*gpow_add, int.add.comm]
|
by rewrite [-*gpow_add, add.comm]
|
||||||
end group
|
end group
|
||||||
|
|
||||||
section ordered_ring
|
section ordered_ring
|
||||||
|
|
|
@ -341,11 +341,11 @@ calc (pr1 p + pr1 q + pr1 r, pr2 p + pr2 q + pr2 r)
|
||||||
= (pr1 p + (pr1 q + pr1 r), pr2 p + pr2 q + pr2 r) : by rewrite add.assoc
|
= (pr1 p + (pr1 q + pr1 r), pr2 p + pr2 q + pr2 r) : by rewrite add.assoc
|
||||||
... = (pr1 p + (pr1 q + pr1 r), pr2 p + (pr2 q + pr2 r)) : by rewrite add.assoc
|
... = (pr1 p + (pr1 q + pr1 r), pr2 p + (pr2 q + pr2 r)) : by rewrite add.assoc
|
||||||
|
|
||||||
theorem add.comm (a b : ℤ) : a + b = b + a :=
|
protected theorem add_comm (a b : ℤ) : a + b = b + a :=
|
||||||
eq_of_repr_equiv_repr (equiv.trans !repr_add
|
eq_of_repr_equiv_repr (equiv.trans !repr_add
|
||||||
(equiv.symm (!padd_comm ▸ !repr_add)))
|
(equiv.symm (!padd_comm ▸ !repr_add)))
|
||||||
|
|
||||||
theorem add.assoc (a b c : ℤ) : a + b + c = a + (b + c) :=
|
protected theorem add_assoc (a b c : ℤ) : a + b + c = a + (b + c) :=
|
||||||
eq_of_repr_equiv_repr (calc
|
eq_of_repr_equiv_repr (calc
|
||||||
repr (a + b + c)
|
repr (a + b + c)
|
||||||
≡ padd (repr (a + b)) (repr c) : repr_add
|
≡ padd (repr (a + b)) (repr c) : repr_add
|
||||||
|
@ -354,9 +354,9 @@ eq_of_repr_equiv_repr (calc
|
||||||
... ≡ padd (repr a) (repr (b + c)) : padd_congr !equiv.refl !repr_add
|
... ≡ padd (repr a) (repr (b + c)) : padd_congr !equiv.refl !repr_add
|
||||||
... ≡ repr (a + (b + c)) : repr_add)
|
... ≡ repr (a + (b + c)) : repr_add)
|
||||||
|
|
||||||
theorem add_zero : Π (a : ℤ), a + 0 = a := int.rec (λm, rfl) (λm, rfl)
|
protected theorem add_zero : Π (a : ℤ), a + 0 = a := int.rec (λm, rfl) (λm, rfl)
|
||||||
|
|
||||||
theorem zero_add (a : ℤ) : 0 + a = a := !add.comm ▸ !add_zero
|
protected theorem zero_add (a : ℤ) : 0 + a = a := !int.add_comm ▸ !int.add_zero
|
||||||
|
|
||||||
/- negation -/
|
/- negation -/
|
||||||
|
|
||||||
|
@ -393,7 +393,7 @@ calc pr1 p + pr1 q + pr2 q + pr2 p
|
||||||
... = pr1 p + (pr2 p + pr2 q + pr1 q) : algebra.add.comm
|
... = pr1 p + (pr2 p + pr2 q + pr1 q) : algebra.add.comm
|
||||||
... = pr2 p + pr2 q + pr1 q + pr1 p : algebra.add.comm
|
... = pr2 p + pr2 q + pr1 q + pr1 p : algebra.add.comm
|
||||||
|
|
||||||
theorem add.left_inv (a : ℤ) : -a + a = 0 :=
|
protected theorem add_left_inv (a : ℤ) : -a + a = 0 :=
|
||||||
have H : repr (-a + a) ≡ repr 0, from
|
have H : repr (-a + a) ≡ repr 0, from
|
||||||
calc
|
calc
|
||||||
repr (-a + a) ≡ padd (repr (neg a)) (repr a) : repr_add
|
repr (-a + a) ≡ padd (repr (neg a)) (repr a) : repr_add
|
||||||
|
@ -485,7 +485,7 @@ begin
|
||||||
{ rewrite algebra.add.comm, congruence, repeat rewrite mul.comm }
|
{ rewrite algebra.add.comm, congruence, repeat rewrite mul.comm }
|
||||||
end
|
end
|
||||||
|
|
||||||
theorem mul.comm (a b : ℤ) : a * b = b * a :=
|
protected theorem mul_comm (a b : ℤ) : a * b = b * a :=
|
||||||
eq_of_repr_equiv_repr
|
eq_of_repr_equiv_repr
|
||||||
((calc
|
((calc
|
||||||
repr (a * b) = pmul (repr a) (repr b) : repr_mul
|
repr (a * b) = pmul (repr a) (repr b) : repr_mul
|
||||||
|
@ -503,7 +503,7 @@ end
|
||||||
|
|
||||||
theorem pmul_assoc (p q r: ℕ × ℕ) : pmul (pmul p q) r = pmul p (pmul q r) := pmul_assoc_prep
|
theorem pmul_assoc (p q r: ℕ × ℕ) : pmul (pmul p q) r = pmul p (pmul q r) := pmul_assoc_prep
|
||||||
|
|
||||||
theorem mul.assoc (a b c : ℤ) : (a * b) * c = a * (b * c) :=
|
protected theorem mul_assoc (a b c : ℤ) : (a * b) * c = a * (b * c) :=
|
||||||
eq_of_repr_equiv_repr
|
eq_of_repr_equiv_repr
|
||||||
((calc
|
((calc
|
||||||
repr (a * b * c) = pmul (repr (a * b)) (repr c) : repr_mul
|
repr (a * b * c) = pmul (repr (a * b)) (repr c) : repr_mul
|
||||||
|
@ -512,13 +512,12 @@ eq_of_repr_equiv_repr
|
||||||
... = pmul (repr a) (repr (b * c)) : repr_mul
|
... = pmul (repr a) (repr (b * c)) : repr_mul
|
||||||
... = repr (a * (b * c)) : repr_mul) ▸ !equiv.refl)
|
... = repr (a * (b * c)) : repr_mul) ▸ !equiv.refl)
|
||||||
|
|
||||||
theorem mul_one : Π (a : ℤ), a * 1 = a
|
protected theorem mul_one : Π (a : ℤ), a * 1 = a
|
||||||
| (of_nat m) := !zero_add -- zero_add happens to be def. = to this thm
|
| (of_nat m) := !int.zero_add -- zero_add happens to be def. = to this thm
|
||||||
| -[1+ m] := !nat.zero_add ▸ rfl
|
| -[1+ m] := !nat.zero_add ▸ rfl
|
||||||
|
|
||||||
|
protected theorem one_mul (a : ℤ) : 1 * a = a :=
|
||||||
theorem one_mul (a : ℤ) : 1 * a = a :=
|
int.mul_comm a 1 ▸ int.mul_one a
|
||||||
mul.comm a 1 ▸ mul_one a
|
|
||||||
|
|
||||||
private theorem mul_distrib_prep {a1 a2 b1 b2 c1 c2 : ℕ} :
|
private theorem mul_distrib_prep {a1 a2 b1 b2 c1 c2 : ℕ} :
|
||||||
((a1+b1)*c1+(a2+b2)*c2, (a1+b1)*c2+(a2+b2)*c1) =
|
((a1+b1)*c1+(a2+b2)*c2, (a1+b1)*c2+(a2+b2)*c1) =
|
||||||
|
@ -529,7 +528,7 @@ begin
|
||||||
{rewrite add.comm4}
|
{rewrite add.comm4}
|
||||||
end
|
end
|
||||||
|
|
||||||
theorem mul.right_distrib (a b c : ℤ) : (a + b) * c = a * c + b * c :=
|
protected theorem mul_right_distrib (a b c : ℤ) : (a + b) * c = a * c + b * c :=
|
||||||
eq_of_repr_equiv_repr
|
eq_of_repr_equiv_repr
|
||||||
(calc
|
(calc
|
||||||
repr ((a + b) * c) = pmul (repr (a + b)) (repr c) : repr_mul
|
repr ((a + b) * c) = pmul (repr (a + b)) (repr c) : repr_mul
|
||||||
|
@ -539,40 +538,40 @@ eq_of_repr_equiv_repr
|
||||||
... = padd (repr (a * c)) (repr (b * c)) : repr_mul
|
... = padd (repr (a * c)) (repr (b * c)) : repr_mul
|
||||||
... ≡ repr (a * c + b * c) : repr_add)
|
... ≡ repr (a * c + b * c) : repr_add)
|
||||||
|
|
||||||
theorem mul.left_distrib (a b c : ℤ) : a * (b + c) = a * b + a * c :=
|
protected theorem mul_left_distrib (a b c : ℤ) : a * (b + c) = a * b + a * c :=
|
||||||
calc
|
calc
|
||||||
a * (b + c) = (b + c) * a : mul.comm
|
a * (b + c) = (b + c) * a : int.mul_comm
|
||||||
... = b * a + c * a : mul.right_distrib
|
... = b * a + c * a : int.mul_right_distrib
|
||||||
... = a * b + c * a : mul.comm
|
... = a * b + c * a : int.mul_comm
|
||||||
... = a * b + a * c : mul.comm
|
... = a * b + a * c : int.mul_comm
|
||||||
|
|
||||||
theorem zero_ne_one : (0 : int) ≠ 1 :=
|
protected theorem zero_ne_one : (0 : int) ≠ 1 :=
|
||||||
assume H : 0 = 1, !succ_ne_zero (of_nat.inj H)⁻¹
|
assume H : 0 = 1, !succ_ne_zero (of_nat.inj H)⁻¹
|
||||||
|
|
||||||
theorem eq_zero_or_eq_zero_of_mul_eq_zero {a b : ℤ} (H : a * b = 0) : a = 0 ∨ b = 0 :=
|
protected theorem eq_zero_or_eq_zero_of_mul_eq_zero {a b : ℤ} (H : a * b = 0) : a = 0 ∨ b = 0 :=
|
||||||
or.imp eq_zero_of_nat_abs_eq_zero eq_zero_of_nat_abs_eq_zero
|
or.imp eq_zero_of_nat_abs_eq_zero eq_zero_of_nat_abs_eq_zero
|
||||||
(eq_zero_or_eq_zero_of_mul_eq_zero (by rewrite [-nat_abs_mul, H]))
|
(eq_zero_or_eq_zero_of_mul_eq_zero (by rewrite [-nat_abs_mul, H]))
|
||||||
|
|
||||||
protected definition integral_domain [reducible] [trans_instance] : algebra.integral_domain int :=
|
protected definition integral_domain [reducible] [trans_instance] : algebra.integral_domain int :=
|
||||||
⦃algebra.integral_domain,
|
⦃algebra.integral_domain,
|
||||||
add := int.add,
|
add := int.add,
|
||||||
add_assoc := add.assoc,
|
add_assoc := int.add_assoc,
|
||||||
zero := 0,
|
zero := 0,
|
||||||
zero_add := zero_add,
|
zero_add := int.zero_add,
|
||||||
add_zero := add_zero,
|
add_zero := int.add_zero,
|
||||||
neg := int.neg,
|
neg := int.neg,
|
||||||
add_left_inv := add.left_inv,
|
add_left_inv := int.add_left_inv,
|
||||||
add_comm := add.comm,
|
add_comm := int.add_comm,
|
||||||
mul := int.mul,
|
mul := int.mul,
|
||||||
mul_assoc := mul.assoc,
|
mul_assoc := int.mul_assoc,
|
||||||
one := 1,
|
one := 1,
|
||||||
one_mul := one_mul,
|
one_mul := int.one_mul,
|
||||||
mul_one := mul_one,
|
mul_one := int.mul_one,
|
||||||
left_distrib := mul.left_distrib,
|
left_distrib := int.mul_left_distrib,
|
||||||
right_distrib := mul.right_distrib,
|
right_distrib := int.mul_right_distrib,
|
||||||
mul_comm := mul.comm,
|
mul_comm := int.mul_comm,
|
||||||
zero_ne_one := zero_ne_one,
|
zero_ne_one := int.zero_ne_one,
|
||||||
eq_zero_or_eq_zero_of_mul_eq_zero := @eq_zero_or_eq_zero_of_mul_eq_zero⦄
|
eq_zero_or_eq_zero_of_mul_eq_zero := @int.eq_zero_or_eq_zero_of_mul_eq_zero⦄
|
||||||
|
|
||||||
definition int_has_sub [reducible] [instance] [priority int.prio] : has_sub int :=
|
definition int_has_sub [reducible] [instance] [priority int.prio] : has_sub int :=
|
||||||
has_sub.mk has_sub.sub
|
has_sub.mk has_sub.sub
|
||||||
|
|
|
@ -167,7 +167,7 @@ or.elim (nat.lt_or_ge m (n * k))
|
||||||
... = of_nat (n - m div k - 1) :
|
... = of_nat (n - m div k - 1) :
|
||||||
nat.mul_sub_div_of_lt (!nat.mul_comm ▸ m_lt_nk)
|
nat.mul_sub_div_of_lt (!nat.mul_comm ▸ m_lt_nk)
|
||||||
... = -[1+m] div k + n :
|
... = -[1+m] div k + n :
|
||||||
by rewrite [nat.sub_sub, of_nat_sub H4, add.comm, sub_eq_add_neg,
|
by rewrite [nat.sub_sub, of_nat_sub H4, int.add_comm, sub_eq_add_neg,
|
||||||
!neg_succ_of_nat_div (of_nat_lt_of_nat_of_lt H2),
|
!neg_succ_of_nat_div (of_nat_lt_of_nat_of_lt H2),
|
||||||
of_nat_add, of_nat_div],
|
of_nat_add, of_nat_div],
|
||||||
Hm⁻¹ ▸ this)
|
Hm⁻¹ ▸ this)
|
||||||
|
@ -259,7 +259,7 @@ calc
|
||||||
-[1+m] mod b = -(m + 1) - -[1+m] div b * b : rfl
|
-[1+m] mod b = -(m + 1) - -[1+m] div b * b : rfl
|
||||||
... = -(m + 1) - -(m div b + 1) * b : neg_succ_of_nat_div _ bpos
|
... = -(m + 1) - -(m div b + 1) * b : neg_succ_of_nat_div _ bpos
|
||||||
... = -m + -1 + (b + m div b * b) :
|
... = -m + -1 + (b + m div b * b) :
|
||||||
by rewrite [neg_add, -neg_mul_eq_neg_mul, sub_neg_eq_add, mul.right_distrib,
|
by rewrite [neg_add, -neg_mul_eq_neg_mul, sub_neg_eq_add, right_distrib,
|
||||||
one_mul, (add.comm b)]
|
one_mul, (add.comm b)]
|
||||||
... = b + -1 + (-m + m div b * b) :
|
... = b + -1 + (-m + m div b * b) :
|
||||||
by rewrite [-*add.assoc, add.comm (-m), add.right_comm (-1), (add.comm b)]
|
by rewrite [-*add.assoc, add.comm (-m), add.right_comm (-1), (add.comm b)]
|
||||||
|
@ -341,7 +341,7 @@ have H2 : a mod (abs b) < abs b, from
|
||||||
theorem add_mul_mod_self {a b c : ℤ} : (a + b * c) mod c = a mod c :=
|
theorem add_mul_mod_self {a b c : ℤ} : (a + b * c) mod c = a mod c :=
|
||||||
decidable.by_cases
|
decidable.by_cases
|
||||||
(assume cz : c = 0, by rewrite [cz, mul_zero, add_zero])
|
(assume cz : c = 0, by rewrite [cz, mul_zero, add_zero])
|
||||||
(assume cnz, by rewrite [(modulo.def), !add_mul_div_self cnz, mul.right_distrib,
|
(assume cnz, by rewrite [(modulo.def), !add_mul_div_self cnz, right_distrib,
|
||||||
sub_add_eq_sub_sub_swap, add_sub_cancel])
|
sub_add_eq_sub_sub_swap, add_sub_cancel])
|
||||||
|
|
||||||
theorem add_mul_mod_self_left (a b c : ℤ) : (a + b * c) mod b = a mod b :=
|
theorem add_mul_mod_self_left (a b c : ℤ) : (a + b * c) mod b = a mod b :=
|
||||||
|
@ -405,7 +405,7 @@ calc
|
||||||
a * b div (a * c) = a * (b div c * c + b mod c) div (a * c) : eq_div_mul_add_mod
|
a * b div (a * c) = a * (b div c * c + b mod c) div (a * c) : eq_div_mul_add_mod
|
||||||
|
|
||||||
... = (a * (b mod c) + a * c * (b div c)) div (a * c) :
|
... = (a * (b mod c) + a * c * (b div c)) div (a * c) :
|
||||||
by rewrite [!add.comm, mul.left_distrib, mul.comm _ c, -!mul.assoc]
|
by rewrite [!add.comm, int.mul_left_distrib, mul.comm _ c, -!mul.assoc]
|
||||||
... = a * (b mod c) div (a * c) + b div c : !add_mul_div_self_left H3
|
... = a * (b mod c) div (a * c) + b div c : !add_mul_div_self_left H3
|
||||||
... = 0 + b div c : {!div_eq_zero_of_lt H5 H4}
|
... = 0 + b div c : {!div_eq_zero_of_lt H5 H4}
|
||||||
... = b div c : zero_add
|
... = b div c : zero_add
|
||||||
|
@ -438,7 +438,7 @@ theorem lt_div_add_one_mul_self (a : ℤ) {b : ℤ} (H : b > 0) : a < (a div b +
|
||||||
have H : a - a div b * b < b, from !mod_lt_of_pos H,
|
have H : a - a div b * b < b, from !mod_lt_of_pos H,
|
||||||
calc
|
calc
|
||||||
a < a div b * b + b : iff.mpr !lt_add_iff_sub_lt_left H
|
a < a div b * b + b : iff.mpr !lt_add_iff_sub_lt_left H
|
||||||
... = (a div b + 1) * b : by rewrite [mul.right_distrib, one_mul]
|
... = (a div b + 1) * b : by rewrite [right_distrib, one_mul]
|
||||||
|
|
||||||
theorem div_le_of_nonneg_of_nonneg {a b : ℤ} (Ha : a ≥ 0) (Hb : b ≥ 0) : a div b ≤ a :=
|
theorem div_le_of_nonneg_of_nonneg {a b : ℤ} (Ha : a ≥ 0) (Hb : b ≥ 0) : a div b ≤ a :=
|
||||||
obtain (m : ℕ) (Hm : a = m), from exists_eq_of_nat Ha,
|
obtain (m : ℕ) (Hm : a = m), from exists_eq_of_nat Ha,
|
||||||
|
@ -647,7 +647,7 @@ have H3 : a * c < (b div c + 1) * c, from
|
||||||
a * c ≤ b : H2
|
a * c ≤ b : H2
|
||||||
... = b div c * c + b mod c : eq_div_mul_add_mod
|
... = b div c * c + b mod c : eq_div_mul_add_mod
|
||||||
... < b div c * c + c : add_lt_add_left (!mod_lt_of_pos H1)
|
... < b div c * c + c : add_lt_add_left (!mod_lt_of_pos H1)
|
||||||
... = (b div c + 1) * c : by rewrite [mul.right_distrib, one_mul],
|
... = (b div c + 1) * c : by rewrite [right_distrib, one_mul],
|
||||||
le_of_lt_add_one (lt_of_mul_lt_mul_right H3 (le_of_lt H1))
|
le_of_lt_add_one (lt_of_mul_lt_mul_right H3 (le_of_lt H1))
|
||||||
|
|
||||||
theorem le_div_iff_mul_le {a b c : ℤ} (H : c > 0) : a ≤ b div c ↔ a * c ≤ b :=
|
theorem le_div_iff_mul_le {a b c : ℤ} (H : c > 0) : a ≤ b div c ↔ a * c ≤ b :=
|
||||||
|
@ -668,7 +668,7 @@ lt_of_mul_lt_mul_right
|
||||||
theorem lt_mul_of_div_lt {a b c : ℤ} (H1 : c > 0) (H2 : a div c < b) : a < b * c :=
|
theorem lt_mul_of_div_lt {a b c : ℤ} (H1 : c > 0) (H2 : a div c < b) : a < b * c :=
|
||||||
assert H3 : (a div c + 1) * c ≤ b * c,
|
assert H3 : (a div c + 1) * c ≤ b * c,
|
||||||
from !mul_le_mul_of_nonneg_right (add_one_le_of_lt H2) (le_of_lt H1),
|
from !mul_le_mul_of_nonneg_right (add_one_le_of_lt H2) (le_of_lt H1),
|
||||||
have H4 : a div c * c + c ≤ b * c, by rewrite [mul.right_distrib at H3, one_mul at H3]; apply H3,
|
have H4 : a div c * c + c ≤ b * c, by rewrite [right_distrib at H3, one_mul at H3]; apply H3,
|
||||||
calc
|
calc
|
||||||
a = a div c * c + a mod c : eq_div_mul_add_mod
|
a = a div c * c + a mod c : eq_div_mul_add_mod
|
||||||
... < a div c * c + c : add_lt_add_left (!mod_lt_of_pos H1)
|
... < a div c * c + c : add_lt_add_left (!mod_lt_of_pos H1)
|
||||||
|
|
|
@ -44,7 +44,7 @@ theorem le.elim {a b : ℤ} (H : a ≤ b) : ∃n : ℕ, a + n = b :=
|
||||||
obtain (n : ℕ) (H1 : b - a = n), from nonneg.elim H,
|
obtain (n : ℕ) (H1 : b - a = n), from nonneg.elim H,
|
||||||
exists.intro n (!add.comm ▸ iff.mpr !add_eq_iff_eq_add_neg (H1⁻¹))
|
exists.intro n (!add.comm ▸ iff.mpr !add_eq_iff_eq_add_neg (H1⁻¹))
|
||||||
|
|
||||||
theorem le.total (a b : ℤ) : a ≤ b ∨ b ≤ a :=
|
protected theorem le_total (a b : ℤ) : a ≤ b ∨ b ≤ a :=
|
||||||
or.imp_right
|
or.imp_right
|
||||||
(assume H : nonneg (-(b - a)),
|
(assume H : nonneg (-(b - a)),
|
||||||
have -(b - a) = a - b, from !neg_sub,
|
have -(b - a) = a - b, from !neg_sub,
|
||||||
|
@ -67,7 +67,7 @@ theorem lt_add_succ (a : ℤ) (n : ℕ) : a < a + succ n :=
|
||||||
le.intro (show a + 1 + n = a + succ n, from
|
le.intro (show a + 1 + n = a + succ n, from
|
||||||
calc
|
calc
|
||||||
a + 1 + n = a + (1 + n) : add.assoc
|
a + 1 + n = a + (1 + n) : add.assoc
|
||||||
... = a + (n + 1) : by rewrite (add.comm 1 n)
|
... = a + (n + 1) : by rewrite (int.add_comm 1 n)
|
||||||
... = a + succ n : rfl)
|
... = a + succ n : rfl)
|
||||||
|
|
||||||
theorem lt.intro {a b : ℤ} {n : ℕ} (H : a + succ n = b) : a < b :=
|
theorem lt.intro {a b : ℤ} {n : ℕ} (H : a + succ n = b) : a < b :=
|
||||||
|
@ -77,7 +77,7 @@ theorem lt.elim {a b : ℤ} (H : a < b) : ∃n : ℕ, a + succ n = b :=
|
||||||
obtain (n : ℕ) (Hn : a + 1 + n = b), from le.elim H,
|
obtain (n : ℕ) (Hn : a + 1 + n = b), from le.elim H,
|
||||||
have a + succ n = b, from
|
have a + succ n = b, from
|
||||||
calc
|
calc
|
||||||
a + succ n = a + 1 + n : by rewrite [add.assoc, add.comm 1 n]
|
a + succ n = a + 1 + n : by rewrite [add.assoc, int.add_comm 1 n]
|
||||||
... = b : Hn,
|
... = b : Hn,
|
||||||
exists.intro n this
|
exists.intro n this
|
||||||
|
|
||||||
|
@ -96,10 +96,10 @@ iff.mpr !of_nat_lt_of_nat_iff H
|
||||||
|
|
||||||
/- show that the integers form an ordered additive group -/
|
/- show that the integers form an ordered additive group -/
|
||||||
|
|
||||||
theorem le.refl (a : ℤ) : a ≤ a :=
|
protected theorem le_refl (a : ℤ) : a ≤ a :=
|
||||||
le.intro (add_zero a)
|
le.intro (add_zero a)
|
||||||
|
|
||||||
theorem le.trans {a b c : ℤ} (H1 : a ≤ b) (H2 : b ≤ c) : a ≤ c :=
|
protected theorem le_trans {a b c : ℤ} (H1 : a ≤ b) (H2 : b ≤ c) : a ≤ c :=
|
||||||
obtain (n : ℕ) (Hn : a + n = b), from le.elim H1,
|
obtain (n : ℕ) (Hn : a + n = b), from le.elim H1,
|
||||||
obtain (m : ℕ) (Hm : b + m = c), from le.elim H2,
|
obtain (m : ℕ) (Hm : b + m = c), from le.elim H2,
|
||||||
have a + of_nat (n + m) = c, from
|
have a + of_nat (n + m) = c, from
|
||||||
|
@ -110,7 +110,7 @@ have a + of_nat (n + m) = c, from
|
||||||
... = c : Hm,
|
... = c : Hm,
|
||||||
le.intro this
|
le.intro this
|
||||||
|
|
||||||
theorem le.antisymm : ∀ {a b : ℤ}, a ≤ b → b ≤ a → a = b :=
|
protected theorem le_antisymm : ∀ {a b : ℤ}, a ≤ b → b ≤ a → a = b :=
|
||||||
take a b : ℤ, assume (H₁ : a ≤ b) (H₂ : b ≤ a),
|
take a b : ℤ, assume (H₁ : a ≤ b) (H₂ : b ≤ a),
|
||||||
obtain (n : ℕ) (Hn : a + n = b), from le.elim H₁,
|
obtain (n : ℕ) (Hn : a + n = b), from le.elim H₁,
|
||||||
obtain (m : ℕ) (Hm : b + m = a), from le.elim H₂,
|
obtain (m : ℕ) (Hm : b + m = a), from le.elim H₂,
|
||||||
|
@ -130,23 +130,23 @@ show a = b, from
|
||||||
... = a + n : by rewrite this
|
... = a + n : by rewrite this
|
||||||
... = b : Hn
|
... = b : Hn
|
||||||
|
|
||||||
theorem lt.irrefl (a : ℤ) : ¬ a < a :=
|
protected theorem lt_irrefl (a : ℤ) : ¬ a < a :=
|
||||||
(suppose a < a,
|
(suppose a < a,
|
||||||
obtain (n : ℕ) (Hn : a + succ n = a), from lt.elim this,
|
obtain (n : ℕ) (Hn : a + succ n = a), from lt.elim this,
|
||||||
have a + succ n = a + 0, from
|
have a + succ n = a + 0, from
|
||||||
Hn ⬝ !add_zero⁻¹,
|
Hn ⬝ !add_zero⁻¹,
|
||||||
!succ_ne_zero (of_nat.inj (add.left_cancel this)))
|
!succ_ne_zero (of_nat.inj (add.left_cancel this)))
|
||||||
|
|
||||||
theorem ne_of_lt {a b : ℤ} (H : a < b) : a ≠ b :=
|
protected theorem ne_of_lt {a b : ℤ} (H : a < b) : a ≠ b :=
|
||||||
(suppose a = b, absurd (this ▸ H) (lt.irrefl b))
|
(suppose a = b, absurd (this ▸ H) (int.lt_irrefl b))
|
||||||
|
|
||||||
theorem le_of_lt {a b : ℤ} (H : a < b) : a ≤ b :=
|
theorem le_of_lt {a b : ℤ} (H : a < b) : a ≤ b :=
|
||||||
obtain (n : ℕ) (Hn : a + succ n = b), from lt.elim H,
|
obtain (n : ℕ) (Hn : a + succ n = b), from lt.elim H,
|
||||||
le.intro Hn
|
le.intro Hn
|
||||||
|
|
||||||
theorem lt_iff_le_and_ne (a b : ℤ) : a < b ↔ (a ≤ b ∧ a ≠ b) :=
|
protected theorem lt_iff_le_and_ne (a b : ℤ) : a < b ↔ (a ≤ b ∧ a ≠ b) :=
|
||||||
iff.intro
|
iff.intro
|
||||||
(assume H, and.intro (le_of_lt H) (ne_of_lt H))
|
(assume H, and.intro (le_of_lt H) (int.ne_of_lt H))
|
||||||
(assume H,
|
(assume H,
|
||||||
have a ≤ b, from and.elim_left H,
|
have a ≤ b, from and.elim_left H,
|
||||||
have a ≠ b, from and.elim_right H,
|
have a ≠ b, from and.elim_right H,
|
||||||
|
@ -155,7 +155,7 @@ iff.intro
|
||||||
obtain (k : ℕ) (Hk : n = nat.succ k), from nat.exists_eq_succ_of_ne_zero this,
|
obtain (k : ℕ) (Hk : n = nat.succ k), from nat.exists_eq_succ_of_ne_zero this,
|
||||||
lt.intro (Hk ▸ Hn))
|
lt.intro (Hk ▸ Hn))
|
||||||
|
|
||||||
theorem le_iff_lt_or_eq (a b : ℤ) : a ≤ b ↔ (a < b ∨ a = b) :=
|
protected theorem le_iff_lt_or_eq (a b : ℤ) : a ≤ b ↔ (a < b ∨ a = b) :=
|
||||||
iff.intro
|
iff.intro
|
||||||
(assume H,
|
(assume H,
|
||||||
by_cases
|
by_cases
|
||||||
|
@ -168,12 +168,12 @@ iff.intro
|
||||||
(assume H,
|
(assume H,
|
||||||
or.elim H
|
or.elim H
|
||||||
(assume H1, le_of_lt H1)
|
(assume H1, le_of_lt H1)
|
||||||
(assume H1, H1 ▸ !le.refl))
|
(assume H1, H1 ▸ !int.le_refl))
|
||||||
|
|
||||||
theorem lt_succ (a : ℤ) : a < a + 1 :=
|
theorem lt_succ (a : ℤ) : a < a + 1 :=
|
||||||
le.refl (a + 1)
|
int.le_refl (a + 1)
|
||||||
|
|
||||||
theorem add_le_add_left {a b : ℤ} (H : a ≤ b) (c : ℤ) : c + a ≤ c + b :=
|
protected theorem add_le_add_left {a b : ℤ} (H : a ≤ b) (c : ℤ) : c + a ≤ c + b :=
|
||||||
obtain (n : ℕ) (Hn : a + n = b), from le.elim H,
|
obtain (n : ℕ) (Hn : a + n = b), from le.elim H,
|
||||||
have H2 : c + a + n = c + b, from
|
have H2 : c + a + n = c + b, from
|
||||||
calc
|
calc
|
||||||
|
@ -181,13 +181,13 @@ have H2 : c + a + n = c + b, from
|
||||||
... = c + b : {Hn},
|
... = c + b : {Hn},
|
||||||
le.intro H2
|
le.intro H2
|
||||||
|
|
||||||
theorem add_lt_add_left {a b : ℤ} (H : a < b) (c : ℤ) : c + a < c + b :=
|
protected theorem add_lt_add_left {a b : ℤ} (H : a < b) (c : ℤ) : c + a < c + b :=
|
||||||
let H' := le_of_lt H in
|
let H' := le_of_lt H in
|
||||||
(iff.mpr (lt_iff_le_and_ne _ _)) (and.intro (add_le_add_left H' _)
|
(iff.mpr (int.lt_iff_le_and_ne _ _)) (and.intro (int.add_le_add_left H' _)
|
||||||
(take Heq, let Heq' := add_left_cancel Heq in
|
(take Heq, let Heq' := add_left_cancel Heq in
|
||||||
!lt.irrefl (Heq' ▸ H)))
|
!int.lt_irrefl (Heq' ▸ H)))
|
||||||
|
|
||||||
theorem mul_nonneg {a b : ℤ} (Ha : 0 ≤ a) (Hb : 0 ≤ b) : 0 ≤ a * b :=
|
protected theorem mul_nonneg {a b : ℤ} (Ha : 0 ≤ a) (Hb : 0 ≤ b) : 0 ≤ a * b :=
|
||||||
obtain (n : ℕ) (Hn : 0 + n = a), from le.elim Ha,
|
obtain (n : ℕ) (Hn : 0 + n = a), from le.elim Ha,
|
||||||
obtain (m : ℕ) (Hm : 0 + m = b), from le.elim Hb,
|
obtain (m : ℕ) (Hm : 0 + m = b), from le.elim Hb,
|
||||||
le.intro
|
le.intro
|
||||||
|
@ -199,7 +199,7 @@ le.intro
|
||||||
... = n * m : by rewrite zero_add
|
... = n * m : by rewrite zero_add
|
||||||
... = 0 + n * m : by rewrite zero_add))
|
... = 0 + n * m : by rewrite zero_add))
|
||||||
|
|
||||||
theorem mul_pos {a b : ℤ} (Ha : 0 < a) (Hb : 0 < b) : 0 < a * b :=
|
protected theorem mul_pos {a b : ℤ} (Ha : 0 < a) (Hb : 0 < b) : 0 < a * b :=
|
||||||
obtain (n : ℕ) (Hn : 0 + nat.succ n = a), from lt.elim Ha,
|
obtain (n : ℕ) (Hn : 0 + nat.succ n = a), from lt.elim Ha,
|
||||||
obtain (m : ℕ) (Hm : 0 + nat.succ m = b), from lt.elim Hb,
|
obtain (m : ℕ) (Hm : 0 + nat.succ m = b), from lt.elim Hb,
|
||||||
lt.intro
|
lt.intro
|
||||||
|
@ -214,45 +214,45 @@ lt.intro
|
||||||
... = of_nat (nat.succ (nat.succ n * m + n)) : by rewrite nat.add_succ
|
... = of_nat (nat.succ (nat.succ n * m + n)) : by rewrite nat.add_succ
|
||||||
... = 0 + nat.succ (nat.succ n * m + n) : by rewrite zero_add))
|
... = 0 + nat.succ (nat.succ n * m + n) : by rewrite zero_add))
|
||||||
|
|
||||||
theorem zero_lt_one : (0 : ℤ) < 1 := trivial
|
protected theorem zero_lt_one : (0 : ℤ) < 1 := trivial
|
||||||
|
|
||||||
theorem not_le_of_gt {a b : ℤ} (H : a < b) : ¬ b ≤ a :=
|
protected theorem not_le_of_gt {a b : ℤ} (H : a < b) : ¬ b ≤ a :=
|
||||||
assume Hba,
|
assume Hba,
|
||||||
let Heq := le.antisymm (le_of_lt H) Hba in
|
let Heq := int.le_antisymm (le_of_lt H) Hba in
|
||||||
!lt.irrefl (Heq ▸ H)
|
!int.lt_irrefl (Heq ▸ H)
|
||||||
|
|
||||||
theorem lt_of_lt_of_le {a b c : ℤ} (Hab : a < b) (Hbc : b ≤ c) : a < c :=
|
protected theorem lt_of_lt_of_le {a b c : ℤ} (Hab : a < b) (Hbc : b ≤ c) : a < c :=
|
||||||
let Hab' := le_of_lt Hab in
|
let Hab' := le_of_lt Hab in
|
||||||
let Hac := le.trans Hab' Hbc in
|
let Hac := int.le_trans Hab' Hbc in
|
||||||
(iff.mpr !lt_iff_le_and_ne) (and.intro Hac
|
(iff.mpr !int.lt_iff_le_and_ne) (and.intro Hac
|
||||||
(assume Heq, not_le_of_gt (Heq ▸ Hab) Hbc))
|
(assume Heq, int.not_le_of_gt (Heq ▸ Hab) Hbc))
|
||||||
|
|
||||||
theorem lt_of_le_of_lt {a b c : ℤ} (Hab : a ≤ b) (Hbc : b < c) : a < c :=
|
protected theorem lt_of_le_of_lt {a b c : ℤ} (Hab : a ≤ b) (Hbc : b < c) : a < c :=
|
||||||
let Hbc' := le_of_lt Hbc in
|
let Hbc' := le_of_lt Hbc in
|
||||||
let Hac := le.trans Hab Hbc' in
|
let Hac := int.le_trans Hab Hbc' in
|
||||||
(iff.mpr !lt_iff_le_and_ne) (and.intro Hac
|
(iff.mpr !int.lt_iff_le_and_ne) (and.intro Hac
|
||||||
(assume Heq, not_le_of_gt (Heq⁻¹ ▸ Hbc) Hab))
|
(assume Heq, int.not_le_of_gt (Heq⁻¹ ▸ Hbc) Hab))
|
||||||
|
|
||||||
protected definition linear_ordered_comm_ring [reducible] [trans_instance] :
|
protected definition linear_ordered_comm_ring [reducible] [trans_instance] :
|
||||||
algebra.linear_ordered_comm_ring int :=
|
algebra.linear_ordered_comm_ring int :=
|
||||||
⦃algebra.linear_ordered_comm_ring, int.integral_domain,
|
⦃algebra.linear_ordered_comm_ring, int.integral_domain,
|
||||||
le := int.le,
|
le := int.le,
|
||||||
le_refl := le.refl,
|
le_refl := int.le_refl,
|
||||||
le_trans := @le.trans,
|
le_trans := @int.le_trans,
|
||||||
le_antisymm := @le.antisymm,
|
le_antisymm := @int.le_antisymm,
|
||||||
lt := int.lt,
|
lt := int.lt,
|
||||||
le_of_lt := @le_of_lt,
|
le_of_lt := @int.le_of_lt,
|
||||||
lt_irrefl := lt.irrefl,
|
lt_irrefl := int.lt_irrefl,
|
||||||
lt_of_lt_of_le := @lt_of_lt_of_le,
|
lt_of_lt_of_le := @int.lt_of_lt_of_le,
|
||||||
lt_of_le_of_lt := @lt_of_le_of_lt,
|
lt_of_le_of_lt := @int.lt_of_le_of_lt,
|
||||||
add_le_add_left := @add_le_add_left,
|
add_le_add_left := @int.add_le_add_left,
|
||||||
mul_nonneg := @mul_nonneg,
|
mul_nonneg := @int.mul_nonneg,
|
||||||
mul_pos := @mul_pos,
|
mul_pos := @int.mul_pos,
|
||||||
le_iff_lt_or_eq := le_iff_lt_or_eq,
|
le_iff_lt_or_eq := int.le_iff_lt_or_eq,
|
||||||
le_total := le.total,
|
le_total := int.le_total,
|
||||||
zero_ne_one := zero_ne_one,
|
zero_ne_one := int.zero_ne_one,
|
||||||
zero_lt_one := zero_lt_one,
|
zero_lt_one := int.zero_lt_one,
|
||||||
add_lt_add_left := @add_lt_add_left⦄
|
add_lt_add_left := @int.add_lt_add_left⦄
|
||||||
|
|
||||||
protected definition decidable_linear_ordered_comm_ring [reducible] [instance] :
|
protected definition decidable_linear_ordered_comm_ring [reducible] [instance] :
|
||||||
algebra.decidable_linear_ordered_comm_ring int :=
|
algebra.decidable_linear_ordered_comm_ring int :=
|
||||||
|
@ -387,7 +387,7 @@ theorem exists_least_of_bdd {P : ℤ → Prop} [HP : decidable_pred P]
|
||||||
let Hzb' := lt_of_not_ge Hzb,
|
let Hzb' := lt_of_not_ge Hzb,
|
||||||
let Hpos := iff.mpr !sub_pos_iff_lt Hzb',
|
let Hpos := iff.mpr !sub_pos_iff_lt Hzb',
|
||||||
have Hzbk : z = b + of_nat (nat_abs (z - b)),
|
have Hzbk : z = b + of_nat (nat_abs (z - b)),
|
||||||
by rewrite [of_nat_nat_abs_of_nonneg (int.le_of_lt Hpos), int.add.comm, algebra.sub_add_cancel],
|
by rewrite [of_nat_nat_abs_of_nonneg (int.le_of_lt Hpos), int.add_comm, algebra.sub_add_cancel],
|
||||||
have Hk : nat_abs (z - b) < least (λ n, P (b + of_nat n)) (nat.succ (nat_abs (elt - b))), begin
|
have Hk : nat_abs (z - b) < least (λ n, P (b + of_nat n)) (nat.succ (nat_abs (elt - b))), begin
|
||||||
let Hz' := iff.mp !lt_add_iff_sub_lt_left Hz,
|
let Hz' := iff.mp !lt_add_iff_sub_lt_left Hz,
|
||||||
rewrite [-of_nat_nat_abs_of_nonneg (int.le_of_lt Hpos) at Hz'],
|
rewrite [-of_nat_nat_abs_of_nonneg (int.le_of_lt Hpos) at Hz'],
|
||||||
|
|
|
@ -158,12 +158,12 @@ theorem add_equiv_add {a1 b1 a2 b2 : prerat} (eqv1 : a1 ≡ a2) (eqv2 : b1 ≡ b
|
||||||
calc
|
calc
|
||||||
(num a1 * denom b1 + num b1 * denom a1) * (denom a2 * denom b2)
|
(num a1 * denom b1 + num b1 * denom a1) * (denom a2 * denom b2)
|
||||||
= num a1 * denom a2 * denom b1 * denom b2 + num b1 * denom b2 * denom a1 * denom a2 :
|
= num a1 * denom a2 * denom b1 * denom b2 + num b1 * denom b2 * denom a1 * denom a2 :
|
||||||
by rewrite [mul.right_distrib, *mul.assoc, mul.left_comm (denom b1),
|
by rewrite [right_distrib, *mul.assoc, mul.left_comm (denom b1),
|
||||||
mul.comm (denom b2), *mul.assoc]
|
mul.comm (denom b2), *mul.assoc]
|
||||||
... = num a2 * denom a1 * denom b1 * denom b2 + num b2 * denom b1 * denom a1 * denom a2 :
|
... = num a2 * denom a1 * denom b1 * denom b2 + num b2 * denom b1 * denom a1 * denom a2 :
|
||||||
by rewrite [↑equiv at *, eqv1, eqv2]
|
by rewrite [↑equiv at *, eqv1, eqv2]
|
||||||
... = (num a2 * denom b2 + num b2 * denom a2) * (denom a1 * denom b1) :
|
... = (num a2 * denom b2 + num b2 * denom a2) * (denom a1 * denom b1) :
|
||||||
by rewrite [mul.right_distrib, *mul.assoc, *mul.left_comm (denom b2),
|
by rewrite [right_distrib, *mul.assoc, *mul.left_comm (denom b2),
|
||||||
*mul.comm (denom b1), *mul.assoc, mul.left_comm (denom a2)]
|
*mul.comm (denom b1), *mul.assoc, mul.left_comm (denom a2)]
|
||||||
|
|
||||||
theorem mul_equiv_mul {a1 b1 a2 b2 : prerat} (eqv1 : a1 ≡ a2) (eqv2 : b1 ≡ b2) :
|
theorem mul_equiv_mul {a1 b1 a2 b2 : prerat} (eqv1 : a1 ≡ a2) (eqv2 : b1 ≡ b2) :
|
||||||
|
@ -215,8 +215,8 @@ theorem add.comm (a b : prerat) : add a b ≡ add b a :=
|
||||||
by rewrite [↑add, ↑equiv, ▸*, add.comm, mul.comm (denom a)]
|
by rewrite [↑add, ↑equiv, ▸*, add.comm, mul.comm (denom a)]
|
||||||
|
|
||||||
theorem add.assoc (a b c : prerat) : add (add a b) c ≡ add a (add b c) :=
|
theorem add.assoc (a b c : prerat) : add (add a b) c ≡ add a (add b c) :=
|
||||||
by rewrite [↑add, ↑equiv, ▸*, *(mul.comm (num c)), *(λy, mul.comm y (denom a)), *mul.left_distrib,
|
by rewrite [↑add, ↑equiv, ▸*, *(mul.comm (num c)), *(λy, mul.comm y (denom a)), *left_distrib,
|
||||||
*mul.right_distrib, *mul.assoc, *add.assoc]
|
*right_distrib, *mul.assoc, *add.assoc]
|
||||||
|
|
||||||
theorem add_zero (a : prerat) : add a zero ≡ a :=
|
theorem add_zero (a : prerat) : add a zero ≡ a :=
|
||||||
by rewrite [↑add, ↑equiv, ↑zero, ↑of_int, ▸*, *mul_one, zero_mul, add_zero]
|
by rewrite [↑add, ↑equiv, ↑zero, ↑of_int, ▸*, *mul_one, zero_mul, add_zero]
|
||||||
|
@ -238,12 +238,12 @@ have H : smul (denom a) (mul a (add b c)) (denom_pos a) =
|
||||||
add (mul a b) (mul a c), from begin
|
add (mul a b) (mul a c), from begin
|
||||||
rewrite[↑smul, ↑mul, ↑add],
|
rewrite[↑smul, ↑mul, ↑add],
|
||||||
congruence,
|
congruence,
|
||||||
rewrite[*mul.left_distrib, *mul.right_distrib, -*int.mul.assoc],
|
rewrite[*left_distrib, *right_distrib, -+(int.mul_assoc)],
|
||||||
have T : ∀ {x y z w : ℤ}, x*y*z*w=y*z*x*w, from
|
have T : ∀ {x y z w : ℤ}, x*y*z*w=y*z*x*w, from
|
||||||
λx y z w, (!int.mul.assoc ⬝ !int.mul.comm) ▸ rfl,
|
λx y z w, (!int.mul_assoc ⬝ !int.mul_comm) ▸ rfl,
|
||||||
exact !congr_arg2 T T,
|
exact !congr_arg2 T T,
|
||||||
rewrite [mul.left_comm (denom a) (denom b) (denom c)],
|
rewrite [mul.left_comm (denom a) (denom b) (denom c)],
|
||||||
rewrite int.mul.assoc
|
rewrite int.mul_assoc
|
||||||
end,
|
end,
|
||||||
equiv.symm (H ▸ smul_equiv (denom_pos a))
|
equiv.symm (H ▸ smul_equiv (denom_pos a))
|
||||||
|
|
||||||
|
@ -258,7 +258,7 @@ theorem mul_inv_cancel : ∀{a : prerat}, ¬ a ≡ zero → mul a (inv a) ≡ on
|
||||||
mul a (inv a) ≡ mul a ia : mul_equiv_mul !equiv.refl (inv_of_neg an_neg adp)
|
mul a (inv a) ≡ mul a ia : mul_equiv_mul !equiv.refl (inv_of_neg an_neg adp)
|
||||||
... ≡ one : begin
|
... ≡ one : begin
|
||||||
esimp [equiv, num, denom, one, mul, of_int],
|
esimp [equiv, num, denom, one, mul, of_int],
|
||||||
rewrite [*int.mul_one, *int.one_mul, int.mul.comm,
|
rewrite [*int.mul_one, *int.one_mul, algebra.mul.comm,
|
||||||
neg_mul_comm]
|
neg_mul_comm]
|
||||||
end)
|
end)
|
||||||
(assume an_zero : an = 0, absurd (equiv_zero_of_num_eq_zero an_zero) H)
|
(assume an_zero : an = 0, absurd (equiv_zero_of_num_eq_zero an_zero) H)
|
||||||
|
@ -268,7 +268,7 @@ theorem mul_inv_cancel : ∀{a : prerat}, ¬ a ≡ zero → mul a (inv a) ≡ on
|
||||||
mul a (inv a) ≡ mul a ia : mul_equiv_mul !equiv.refl (inv_of_pos an_pos adp)
|
mul a (inv a) ≡ mul a ia : mul_equiv_mul !equiv.refl (inv_of_pos an_pos adp)
|
||||||
... ≡ one : begin
|
... ≡ one : begin
|
||||||
esimp [equiv, num, denom, one, mul, of_int],
|
esimp [equiv, num, denom, one, mul, of_int],
|
||||||
rewrite [*int.mul_one, *int.one_mul, int.mul.comm]
|
rewrite [*int.mul_one, *int.one_mul, algebra.mul.comm]
|
||||||
end)
|
end)
|
||||||
|
|
||||||
theorem zero_not_equiv_one : ¬ zero ≡ one :=
|
theorem zero_not_equiv_one : ¬ zero ≡ one :=
|
||||||
|
@ -306,8 +306,8 @@ theorem reduce_equiv : ∀ a : prerat, reduce a ≡ a
|
||||||
(assume anz : an = 0,
|
(assume anz : an = 0,
|
||||||
begin rewrite [↑reduce, if_pos anz, ↑equiv, anz], krewrite zero_mul end)
|
begin rewrite [↑reduce, if_pos anz, ↑equiv, anz], krewrite zero_mul end)
|
||||||
(assume annz : an ≠ 0,
|
(assume annz : an ≠ 0,
|
||||||
by rewrite [↑reduce, if_neg annz, ↑equiv, int.mul.comm, -!mul_div_assoc !gcd_dvd_left,
|
by rewrite [↑reduce, if_neg annz, ↑equiv, algebra.mul.comm, -!mul_div_assoc !gcd_dvd_left,
|
||||||
-!mul_div_assoc !gcd_dvd_right, int.mul.comm])
|
-!mul_div_assoc !gcd_dvd_right, algebra.mul.comm])
|
||||||
|
|
||||||
theorem reduce_eq_reduce : ∀{a b : prerat}, a ≡ b → reduce a = reduce b
|
theorem reduce_eq_reduce : ∀{a b : prerat}, a ≡ b → reduce a = reduce b
|
||||||
| (mk an ad adpos) (mk bn bd bdpos) :=
|
| (mk an ad adpos) (mk bn bd bdpos) :=
|
||||||
|
@ -331,7 +331,7 @@ theorem reduce_eq_reduce : ∀{a b : prerat}, a ≡ b → reduce a = reduce b
|
||||||
{apply div_gcd_eq_div_gcd H adpos bdpos},
|
{apply div_gcd_eq_div_gcd H adpos bdpos},
|
||||||
{esimp, rewrite [gcd.comm, gcd.comm bn],
|
{esimp, rewrite [gcd.comm, gcd.comm bn],
|
||||||
apply div_gcd_eq_div_gcd_of_nonneg,
|
apply div_gcd_eq_div_gcd_of_nonneg,
|
||||||
rewrite [int.mul.comm, -H, int.mul.comm],
|
rewrite [algebra.mul.comm, -H, algebra.mul.comm],
|
||||||
apply annz,
|
apply annz,
|
||||||
apply bnnz,
|
apply bnnz,
|
||||||
apply le_of_lt adpos,
|
apply le_of_lt adpos,
|
||||||
|
|
|
@ -66,7 +66,7 @@ gcd.induction x y
|
||||||
rewrite [-of_nat_mod],
|
rewrite [-of_nat_mod],
|
||||||
rewrite [int.modulo.def],
|
rewrite [int.modulo.def],
|
||||||
rewrite [+algebra.mul_sub_right_distrib],
|
rewrite [+algebra.mul_sub_right_distrib],
|
||||||
rewrite [+algebra.mul_sub_left_distrib, *mul.left_distrib],
|
rewrite [+algebra.mul_sub_left_distrib, *left_distrib],
|
||||||
rewrite [*sub_eq_add_neg, {pr₂ (egcd n (m mod n)) * of_nat m + - _}algebra.add.comm, -algebra.add.assoc],
|
rewrite [*sub_eq_add_neg, {pr₂ (egcd n (m mod n)) * of_nat m + - _}algebra.add.comm, -algebra.add.assoc],
|
||||||
rewrite [algebra.mul.assoc]
|
rewrite [algebra.mul.assoc]
|
||||||
end)
|
end)
|
||||||
|
@ -79,7 +79,7 @@ obtain a' b' (H : a' * nat_abs x + b' * nat_abs y = gcd x y), from !Bezout_aux,
|
||||||
begin
|
begin
|
||||||
existsi (a' * sign x),
|
existsi (a' * sign x),
|
||||||
existsi (b' * sign y),
|
existsi (b' * sign y),
|
||||||
rewrite [*int.mul.assoc, -*abs_eq_sign_mul, -*of_nat_nat_abs],
|
rewrite [*mul.assoc, -*abs_eq_sign_mul, -*of_nat_nat_abs],
|
||||||
apply H
|
apply H
|
||||||
end
|
end
|
||||||
end Bezout
|
end Bezout
|
||||||
|
@ -99,7 +99,7 @@ decidable.by_cases
|
||||||
have cpx : coprime p x, from coprime_of_prime_of_not_dvd pp this,
|
have cpx : coprime p x, from coprime_of_prime_of_not_dvd pp this,
|
||||||
obtain (a b : ℤ) (Hab : a * p + b * x = gcd p x), from Bezout_aux p x,
|
obtain (a b : ℤ) (Hab : a * p + b * x = gcd p x), from Bezout_aux p x,
|
||||||
assert a * p * y + b * x * y = y,
|
assert a * p * y + b * x * y = y,
|
||||||
by rewrite [-int.mul.right_distrib, Hab, ↑coprime at cpx, cpx, int.one_mul],
|
by rewrite [-right_distrib, Hab, ↑coprime at cpx, cpx, int.one_mul],
|
||||||
have p ∣ y,
|
have p ∣ y,
|
||||||
begin
|
begin
|
||||||
apply dvd_of_of_nat_dvd_of_nat,
|
apply dvd_of_of_nat_dvd_of_nat,
|
||||||
|
@ -108,7 +108,7 @@ decidable.by_cases
|
||||||
{apply dvd_mul_of_dvd_left,
|
{apply dvd_mul_of_dvd_left,
|
||||||
apply dvd_mul_of_dvd_right,
|
apply dvd_mul_of_dvd_right,
|
||||||
apply dvd.refl},
|
apply dvd.refl},
|
||||||
{rewrite int.mul.assoc,
|
{rewrite mul.assoc,
|
||||||
apply dvd_mul_of_dvd_right,
|
apply dvd_mul_of_dvd_right,
|
||||||
apply of_nat_dvd_of_nat_of_dvd H}
|
apply of_nat_dvd_of_nat_of_dvd H}
|
||||||
end,
|
end,
|
||||||
|
|
Loading…
Reference in a new issue