2014-11-28 08:11:23 -05:00
|
|
|
/-
|
|
|
|
Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
Authors: Leonardo de Moura, Jeremy Avigad
|
|
|
|
|
|
|
|
General properties of binary operations.
|
|
|
|
-/
|
2015-04-09 11:00:59 -07:00
|
|
|
import algebra.function
|
|
|
|
open eq.ops function
|
2014-07-24 17:46:41 -07:00
|
|
|
|
|
|
|
namespace binary
|
2014-11-28 08:11:23 -05:00
|
|
|
section
|
2014-10-09 07:13:06 -07:00
|
|
|
variable {A : Type}
|
2014-11-28 08:11:23 -05:00
|
|
|
variables (op₁ : A → A → A) (inv : A → A) (one : A)
|
|
|
|
|
2015-01-26 11:49:08 -08:00
|
|
|
local notation a * b := op₁ a b
|
|
|
|
local notation a ⁻¹ := inv a
|
|
|
|
local notation 1 := one
|
2014-11-28 08:11:23 -05:00
|
|
|
|
2015-04-09 10:54:28 -07:00
|
|
|
definition commutative [reducible] := ∀a b, a * b = b * a
|
|
|
|
definition associative [reducible] := ∀a b c, (a * b) * c = a * (b * c)
|
|
|
|
definition left_identity [reducible] := ∀a, 1 * a = a
|
|
|
|
definition right_identity [reducible] := ∀a, a * 1 = a
|
|
|
|
definition left_inverse [reducible] := ∀a, a⁻¹ * a = 1
|
|
|
|
definition right_inverse [reducible] := ∀a, a * a⁻¹ = 1
|
|
|
|
definition left_cancelative [reducible] := ∀a b c, a * b = a * c → b = c
|
|
|
|
definition right_cancelative [reducible] := ∀a b c, a * b = c * b → a = c
|
|
|
|
|
|
|
|
definition inv_op_cancel_left [reducible] := ∀a b, a⁻¹ * (a * b) = b
|
|
|
|
definition op_inv_cancel_left [reducible] := ∀a b, a * (a⁻¹ * b) = b
|
|
|
|
definition inv_op_cancel_right [reducible] := ∀a b, a * b⁻¹ * b = a
|
|
|
|
definition op_inv_cancel_right [reducible] := ∀a b, a * b * b⁻¹ = a
|
2014-11-28 08:11:23 -05:00
|
|
|
|
|
|
|
variable (op₂ : A → A → A)
|
|
|
|
|
2015-01-26 11:49:08 -08:00
|
|
|
local notation a + b := op₂ a b
|
2014-11-28 08:11:23 -05:00
|
|
|
|
2015-04-09 10:54:28 -07:00
|
|
|
definition left_distributive [reducible] := ∀a b c, a * (b + c) = a * b + a * c
|
|
|
|
definition right_distributive [reducible] := ∀a b c, (a + b) * c = a * c + b * c
|
|
|
|
|
|
|
|
definition right_commutative [reducible] {B : Type} (f : B → A → B) := ∀ b a₁ a₂, f (f b a₁) a₂ = f (f b a₂) a₁
|
|
|
|
definition left_commutative [reducible] {B : Type} (f : A → B → B) := ∀ a₁ a₂ b, f a₁ (f a₂ b) = f a₂ (f a₁ b)
|
2014-09-06 11:05:07 -07:00
|
|
|
end
|
2014-07-24 17:46:41 -07:00
|
|
|
|
2015-04-21 19:13:19 -07:00
|
|
|
section
|
2014-10-09 07:13:06 -07:00
|
|
|
variable {A : Type}
|
|
|
|
variable {f : A → A → A}
|
|
|
|
variable H_comm : commutative f
|
|
|
|
variable H_assoc : associative f
|
2015-04-21 19:13:19 -07:00
|
|
|
local infixl `*` := f
|
2015-04-09 10:54:28 -07:00
|
|
|
theorem left_comm : left_commutative f :=
|
2014-09-06 11:05:07 -07:00
|
|
|
take a b c, calc
|
2014-11-28 08:11:23 -05:00
|
|
|
a*(b*c) = (a*b)*c : H_assoc
|
|
|
|
... = (b*a)*c : H_comm
|
2014-09-06 11:05:07 -07:00
|
|
|
... = b*(a*c) : H_assoc
|
2014-07-24 17:46:41 -07:00
|
|
|
|
2015-04-09 10:54:28 -07:00
|
|
|
theorem right_comm : right_commutative f :=
|
2014-09-06 11:05:07 -07:00
|
|
|
take a b c, calc
|
|
|
|
(a*b)*c = a*(b*c) : H_assoc
|
2014-11-28 08:11:23 -05:00
|
|
|
... = a*(c*b) : H_comm
|
|
|
|
... = (a*c)*b : H_assoc
|
2014-09-06 11:05:07 -07:00
|
|
|
end
|
2014-10-08 21:45:44 -04:00
|
|
|
|
2015-04-21 19:13:19 -07:00
|
|
|
section
|
2014-10-09 07:13:06 -07:00
|
|
|
variable {A : Type}
|
|
|
|
variable {f : A → A → A}
|
|
|
|
variable H_assoc : associative f
|
2015-04-21 19:13:19 -07:00
|
|
|
local infixl `*` := f
|
2014-10-08 21:45:44 -04:00
|
|
|
theorem assoc4helper (a b c d) : (a*b)*(c*d) = a*((b*c)*d) :=
|
|
|
|
calc
|
|
|
|
(a*b)*(c*d) = a*(b*(c*d)) : H_assoc
|
2014-11-28 08:11:23 -05:00
|
|
|
... = a*((b*c)*d) : H_assoc
|
2014-10-08 21:45:44 -04:00
|
|
|
end
|
|
|
|
|
2015-04-09 11:00:59 -07:00
|
|
|
definition right_commutative_compose_right [reducible]
|
|
|
|
{A B : Type} (f : A → A → A) (g : B → A) (rcomm : right_commutative f) : right_commutative (compose_right f g) :=
|
|
|
|
λ a b₁ b₂, !rcomm
|
|
|
|
|
|
|
|
definition left_commutative_compose_left [reducible]
|
|
|
|
{A B : Type} (f : A → A → A) (g : B → A) (lcomm : left_commutative f) : left_commutative (compose_left f g) :=
|
|
|
|
λ a b₁ b₂, !lcomm
|
2014-08-07 16:59:08 -07:00
|
|
|
end binary
|