The abelianization of a group #
This file defines the commutator and the abelianization of a group. It furthermore prepares for the
result that the abelianization is left adjoint to the forgetful functor from abelian groups to
groups, which can be found in Algebra/Category/Group/Adjunctions
.
Main definitions #
commutator
: defines the commutator of a groupG
as a subgroup ofG
.Abelianization
: defines the abelianization of a groupG
as the quotient of a group by its commutator subgroup.Abelianization.map
: lifts a group homomorphism to a homomorphism between the abelianizationsMulEquiv.abelianizationCongr
: Equivalent groups have equivalent abelianizations
instance
instFGSubtypeMemSubgroupCommutatorOfFiniteElemCommutatorSet
(G : Type u)
[Group G]
[Finite ↑(commutatorSet G)]
:
Group.FG ↥(commutator G)
The abelianization of G is the quotient of G by its commutator subgroup.
Equations
- Abelianization G = (G ⧸ commutator G)
Equations
Equations
- Abelianization.instInhabited G = { default := 1 }
Equations
instance
Abelianization.instFintypeOfDecidablePredMemSubgroupCommutator
(G : Type u)
[Group G]
[Fintype G]
[DecidablePred fun (x : G) => x ∈ commutator G]
:
of
is the canonical projection from G to its abelianization.
Equations
- Abelianization.of = { toFun := QuotientGroup.mk, map_one' := ⋯, map_mul' := ⋯ }
@[simp]
theorem
Abelianization.lift.unique
{G : Type u}
[Group G]
{A : Type v}
[CommGroup A]
(f : G →* A)
(φ : Abelianization G →* A)
(hφ : ∀ (x : G), φ (Abelianization.of x) = f x)
{x : Abelianization G}
:
@[simp]
The map operation of the Abelianization
functor
Equations
@[simp]
Equivalent groups have equivalent abelianizations
Equations
- e.abelianizationCongr = { toFun := ⇑(Abelianization.map e.toMonoidHom), invFun := ⇑(Abelianization.map e.symm.toMonoidHom), left_inv := ⋯, right_inv := ⋯, map_mul' := ⋯ }
@[simp]
An Abelian group is equivalent to its own abelianization.
Equations
- Abelianization.equivOfComm = { toFun := ⇑Abelianization.of, invFun := ⇑(Abelianization.lift (MonoidHom.id H)), left_inv := ⋯, right_inv := ⋯, map_mul' := ⋯ }
@[simp]
@[simp]
Representatives (g₁, g₂) : G × G
of commutators ⁅g₁, g₂⁆ ∈ G
.
Equations
- commutatorRepresentatives G = Set.range fun (g : ↑(commutatorSet G)) => (Exists.choose ⋯, ⋯.choose)
instance
instFiniteElemProdCommutatorRepresentativesOfCommutatorSet
(G : Type u)
[Group G]
[Finite ↑(commutatorSet G)]
:
Subgroup generated by representatives g₁ g₂ : G
of commutators ⁅g₁, g₂⁆ ∈ G
.
theorem
rank_closureCommutatorRepresentatives_le
(G : Type u)
[Group G]
[Finite ↑(commutatorSet G)]
:
instance
instFiniteElemSubtypeMemSubgroupClosureCommutatorRepresentativesCommutatorSet
(G : Type u)
[Group G]
[Finite ↑(commutatorSet G)]
: