Propositional typeclasses on several monoid homs #
This file contains typeclasses used in the definition of equivariant maps, in the spirit what was initially developed by Frédéric Dupuis and Heather Macbeth for linear maps. However, we do not expect that all maps should be guessed automatically, as it happens for linear maps.
If φ, ψ… are monoid homs and M, N… are monoids, we add two instances:
- MonoidHom.CompTriple φ ψ χ, which expresses that- ψ.comp φ = χ
- MonoidHom.IsId φ, which expresses that- φ = id
Some basic lemmas are proved:
- MonoidHom.CompTriple.compasserts- MonoidHom.CompTriple φ ψ (ψ.comp φ)
- MonoidHom.CompTriple.id_compasserts- MonoidHom.CompTriple φ ψ ψin the presence of- MonoidHom.IsId φ
- its variant MonoidHom.CompTriple.comp_id
TODO :
- align with RingHomCompTriple
- probably rename MonoidHom.CompTriple as MonoidHomCompTriple (or, on the opposite, rename RingHomCompTriple as RingHom.CompTriple)
- does one need AddHom.CompTriple ?
instance
MonoidHom.CompTriple.instIsIdOfIsIdCoe
{M : Type u_1}
[Monoid M]
{σ : M →* M}
[h : _root_.CompTriple.IsId ⇑σ]
 :
IsId σ
instance
MonoidHom.CompTriple.instComp_id
{N : Type u_4}
{P : Type u_5}
[Monoid N]
[Monoid P]
{φ : N →* N}
[IsId φ]
{ψ : N →* P}
 :
φ.CompTriple ψ ψ
instance
MonoidHom.CompTriple.instId_comp
{M : Type u_4}
{N : Type u_5}
[Monoid M]
[Monoid N]
{φ : M →* N}
{ψ : N →* N}
[IsId ψ]
 :
φ.CompTriple ψ φ
theorem
MonoidHom.CompTriple.comp_inv
{M : Type u_1}
{N : Type u_2}
[Monoid M]
[Monoid N]
{φ : M →* N}
{ψ : N →* M}
(h : Function.RightInverse ⇑φ ⇑ψ)
{χ : M →* M}
[IsId χ]
 :
φ.CompTriple ψ χ
instance
MonoidHom.CompTriple.instRootCompTriple
{M : Type u_1}
{N : Type u_2}
{P : Type u_3}
[Monoid M]
[Monoid N]
[Monoid P]
{φ : M →* N}
{ψ : N →* P}
{χ : M →* P}
[κ : φ.CompTriple ψ χ]
 :
_root_.CompTriple ⇑φ ⇑ψ ⇑χ
theorem
MonoidHom.CompTriple.comp
{M : Type u_1}
{N : Type u_2}
{P : Type u_3}
[Monoid M]
[Monoid N]
[Monoid P]
{φ : M →* N}
{ψ : N →* P}
 :
φ.CompTriple ψ (ψ.comp φ)
φ, ψ and ψ.comp φ form a MonoidHom.CompTriple
(to be used with care, because no simplification is done)