open import 1Lab.Prelude

open import Algebra.Group.Cat.Base
open import Algebra.Group

open import Data.Fin
module Algebra.Group.Instances.Symmetric where

Symmetric groups🔗

If is a set, then the type of all bijections is also a set, and it forms the carrier for a group: The symmetric group on

Sym :  {} (X : Set)  Group-on (∣ X ∣ ≃ ∣ X ∣)
Sym X = to-group-on group-str where
  open make-group
  group-str : make-group (∣ X ∣ ≃ ∣ X ∣)
  group-str .mul g f = f ∙e g

The group operation is composition of equivalences; The identity element is the identity equivalence.

  group-str .unit = id , id-equiv

This type is a set because is a set (because is a set by assumption), and being an equivalence is a proposition.

  group-str .group-is-set = hlevel 2

The associativity and identity laws hold definitionally.

  group-str .assoc _ _ _ = trivial!
  group-str .idl _ = trivial!

The inverse is given by the inverse equivalence, and the inverse equations hold by the fact that the inverse of an equivalence is both a section and a retraction.

  group-str .inv = _e⁻¹
  group-str .invl (f , eqv) = ext (equiv→unit eqv)

We write for the symmetric group on the standard finite set with elements.

S : Nat  Group lzero
S n = el! (Fin n ≃ Fin n) , Sym (el! (Fin n))