2015-02-18 21:42:45 +00:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2014 Robert Lewis. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
Authors: Robert Lewis
|
|
|
|
|
|
2015-02-18 22:33:41 +00:00
|
|
|
|
Structures with multiplicative and additive components, including division rings and fields.
|
2015-02-18 21:42:45 +00:00
|
|
|
|
The development is modeled after Isabelle's library.
|
|
|
|
|
-/
|
2015-02-23 18:05:24 +00:00
|
|
|
|
----------------------------------------------------------------------------------------------------
|
2015-02-18 21:42:45 +00:00
|
|
|
|
import logic.eq logic.connectives data.unit data.sigma data.prod
|
|
|
|
|
import algebra.function algebra.binary algebra.group algebra.ring
|
|
|
|
|
open eq eq.ops
|
|
|
|
|
|
|
|
|
|
namespace algebra
|
|
|
|
|
|
|
|
|
|
variable {A : Type}
|
|
|
|
|
|
2015-03-16 21:05:13 +00:00
|
|
|
|
-- in division rings, 1 / 0 = 0
|
2015-03-25 21:08:36 +00:00
|
|
|
|
structure division_ring [class] (A : Type) extends ring A, has_inv A, zero_ne_one_class A :=
|
2015-02-18 21:42:45 +00:00
|
|
|
|
(mul_inv_cancel : ∀{a}, a ≠ zero → mul a (inv a) = one)
|
|
|
|
|
(inv_mul_cancel : ∀{a}, a ≠ zero → mul (inv a) a = one)
|
2015-03-27 17:11:23 +00:00
|
|
|
|
--(inv_zero : inv zero = zero)
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
section division_ring
|
|
|
|
|
variables [s : division_ring A] {a b c : A}
|
|
|
|
|
include s
|
|
|
|
|
|
|
|
|
|
definition divide (a b : A) : A := a * b⁻¹
|
|
|
|
|
infix `/` := divide
|
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
-- only in this file
|
|
|
|
|
local attribute divide [reducible]
|
|
|
|
|
|
2015-02-18 21:42:45 +00:00
|
|
|
|
theorem mul_inv_cancel (H : a ≠ 0) : a * a⁻¹ = 1 :=
|
|
|
|
|
division_ring.mul_inv_cancel H
|
|
|
|
|
|
|
|
|
|
theorem inv_mul_cancel (H : a ≠ 0) : a⁻¹ * a = 1 :=
|
|
|
|
|
division_ring.inv_mul_cancel H
|
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
theorem inv_eq_one_div : a⁻¹ = 1 / a := !one_mul⁻¹
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-03-27 17:11:23 +00:00
|
|
|
|
-- the following are only theorems if we assume inv_zero here
|
|
|
|
|
/- theorem inv_zero : 0⁻¹ = 0 := !division_ring.inv_zero
|
2015-03-16 21:05:13 +00:00
|
|
|
|
|
|
|
|
|
theorem one_div_zero : 1 / 0 = 0 :=
|
|
|
|
|
calc
|
|
|
|
|
1 / 0 = 1 * 0⁻¹ : refl
|
|
|
|
|
... = 1 * 0 : division_ring.inv_zero A
|
|
|
|
|
... = 0 : mul_zero
|
2015-03-27 17:11:23 +00:00
|
|
|
|
-/
|
2015-03-16 21:05:13 +00:00
|
|
|
|
|
2015-02-27 20:44:36 +00:00
|
|
|
|
theorem div_eq_mul_one_div : a / b = a * (1 / b) :=
|
2015-03-25 21:08:36 +00:00
|
|
|
|
by rewrite [↑divide, one_mul]
|
2015-02-27 20:44:36 +00:00
|
|
|
|
|
2015-03-27 17:11:23 +00:00
|
|
|
|
-- theorem div_zero : a / 0 = 0 := by rewrite [div_eq_mul_one_div, one_div_zero, mul_zero]
|
2015-03-16 21:05:13 +00:00
|
|
|
|
|
2015-02-18 21:42:45 +00:00
|
|
|
|
theorem mul_one_div_cancel (H : a ≠ 0) : a * (1 / a) = 1 :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [-inv_eq_one_div, (mul_inv_cancel H)]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem one_div_mul_cancel (H : a ≠ 0) : (1 / a) * a = 1 :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [-inv_eq_one_div, (inv_mul_cancel H)]
|
2015-03-25 21:08:36 +00:00
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
theorem div_self (H : a ≠ 0) : a / a = 1 := mul_inv_cancel H
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-05-18 22:45:23 +00:00
|
|
|
|
theorem one_div_one : 1 / 1 = (1:A) := div_self (ne.symm zero_ne_one)
|
2015-03-19 15:53:04 +00:00
|
|
|
|
|
2015-02-23 18:05:24 +00:00
|
|
|
|
theorem mul_div_assoc : (a * b) / c = a * (b / c) := !mul.assoc
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem one_div_ne_zero (H : a ≠ 0) : 1 / a ≠ 0 :=
|
|
|
|
|
assume H2 : 1 / a = 0,
|
2015-05-18 22:45:23 +00:00
|
|
|
|
have C1 : 0 = (1:A), from symm (by rewrite [-(mul_one_div_cancel H), H2, mul_zero]),
|
2015-02-27 20:44:36 +00:00
|
|
|
|
absurd C1 zero_ne_one
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-03-27 17:11:23 +00:00
|
|
|
|
-- theorem ne_zero_of_one_div_ne_zero (H : 1 / a ≠ 0) : a ≠ 0 :=
|
|
|
|
|
-- assume Ha : a = 0, absurd (Ha⁻¹ ▸ one_div_zero) H
|
2015-03-16 21:05:13 +00:00
|
|
|
|
|
2015-05-23 04:05:06 +00:00
|
|
|
|
theorem one_inv_eq : 1⁻¹ = (1:A) :=
|
2015-05-18 22:45:23 +00:00
|
|
|
|
by rewrite [-mul_one, inv_mul_cancel (ne.symm (@zero_ne_one A _))]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem div_one : a / 1 = a :=
|
2015-05-23 04:05:06 +00:00
|
|
|
|
by rewrite [↑divide, one_inv_eq, mul_one]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-02-23 18:05:24 +00:00
|
|
|
|
theorem zero_div : 0 / a = 0 := !zero_mul
|
|
|
|
|
|
|
|
|
|
-- note: integral domain has a "mul_ne_zero". Discrete fields are int domains.
|
2015-02-18 21:42:45 +00:00
|
|
|
|
theorem mul_ne_zero' (Ha : a ≠ 0) (Hb : b ≠ 0) : a * b ≠ 0 :=
|
|
|
|
|
assume H : a * b = 0,
|
2015-02-27 20:44:36 +00:00
|
|
|
|
have C1 : a = 0, by rewrite [-mul_one, -(mul_one_div_cancel Hb), -mul.assoc, H, zero_mul],
|
2015-02-18 21:42:45 +00:00
|
|
|
|
absurd C1 Ha
|
|
|
|
|
|
|
|
|
|
theorem mul_ne_zero_comm (H : a * b ≠ 0) : b * a ≠ 0 :=
|
2015-05-23 04:05:06 +00:00
|
|
|
|
have H2 : a ≠ 0 ∧ b ≠ 0, from ne_zero_and_ne_zero_of_mul_ne_zero H,
|
2015-02-18 21:42:45 +00:00
|
|
|
|
mul_ne_zero' (and.right H2) (and.left H2)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-- make "left" and "right" versions?
|
|
|
|
|
theorem eq_one_div_of_mul_eq_one (H : a * b = 1) : b = 1 / a :=
|
2015-03-25 21:08:36 +00:00
|
|
|
|
have H2 : a ≠ 0, from
|
2015-05-18 22:45:23 +00:00
|
|
|
|
(assume aeq0 : a = 0,
|
|
|
|
|
have B : 0 = (1:A), by rewrite [-(zero_mul b), -aeq0, H],
|
2015-02-18 21:42:45 +00:00
|
|
|
|
absurd B zero_ne_one),
|
|
|
|
|
show b = 1 / a, from symm (calc
|
2015-02-27 20:44:36 +00:00
|
|
|
|
1 / a = (1 / a) * 1 : mul_one
|
|
|
|
|
... = (1 / a) * (a * b) : H
|
|
|
|
|
... = (1 / a) * a * b : mul.assoc
|
|
|
|
|
... = 1 * b : one_div_mul_cancel H2
|
|
|
|
|
... = b : one_mul)
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
-- which one is left and which is right?
|
|
|
|
|
theorem eq_one_div_of_mul_eq_one_left (H : b * a = 1) : b = 1 / a :=
|
2015-03-25 21:08:36 +00:00
|
|
|
|
have H2 : a ≠ 0, from
|
2015-02-18 21:42:45 +00:00
|
|
|
|
(assume A : a = 0,
|
|
|
|
|
have B : 0 = 1, from symm (calc
|
|
|
|
|
1 = b * a : symm H
|
|
|
|
|
... = b * 0 : A
|
2015-02-27 20:44:36 +00:00
|
|
|
|
... = 0 : mul_zero),
|
2015-02-18 21:42:45 +00:00
|
|
|
|
absurd B zero_ne_one),
|
|
|
|
|
show b = 1 / a, from symm (calc
|
2015-02-27 20:44:36 +00:00
|
|
|
|
1 / a = 1 * (1 / a) : one_mul
|
|
|
|
|
... = b * a * (1 / a) : H
|
|
|
|
|
... = b * (a * (1 / a)) : mul.assoc
|
|
|
|
|
... = b * 1 : mul_one_div_cancel H2
|
|
|
|
|
... = b : mul_one)
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem one_div_mul_one_div (Ha : a ≠ 0) (Hb : b ≠ 0) : (1 / a) * (1 / b) = 1 / (b * a) :=
|
2015-03-25 21:08:36 +00:00
|
|
|
|
have H : (b * a) * ((1 / a) * (1 / b)) = 1, by
|
2015-02-27 20:44:36 +00:00
|
|
|
|
rewrite [mul.assoc, -(mul.assoc a), (mul_one_div_cancel Ha), one_mul, (mul_one_div_cancel Hb)],
|
2015-03-25 21:08:36 +00:00
|
|
|
|
eq_one_div_of_mul_eq_one H
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-05-18 22:45:23 +00:00
|
|
|
|
theorem one_div_neg_one_eq_neg_one : (1:A) / (-1) = -1 :=
|
|
|
|
|
have H : (-1) * (-1) = (1:A), by rewrite [-neg_eq_neg_one_mul, neg_neg],
|
2015-02-18 21:42:45 +00:00
|
|
|
|
symm (eq_one_div_of_mul_eq_one H)
|
|
|
|
|
|
2015-03-25 21:08:36 +00:00
|
|
|
|
theorem one_div_neg_eq_neg_one_div (H : a ≠ 0) : 1 / (- a) = - (1 / a) :=
|
2015-02-18 21:42:45 +00:00
|
|
|
|
have H1 : -1 ≠ 0, from
|
|
|
|
|
(assume H2 : -1 = 0, absurd (symm (calc
|
2015-02-27 20:44:36 +00:00
|
|
|
|
1 = -(-1) : neg_neg
|
|
|
|
|
... = -0 : H2
|
2015-05-18 22:45:23 +00:00
|
|
|
|
... = (0:A) : neg_zero)) zero_ne_one),
|
2015-02-18 21:42:45 +00:00
|
|
|
|
calc
|
2015-02-27 20:44:36 +00:00
|
|
|
|
1 / (- a) = 1 / ((-1) * a) : neg_eq_neg_one_mul
|
2015-03-25 21:08:36 +00:00
|
|
|
|
... = (1 / a) * (1 / (- 1)) : one_div_mul_one_div H H1
|
2015-02-27 20:44:36 +00:00
|
|
|
|
... = (1 / a) * (-1) : one_div_neg_one_eq_neg_one
|
|
|
|
|
... = - (1 / a) : mul_neg_one_eq_neg
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-02-23 18:05:24 +00:00
|
|
|
|
theorem div_neg_eq_neg_div (Ha : a ≠ 0) : b / (- a) = - (b / a) :=
|
|
|
|
|
calc
|
|
|
|
|
b / (- a) = b * (1 / (- a)) : inv_eq_one_div
|
2015-02-27 20:44:36 +00:00
|
|
|
|
... = b * -(1 / a) : one_div_neg_eq_neg_one_div Ha
|
|
|
|
|
... = -(b * (1 / a)) : neg_mul_eq_mul_neg
|
|
|
|
|
... = - (b * a⁻¹) : inv_eq_one_div
|
2015-02-23 18:05:24 +00:00
|
|
|
|
|
|
|
|
|
theorem neg_div (Ha : a ≠ 0) : (-b) / a = - (b / a) :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [neg_eq_neg_one_mul, mul_div_assoc, -neg_eq_neg_one_mul]
|
2015-02-23 18:05:24 +00:00
|
|
|
|
|
|
|
|
|
theorem neg_div_neg_eq_div (Hb : b ≠ 0) : (-a) / (-b) = a / b :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [(div_neg_eq_neg_div Hb), (neg_div Hb), neg_neg]
|
2015-02-23 18:05:24 +00:00
|
|
|
|
|
2015-02-18 21:42:45 +00:00
|
|
|
|
theorem div_div (H : a ≠ 0) : 1 / (1 / a) = a :=
|
|
|
|
|
symm (eq_one_div_of_mul_eq_one_left (mul_one_div_cancel H))
|
|
|
|
|
|
|
|
|
|
theorem eq_of_invs_eq (Ha : a ≠ 0) (Hb : b ≠ 0) (H : 1 / a = 1 / b) : a = b :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [-(div_div Ha), H, (div_div Hb)]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-05-23 04:05:06 +00:00
|
|
|
|
theorem mul_inv_eq (Ha : a ≠ 0) (Hb : b ≠ 0) : (b * a)⁻¹ = a⁻¹ * b⁻¹ :=
|
2015-02-18 21:42:45 +00:00
|
|
|
|
have H1 : b * a ≠ 0, from mul_ne_zero' Hb Ha,
|
|
|
|
|
eq.symm (calc
|
2015-02-19 20:17:21 +00:00
|
|
|
|
a⁻¹ * b⁻¹ = (1 / a) * b⁻¹ : inv_eq_one_div
|
|
|
|
|
... = (1 / a) * (1 / b) : inv_eq_one_div
|
2015-02-18 21:42:45 +00:00
|
|
|
|
... = (1 / (b * a)) : one_div_mul_one_div Ha Hb
|
2015-02-19 20:17:21 +00:00
|
|
|
|
... = (b * a)⁻¹ : inv_eq_one_div)
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem mul_div_cancel (Hb : b ≠ 0) : a * b / b = a :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [↑divide, mul.assoc, (mul_inv_cancel Hb), mul_one]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem div_mul_cancel (Hb : b ≠ 0) : a / b * b = a :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [↑divide, mul.assoc, (inv_mul_cancel Hb), mul_one]
|
2015-03-25 21:08:36 +00:00
|
|
|
|
|
2015-02-23 18:05:24 +00:00
|
|
|
|
theorem div_add_div_same : a / c + b / c = (a + b) / c := !right_distrib⁻¹
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-02-18 22:33:41 +00:00
|
|
|
|
theorem inv_mul_add_mul_inv_eq_inv_add_inv (Ha : a ≠ 0) (Hb : b ≠ 0) :
|
|
|
|
|
(1 / a) * (a + b) * (1 / b) = 1 / a + 1 / b :=
|
|
|
|
|
by rewrite [(left_distrib (1 / a)), (one_div_mul_cancel Ha), right_distrib, one_mul,
|
|
|
|
|
mul.assoc, (mul_one_div_cancel Hb), mul_one, add.comm]
|
|
|
|
|
|
|
|
|
|
theorem inv_mul_sub_mul_inv_eq_inv_add_inv (Ha : a ≠ 0) (Hb : b ≠ 0) :
|
|
|
|
|
(1 / a) * (b - a) * (1 / b) = 1 / a - 1 / b :=
|
|
|
|
|
by rewrite [(mul_sub_left_distrib (1 / a)), (one_div_mul_cancel Ha), mul_sub_right_distrib,
|
2015-02-27 20:44:36 +00:00
|
|
|
|
one_mul, mul.assoc, (mul_one_div_cancel Hb), mul_one, one_mul]
|
2015-02-18 22:33:41 +00:00
|
|
|
|
|
2015-03-25 21:08:36 +00:00
|
|
|
|
theorem div_eq_one_iff_eq (Hb : b ≠ 0) : a / b = 1 ↔ a = b :=
|
2015-02-18 22:33:41 +00:00
|
|
|
|
iff.intro
|
|
|
|
|
(assume H1 : a / b = 1, symm (calc
|
2015-02-27 20:44:36 +00:00
|
|
|
|
b = 1 * b : one_mul
|
2015-02-18 22:33:41 +00:00
|
|
|
|
... = a / b * b : H1
|
2015-02-27 20:44:36 +00:00
|
|
|
|
... = a : div_mul_cancel Hb))
|
2015-02-18 22:33:41 +00:00
|
|
|
|
(assume H2 : a = b, calc
|
|
|
|
|
a / b = b / b : H2
|
2015-02-27 20:44:36 +00:00
|
|
|
|
... = 1 : div_self Hb)
|
2015-02-18 22:33:41 +00:00
|
|
|
|
|
2015-02-23 18:05:24 +00:00
|
|
|
|
theorem eq_div_iff_mul_eq (Hc : c ≠ 0) : a = b / c ↔ a * c = b :=
|
|
|
|
|
iff.intro
|
2015-02-27 20:44:36 +00:00
|
|
|
|
(assume H : a = b / c, by rewrite [H, (div_mul_cancel Hc)])
|
|
|
|
|
(assume H : a * c = b, by rewrite [-(mul_div_cancel Hc), H])
|
2015-02-23 18:05:24 +00:00
|
|
|
|
|
|
|
|
|
theorem add_div_eq_mul_add_div (Hc : c ≠ 0) : a + b / c = (a * c + b) / c :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
have H : (a + b / c) * c = a * c + b, by rewrite [right_distrib, (div_mul_cancel Hc)],
|
2015-02-23 18:05:24 +00:00
|
|
|
|
(iff.elim_right (eq_div_iff_mul_eq Hc)) H
|
|
|
|
|
|
2015-03-27 17:11:23 +00:00
|
|
|
|
theorem mul_mul_div (Hc : c ≠ 0) : a = a * c * (1 / c) :=
|
2015-03-20 15:20:12 +00:00
|
|
|
|
calc
|
|
|
|
|
a = a * 1 : mul_one
|
|
|
|
|
... = a * (c * (1 / c)) : mul_one_div_cancel Hc
|
|
|
|
|
... = a * c * (1 / c) : mul.assoc
|
|
|
|
|
|
2015-02-27 20:44:36 +00:00
|
|
|
|
-- There are many similar rules to these last two in the Isabelle library
|
|
|
|
|
-- that haven't been ported yet. Do as necessary.
|
|
|
|
|
|
2015-02-18 21:42:45 +00:00
|
|
|
|
end division_ring
|
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
structure field [class] (A : Type) extends division_ring A, comm_ring A
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
section field
|
|
|
|
|
variables [s : field A] {a b c d: A}
|
|
|
|
|
include s
|
2015-02-23 18:05:24 +00:00
|
|
|
|
local attribute divide [reducible]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-02-27 20:44:36 +00:00
|
|
|
|
theorem one_div_mul_one_div' (Ha : a ≠ 0) (Hb : b ≠ 0) : (1 / a) * (1 / b) = 1 / (a * b) :=
|
|
|
|
|
by rewrite [(one_div_mul_one_div Ha Hb), mul.comm b]
|
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
theorem div_mul_right (Hb : b ≠ 0) (H : a * b ≠ 0) : a / (a * b) = 1 / b :=
|
2015-05-23 04:05:06 +00:00
|
|
|
|
let Ha : a ≠ 0 := and.left (ne_zero_and_ne_zero_of_mul_ne_zero H) in
|
2015-02-18 21:42:45 +00:00
|
|
|
|
symm (calc
|
2015-02-27 20:44:36 +00:00
|
|
|
|
1 / b = 1 * (1 / b) : one_mul
|
|
|
|
|
... = (a * a⁻¹) * (1 / b) : mul_inv_cancel Ha
|
|
|
|
|
... = a * (a⁻¹ * (1 / b)) : mul.assoc
|
|
|
|
|
... = a * ((1 / a) * (1 / b)) :inv_eq_one_div
|
|
|
|
|
... = a * (1 / (b * a)) : one_div_mul_one_div Ha Hb
|
|
|
|
|
... = a * (1 / (a * b)) : mul.comm
|
|
|
|
|
... = a * (a * b)⁻¹ : inv_eq_one_div)
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
theorem div_mul_left (Ha : a ≠ 0) (H : a * b ≠ 0) : b / (a * b) = 1 / a :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
let H1 : b * a ≠ 0 := mul_ne_zero_comm H in
|
|
|
|
|
by rewrite [mul.comm a, (div_mul_right Ha H1)]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem mul_div_cancel_left (Ha : a ≠ 0) : a * b / a = b :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [mul.comm a, (mul_div_cancel Ha)]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem mul_div_cancel' (Hb : b ≠ 0) : b * (a / b) = a :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [mul.comm, (div_mul_cancel Hb)]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem one_div_add_one_div (Ha : a ≠ 0) (Hb : b ≠ 0) : 1 / a + 1 / b = (a + b) / (a * b) :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
have H [visible] : a * b ≠ 0, from (mul_ne_zero' Ha Hb),
|
|
|
|
|
by rewrite [add.comm, -(div_mul_left Ha H), -(div_mul_right Hb H), ↑divide, -right_distrib]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem div_mul_div (Hb : b ≠ 0) (Hd : d ≠ 0) : (a / b) * (c / d) = (a * c) / (b * d) :=
|
2015-05-23 04:05:06 +00:00
|
|
|
|
by rewrite [↑divide, 2 mul.assoc, (mul.comm b⁻¹), mul.assoc, (mul_inv_eq Hd Hb)]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem mul_div_mul_left (Hb : b ≠ 0) (Hc : c ≠ 0) : (c * a) / (c * b) = a / b :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
have H [visible] : c * b ≠ 0, from mul_ne_zero' Hc Hb,
|
|
|
|
|
by rewrite [-(div_mul_div Hc Hb), (div_self Hc), one_mul]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem mul_div_mul_right (Hb : b ≠ 0) (Hc : c ≠ 0) : (a * c) / (b * c) = a / b :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [(mul.comm a), (mul.comm b), (mul_div_mul_left Hb Hc)]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
2015-03-16 21:05:13 +00:00
|
|
|
|
theorem div_mul_eq_mul_div : (b / c) * a = (b * a) / c :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [↑divide, mul.assoc, (mul.comm c⁻¹), -mul.assoc]
|
2015-03-25 21:08:36 +00:00
|
|
|
|
|
2015-02-18 21:42:45 +00:00
|
|
|
|
-- this one is odd -- I am not sure what to call it, but again, the prefix is right
|
|
|
|
|
theorem div_mul_eq_mul_div_comm (Hc : c ≠ 0) : (b / c) * a = b * (a / c) :=
|
2015-03-16 21:05:13 +00:00
|
|
|
|
by rewrite [(div_mul_eq_mul_div), -(one_mul c), -(div_mul_div (ne.symm zero_ne_one) Hc), div_one, one_mul]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem div_add_div (Hb : b ≠ 0) (Hd : d ≠ 0) :
|
|
|
|
|
(a / b) + (c / d) = ((a * d) + (b * c)) / (b * d) :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
have H [visible] : b * d ≠ 0, from mul_ne_zero' Hb Hd,
|
|
|
|
|
by rewrite [-(mul_div_mul_right Hb Hd), -(mul_div_mul_left Hd Hb), div_add_div_same]
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
theorem div_sub_div (Hb : b ≠ 0) (Hd : d ≠ 0) :
|
|
|
|
|
(a / b) - (c / d) = ((a * d) - (b * c)) / (b * d) :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [↑sub, neg_eq_neg_one_mul, -mul_div_assoc, (div_add_div Hb Hd),
|
|
|
|
|
-mul.assoc, (mul.comm b), mul.assoc, -neg_eq_neg_one_mul]
|
2015-03-25 21:08:36 +00:00
|
|
|
|
|
2015-02-18 21:42:45 +00:00
|
|
|
|
theorem mul_eq_mul_of_div_eq_div (Hb : b ≠ 0) (Hd : d ≠ 0) (H : a / b = c / d) : a * d = c * b :=
|
2015-02-27 20:44:36 +00:00
|
|
|
|
by rewrite [-mul_one, mul.assoc, (mul.comm d), -mul.assoc, -(div_self Hb),
|
2015-03-16 21:05:13 +00:00
|
|
|
|
-(div_mul_eq_mul_div_comm Hb), H, (div_mul_eq_mul_div), (div_mul_cancel Hd)]
|
2015-02-27 20:44:36 +00:00
|
|
|
|
|
|
|
|
|
theorem one_div_div (Ha : a ≠ 0) (Hb : b ≠ 0) : 1 / (a / b) = b / a :=
|
|
|
|
|
have H : (a / b) * (b / a) = 1, from calc
|
|
|
|
|
(a / b) * (b / a) = (a * b) / (b * a) : div_mul_div Hb Ha
|
|
|
|
|
... = (a * b) / (a * b) : mul.comm
|
|
|
|
|
... = 1 : div_self (mul_ne_zero' Ha Hb),
|
|
|
|
|
symm (eq_one_div_of_mul_eq_one H)
|
|
|
|
|
|
|
|
|
|
theorem div_div_eq_mul_div (Hb : b ≠ 0) (Hc : c ≠ 0) : a / (b / c) = (a * c) / b :=
|
|
|
|
|
by rewrite [div_eq_mul_one_div, (one_div_div Hb Hc), -mul_div_assoc]
|
|
|
|
|
|
|
|
|
|
theorem div_div_eq_div_mul (Hb : b ≠ 0) (Hc : c ≠ 0) : (a / b) / c = a / (b * c) :=
|
|
|
|
|
by rewrite [div_eq_mul_one_div, (div_mul_div Hb Hc), mul_one]
|
|
|
|
|
|
|
|
|
|
theorem div_div_div_div (Hb : b ≠ 0) (Hc : c ≠ 0) (Hd : d ≠ 0) : (a / b) / (c / d) = (a * d) / (b * c) :=
|
2015-03-16 21:05:13 +00:00
|
|
|
|
by rewrite [(div_div_eq_mul_div Hc Hd), (div_mul_eq_mul_div), (div_div_eq_div_mul Hb Hc)]
|
2015-02-27 20:44:36 +00:00
|
|
|
|
|
|
|
|
|
-- remaining to transfer from Isabelle fields: ordered fields
|
2015-02-18 21:42:45 +00:00
|
|
|
|
|
|
|
|
|
end field
|
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
structure discrete_field [class] (A : Type) extends field A :=
|
2015-04-18 17:48:27 +00:00
|
|
|
|
(has_decidable_eq : decidable_eq A)
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(inv_zero : inv zero = zero)
|
2015-02-19 20:17:21 +00:00
|
|
|
|
|
2015-04-18 17:48:27 +00:00
|
|
|
|
attribute discrete_field.has_decidable_eq [instance]
|
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
section discrete_field
|
|
|
|
|
variable [s : discrete_field A]
|
|
|
|
|
include s
|
2015-03-16 21:05:13 +00:00
|
|
|
|
variables {a b c d : A}
|
2015-02-19 20:17:21 +00:00
|
|
|
|
|
2015-03-27 17:11:23 +00:00
|
|
|
|
-- many of the theorems in discrete_field are the same as theorems in field or division ring,
|
|
|
|
|
-- but with fewer hypotheses since 0⁻¹ = 0 and equality is decidable.
|
|
|
|
|
-- they are named with '. Is there a better convention?
|
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
theorem discrete_field.eq_zero_or_eq_zero_of_mul_eq_zero
|
|
|
|
|
(x y : A) (H : x * y = 0) : x = 0 ∨ y = 0 :=
|
|
|
|
|
decidable.by_cases
|
|
|
|
|
(assume H : x = 0, or.inl H)
|
|
|
|
|
(assume H1 : x ≠ 0,
|
2015-03-25 21:08:36 +00:00
|
|
|
|
or.inr (by rewrite [-one_mul, -(inv_mul_cancel H1), mul.assoc, H, mul_zero]))
|
2015-02-19 20:17:21 +00:00
|
|
|
|
|
2015-03-25 21:08:36 +00:00
|
|
|
|
definition discrete_field.to_integral_domain [instance] [reducible] [coercion] :
|
2015-02-19 20:17:21 +00:00
|
|
|
|
integral_domain A :=
|
|
|
|
|
⦃ integral_domain, s,
|
|
|
|
|
eq_zero_or_eq_zero_of_mul_eq_zero := discrete_field.eq_zero_or_eq_zero_of_mul_eq_zero⦄
|
|
|
|
|
|
2015-05-18 22:45:23 +00:00
|
|
|
|
theorem inv_zero : 0⁻¹ = (0:A) := !discrete_field.inv_zero
|
2015-03-27 17:11:23 +00:00
|
|
|
|
|
2015-05-18 22:45:23 +00:00
|
|
|
|
theorem one_div_zero : 1 / 0 = (0:A) :=
|
2015-03-27 17:11:23 +00:00
|
|
|
|
calc
|
|
|
|
|
1 / 0 = 1 * 0⁻¹ : refl
|
|
|
|
|
... = 1 * 0 : discrete_field.inv_zero A
|
|
|
|
|
... = 0 : mul_zero
|
|
|
|
|
|
|
|
|
|
theorem div_zero : a / 0 = 0 := by rewrite [div_eq_mul_one_div, one_div_zero, mul_zero]
|
|
|
|
|
|
|
|
|
|
theorem ne_zero_of_one_div_ne_zero (H : 1 / a ≠ 0) : a ≠ 0 :=
|
|
|
|
|
assume Ha : a = 0, absurd (Ha⁻¹ ▸ one_div_zero) H
|
|
|
|
|
|
2015-02-27 20:44:36 +00:00
|
|
|
|
theorem inv_zero_imp_zero (H : 1 / a = 0) : a = 0 :=
|
|
|
|
|
decidable.by_cases
|
2015-03-20 15:20:12 +00:00
|
|
|
|
(assume Ha, Ha)
|
|
|
|
|
(assume Ha, false.elim ((one_div_ne_zero Ha) H))
|
2015-02-27 20:44:36 +00:00
|
|
|
|
|
2015-03-16 21:05:13 +00:00
|
|
|
|
-- the following could all go in "discrete_division_ring"
|
|
|
|
|
theorem one_div_mul_one_div'' : (1 / a) * (1 / b) = 1 / (b * a) :=
|
|
|
|
|
decidable.by_cases
|
|
|
|
|
(assume Ha : a = 0,
|
|
|
|
|
by rewrite [Ha, div_zero, zero_mul, -(@div_zero A s 1), mul_zero b])
|
|
|
|
|
(assume Ha : a ≠ 0,
|
|
|
|
|
decidable.by_cases
|
|
|
|
|
(assume Hb : b = 0,
|
|
|
|
|
by rewrite [Hb, div_zero, mul_zero, -(@div_zero A s 1), zero_mul a])
|
|
|
|
|
(assume Hb : b ≠ 0, one_div_mul_one_div Ha Hb))
|
|
|
|
|
|
|
|
|
|
theorem one_div_neg_eq_neg_one_div' : 1 / (- a) = - (1 / a) :=
|
|
|
|
|
decidable.by_cases
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(assume Ha : a = 0, by rewrite [Ha, neg_zero, 2 div_zero, neg_zero])
|
2015-03-16 21:05:13 +00:00
|
|
|
|
(assume Ha : a ≠ 0, one_div_neg_eq_neg_one_div Ha)
|
|
|
|
|
|
|
|
|
|
theorem neg_div' : (-b) / a = - (b / a) :=
|
|
|
|
|
decidable.by_cases
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(assume Ha : a = 0, by rewrite [Ha, 2 div_zero, neg_zero])
|
2015-03-16 21:05:13 +00:00
|
|
|
|
(assume Ha : a ≠ 0, neg_div Ha)
|
|
|
|
|
|
|
|
|
|
theorem neg_div_neg_eq_div' : (-a) / (-b) = a / b :=
|
|
|
|
|
decidable.by_cases
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(assume Hb : b = 0, by rewrite [Hb, neg_zero, 2 div_zero])
|
2015-03-16 21:05:13 +00:00
|
|
|
|
(assume Hb : b ≠ 0, neg_div_neg_eq_div Hb)
|
|
|
|
|
|
|
|
|
|
theorem div_div' : 1 / (1 / a) = a :=
|
|
|
|
|
decidable.by_cases
|
|
|
|
|
(assume Ha : a = 0, by rewrite [Ha, 2 div_zero])
|
|
|
|
|
(assume Ha : a ≠ 0, div_div Ha)
|
|
|
|
|
|
|
|
|
|
theorem eq_of_invs_eq' (H : 1 / a = 1 / b) : a = b :=
|
|
|
|
|
decidable.by_cases
|
|
|
|
|
(assume Ha : a = 0,
|
|
|
|
|
have Hb : b = 0, from inv_zero_imp_zero (by rewrite [-H, Ha, div_zero]),
|
|
|
|
|
Hb⁻¹ ▸ Ha)
|
|
|
|
|
(assume Ha : a ≠ 0,
|
|
|
|
|
have Hb : b ≠ 0, from ne_zero_of_one_div_ne_zero (H ▸ (one_div_ne_zero Ha)),
|
|
|
|
|
eq_of_invs_eq Ha Hb H)
|
|
|
|
|
|
|
|
|
|
theorem mul_inv' : (b * a)⁻¹ = a⁻¹ * b⁻¹ :=
|
|
|
|
|
decidable.by_cases
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(assume Ha : a = 0, by rewrite [Ha, mul_zero, 2 inv_zero, zero_mul])
|
2015-03-16 21:05:13 +00:00
|
|
|
|
(assume Ha : a ≠ 0,
|
|
|
|
|
decidable.by_cases
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(assume Hb : b = 0, by rewrite [Hb, zero_mul, 2 inv_zero, mul_zero])
|
2015-05-23 04:05:06 +00:00
|
|
|
|
(assume Hb : b ≠ 0, mul_inv_eq Ha Hb))
|
2015-03-16 21:05:13 +00:00
|
|
|
|
|
|
|
|
|
-- the following are specifically for fields
|
|
|
|
|
theorem one_div_mul_one_div''' : (1 / a) * (1 / b) = 1 / (a * b) :=
|
|
|
|
|
by rewrite [(one_div_mul_one_div''), mul.comm b]
|
|
|
|
|
|
|
|
|
|
theorem div_mul_right' (Ha : a ≠ 0) : a / (a * b) = 1 / b :=
|
|
|
|
|
decidable.by_cases
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(assume Hb : b = 0, by rewrite [Hb, mul_zero, 2 div_zero])
|
2015-03-16 21:05:13 +00:00
|
|
|
|
(assume Hb : b ≠ 0, div_mul_right Hb (mul_ne_zero Ha Hb))
|
|
|
|
|
|
|
|
|
|
theorem div_mul_left' (Hb : b ≠ 0) : b / (a * b) = 1 / a :=
|
|
|
|
|
by rewrite [mul.comm a, div_mul_right' Hb]
|
|
|
|
|
|
|
|
|
|
theorem div_mul_div' : (a / b) * (c / d) = (a * c) / (b * d) :=
|
|
|
|
|
decidable.by_cases
|
|
|
|
|
(assume Hb : b = 0, by rewrite [Hb, div_zero, zero_mul, -(@div_zero A s (a * c)), zero_mul])
|
|
|
|
|
(assume Hb : b ≠ 0,
|
|
|
|
|
decidable.by_cases
|
|
|
|
|
(assume Hd : d = 0, by rewrite [Hd, div_zero, mul_zero, -(@div_zero A s (a * c)), mul_zero])
|
|
|
|
|
(assume Hd : d ≠ 0, div_mul_div Hb Hd))
|
|
|
|
|
|
|
|
|
|
theorem mul_div_mul_left' (Hc : c ≠ 0) : (c * a) / (c * b) = a / b :=
|
|
|
|
|
decidable.by_cases
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(assume Hb : b = 0, by rewrite [Hb, mul_zero, 2 div_zero])
|
2015-03-16 21:05:13 +00:00
|
|
|
|
(assume Hb : b ≠ 0, mul_div_mul_left Hb Hc)
|
|
|
|
|
|
|
|
|
|
theorem mul_div_mul_right' (Hc : c ≠ 0) : (a * c) / (b * c) = a / b :=
|
|
|
|
|
by rewrite [(mul.comm a), (mul.comm b), (mul_div_mul_left' Hc)]
|
|
|
|
|
|
|
|
|
|
-- this one is odd -- I am not sure what to call it, but again, the prefix is right
|
|
|
|
|
theorem div_mul_eq_mul_div_comm' : (b / c) * a = b * (a / c) :=
|
|
|
|
|
decidable.by_cases
|
|
|
|
|
(assume Hc : c = 0, by rewrite [Hc, div_zero, zero_mul, -(mul_zero b), -(@div_zero A s a)])
|
|
|
|
|
(assume Hc : c ≠ 0, div_mul_eq_mul_div_comm Hc)
|
|
|
|
|
|
|
|
|
|
theorem one_div_div' : 1 / (a / b) = b / a :=
|
|
|
|
|
decidable.by_cases
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(assume Ha : a = 0, by rewrite [Ha, zero_div, 2 div_zero])
|
2015-03-16 21:05:13 +00:00
|
|
|
|
(assume Ha : a ≠ 0,
|
|
|
|
|
decidable.by_cases
|
2015-03-27 17:11:23 +00:00
|
|
|
|
(assume Hb : b = 0, by rewrite [Hb, 2 div_zero, zero_div])
|
2015-03-16 21:05:13 +00:00
|
|
|
|
(assume Hb : b ≠ 0, one_div_div Ha Hb))
|
|
|
|
|
|
|
|
|
|
theorem div_div_eq_mul_div' : a / (b / c) = (a * c) / b :=
|
|
|
|
|
by rewrite [div_eq_mul_one_div, one_div_div', -mul_div_assoc]
|
|
|
|
|
|
|
|
|
|
theorem div_div_eq_div_mul' : (a / b) / c = a / (b * c) :=
|
|
|
|
|
by rewrite [div_eq_mul_one_div, div_mul_div', mul_one]
|
|
|
|
|
|
|
|
|
|
theorem div_div_div_div' : (a / b) / (c / d) = (a * d) / (b * c) :=
|
|
|
|
|
by rewrite [div_div_eq_mul_div', div_mul_eq_mul_div, div_div_eq_div_mul']
|
|
|
|
|
|
2015-02-19 20:17:21 +00:00
|
|
|
|
end discrete_field
|
|
|
|
|
|
2015-02-18 21:42:45 +00:00
|
|
|
|
end algebra
|
2015-03-16 21:05:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/-
|
|
|
|
|
decidable.by_cases
|
|
|
|
|
(assume Ha : a = 0, sorry)
|
|
|
|
|
(assume Ha : a ≠ 0, sorry)
|
|
|
|
|
-/
|