Free groups #
This file defines free groups over a type. Furthermore, it is shown that the free group construction
is an instance of a monad. For the result that FreeGroup is the left adjoint to the forgetful
functor from groups to types, see Mathlib/Algebra/Category/GrpCat/Adjunctions.lean.
Main definitions #
- FreeGroup/- FreeAddGroup: the free group (resp. free additive group) associated to a type- αdefined as the words over- a : α × Boolmodulo the relation- a * x * x⁻¹ * b = a * b.
- FreeGroup.mk/- FreeAddGroup.mk: the canonical quotient map- List (α × Bool) → FreeGroup α.
- FreeGroup.of/- FreeAddGroup.of: the canonical injection- α → FreeGroup α.
- FreeGroup.lift f/- FreeAddGroup.lift: the canonical group homomorphism- FreeGroup α →* Ggiven a group- Gand a function- f : α → G.
Main statements #
- FreeGroup.Red.church_rosser/- FreeAddGroup.Red.church_rosser: The Church-Rosser theorem for word reduction (also known as Newman's diamond lemma).
- FreeGroup.freeGroupUnitEquivInt: The free group over the one-point type is isomorphic to the integers.
- The free group construction is an instance of a monad.
Implementation details #
First we introduce the one step reduction relation FreeGroup.Red.Step:
w * x * x⁻¹ * v   ~>   w * v, its reflexive transitive closure FreeGroup.Red.trans
and prove that its join is an equivalence relation. Then we introduce FreeGroup α as a quotient
over FreeGroup.Red.Step.
For the additive version we introduce the same relation under a different name so that we can distinguish the quotient types more easily.
Tags #
free group, Newman's diamond lemma, Church-Rosser theorem
Reflexive-transitive closure of Red.Step
Instances For
Reflexive-transitive closure of Red.Step
Instances For
Church-Rosser theorem for word reduction: If w1 w2 w3 are words such that w1 reduces
to w2 and w3 respectively, then there is a word w4 such that w2 and w3 reduce to w4
respectively. This is also known as Newman's diamond lemma.
Church-Rosser theorem for word reduction: If w1 w2 w3 are words such that w1 reduces
to w2 and w3 respectively, then there is a word w4 such that w2 and w3 reduce to w4
respectively. This is also known as Newman's diamond lemma.
If x and y are distinct letters and w₁ w₂ are words such that xw₁ reduces to yw₂, then
w₁ reduces to x⁻¹yw₂.
If x and y are distinct letters and w₁ w₂ are words such that x + w₁
reduces to y + w₂, then w₁ reduces to -x + y + w₂.
Reduced words #
Predicate asserting that the word L admits no reduction steps, i.e., no two neighboring
elements of the word cancel.
Equations
- FreeGroup.IsReduced L = List.IsChain (fun (a b : α × Bool) => a.1 = b.1 → a.2 = b.2) L
Instances For
Predicate asserting the word L admits no reduction steps,
i.e., no two neighboring elements of the word cancel.
Equations
- FreeAddGroup.IsReduced L = List.IsChain (fun (a b : α × Bool) => a.1 = b.1 → a.2 = b.2) L
Instances For
If α is a type, then FreeGroup α is the free group generated by α.
This is a group equipped with a function FreeGroup.of : α → FreeGroup α which has
the following universal property: if G is any group, and f : α → G is any function,
then this function is the composite of FreeGroup.of and a unique group homomorphism
FreeGroup.lift f : FreeGroup α →* G.
A typical element of FreeGroup α is a formal product of
elements of α and their formal inverses, quotient by reduction.
For example if x and y are terms of type α then x⁻¹ * y * y * x * y⁻¹ is a
"typical" element of FreeGroup α. In particular if α is empty
then FreeGroup α is isomorphic to the trivial group, and if α has one term
then FreeGroup α is isomorphic to Multiplicative ℤ.
If α has two or more terms then FreeGroup α is not commutative.
Equations
Instances For
If α is a type, then FreeAddGroup α is the free additive group generated by α.
This is a group equipped with a function FreeAddGroup.of : α → FreeAddGroup α which has
the following universal property: if G is any group, and f : α → G is any function,
then this function is the composite of FreeAddGroup.of and a unique group homomorphism
FreeAddGroup.lift f : FreeAddGroup α →+ G.
A typical element of FreeAddGroup α is a formal sum of
elements of α and their formal inverses, quotient by reduction.
For example if x and y are terms of type α then -x + y + y + x + -y is a
"typical" element of FreeAddGroup α. In particular if α is empty
then FreeAddGroup α is isomorphic to the trivial group, and if α has one term
then FreeAddGroup α is isomorphic to ℤ.
If α has two or more terms then FreeAddGroup α is not commutative.
Equations
Instances For
Equations
- FreeGroup.instOne = { one := FreeGroup.mk [] }
Equations
- FreeAddGroup.instZero = { zero := FreeAddGroup.mk [] }
Equations
- FreeGroup.instInhabited = { default := 1 }
Equations
- FreeAddGroup.instInhabited = { default := 0 }
Equations
Equations
Equations
- FreeGroup.instMul = { mul := fun (x y : FreeGroup α) => Quot.liftOn x (fun (L₁ : List (α × Bool)) => Quot.liftOn y (fun (L₂ : List (α × Bool)) => FreeGroup.mk (L₁ ++ L₂)) ⋯) ⋯ }
Equations
- One or more equations did not get rendered due to their size.
Equations
- FreeGroup.instInv = { inv := Quot.map FreeGroup.invRev ⋯ }
Equations
- FreeAddGroup.instNeg = { neg := Quot.map FreeAddGroup.negRev ⋯ }
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
of is the canonical injection from the type to the free group over that type by sending each
element to the equivalence class of the letter that is the element.
Equations
Instances For
of is the canonical injection from the type to the free group over that type
by sending each element to the equivalence class of the letter that is the element.
Equations
Instances For
The canonical map from the type to the free group is an injection.
The canonical map from the type to the additive free group is an injection.
Given f : α → β with β an additive group, the canonical map
List (α × Bool) → β
Equations
Instances For
If β is a group, then any function from α to β extends uniquely to a group homomorphism
from the free group over α to β
Equations
- FreeGroup.lift = { toFun := fun (f : α → β) => MonoidHom.mk' (Quot.lift (FreeGroup.Lift.aux f) ⋯) ⋯, invFun := fun (g : FreeGroup α →* β) => ⇑g ∘ FreeGroup.of, left_inv := ⋯, right_inv := ⋯ }
Instances For
If β is an additive group, then any function from α to β extends uniquely to an
additive group homomorphism from the free additive group over α to β
Equations
- One or more equations did not get rendered due to their size.
Instances For
Any function from α to β extends uniquely to a group homomorphism from the free group over
α to the free group over β.
Equations
- FreeGroup.map f = MonoidHom.mk' (Quot.map (List.map fun (x : α × Bool) => (f x.1, x.2)) ⋯) ⋯
Instances For
Any function from α to β extends uniquely to an additive group homomorphism
from the additive free group over α to the additive free group over β.
Equations
- FreeAddGroup.map f = AddMonoidHom.mk' (Quot.map (List.map fun (x : α × Bool) => (f x.1, x.2)) ⋯) ⋯
Instances For
Equivalent types give rise to multiplicatively equivalent free groups.
The converse can be found in Mathlib/GroupTheory/FreeGroup/GeneratorEquiv.lean, as
Equiv.ofFreeGroupEquiv.
Equations
- FreeGroup.freeGroupCongr e = { toFun := ⇑(FreeGroup.map ⇑e), invFun := ⇑(FreeGroup.map ⇑e.symm), left_inv := ⋯, right_inv := ⋯, map_mul' := ⋯ }
Instances For
Equivalent types give rise to additively equivalent additive free groups.
Equations
- FreeAddGroup.freeAddGroupCongr e = { toFun := ⇑(FreeAddGroup.map ⇑e), invFun := ⇑(FreeAddGroup.map ⇑e.symm), left_inv := ⋯, right_inv := ⋯, map_add' := ⋯ }
Instances For
If α is a group, then any function from α to α extends uniquely to a homomorphism from the
free group over α to α. This is the multiplicative version of FreeGroup.sum.
Equations
Instances For
If α is an additive group, then any function from α to α extends uniquely
to an additive homomorphism from the additive free group over α to α.
Equations
Instances For
If α is a group, then any function from α to α extends uniquely to a homomorphism from the
free group over α to α. This is the additive version of Prod.
Equations
- x.sum = FreeGroup.prod x
Instances For
The bijection between the additive free group on the empty type, and a type with one element.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.