refactor(library/data/int/{basic,order}): protect theorem names

This commit is contained in:
Jeremy Avigad 2015-10-22 16:36:45 -04:00 committed by Leonardo de Moura
parent dc8858d764
commit 6dfaf1863c
6 changed files with 105 additions and 106 deletions

View file

@ -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

View file

@ -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

View file

@ -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)

View file

@ -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'],

View file

@ -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,

View file

@ -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,