The equivalence between Monad C
and Mon_ (C ⥤ C)
. #
A monad "is just" a monoid in the category of endofunctors.
Definitions/Theorems #
toMon
associates a monoid object inC ⥤ C
to any monad onC
.monadToMon
is the functorial version oftoMon
.ofMon
associates a monad onC
to any monoid object inC ⥤ C
.monadMonEquiv
is the equivalence betweenMonad C
andMon_ (C ⥤ C)
.
@[simp]
theorem
CategoryTheory.Monad.toMon_mul
{C : Type u}
[Category.{v, u} C]
(M : Monad C)
:
M.toMon.mul = M.μ
@[simp]
theorem
CategoryTheory.Monad.toMon_one
{C : Type u}
[Category.{v, u} C]
(M : Monad C)
:
M.toMon.one = M.η
@[simp]
theorem
CategoryTheory.Monad.toMon_X
{C : Type u}
[Category.{v, u} C]
(M : Monad C)
:
M.toMon.X = M.toFunctor
Passing from Monad C
to Mon_ (C ⥤ C)
is functorial.
Equations
- One or more equations did not get rendered due to their size.
Instances For
@[simp]
theorem
CategoryTheory.Monad.monadToMon_map_hom
(C : Type u)
[Category.{v, u} C]
{X✝ Y✝ : Monad C}
(f : X✝ ⟶ Y✝)
:
((monadToMon C).map f).hom = f.toNatTrans
@[simp]
theorem
CategoryTheory.Monad.monadToMon_obj
(C : Type u)
[Category.{v, u} C]
(M : Monad C)
:
(monadToMon C).obj M = M.toMon
To every monoid object in C ⥤ C
we associate a Monad C
.
Equations
- CategoryTheory.Monad.ofMon M = { toFunctor := M.X, η := M.one, μ := M.mul, assoc := ⋯, left_unit := ⋯, right_unit := ⋯ }
Instances For
@[simp]
@[simp]
@[simp]
theorem
CategoryTheory.Monad.ofMon_obj
{C : Type u}
[Category.{v, u} C]
(M : Mon_ (Functor C C))
(X : C)
:
Passing from Mon_ (C ⥤ C)
to Monad C
is functorial.
Equations
- One or more equations did not get rendered due to their size.
Instances For
@[simp]
theorem
CategoryTheory.Monad.monToMonad_obj
(C : Type u)
[Category.{v, u} C]
(M : Mon_ (Functor C C))
:
(monToMonad C).obj M = ofMon M
@[simp]
theorem
CategoryTheory.Monad.monToMonad_map_toNatTrans
(C : Type u)
[Category.{v, u} C]
{X Y : Mon_ (Functor C C)}
(f : X ⟶ Y)
:
((monToMonad C).map f).toNatTrans = f.hom
Oh, monads are just monoids in the category of endofunctors (equivalence of categories).
Equations
- One or more equations did not get rendered due to their size.
Instances For
@[simp]
theorem
CategoryTheory.Monad.monadMonEquiv_unitIso_hom_app_toNatTrans_app
(C : Type u)
[Category.{v, u} C]
(x✝ : Monad C)
(x✝¹ : C)
:
((monadMonEquiv C).unitIso.hom.app x✝).app x✝¹ = CategoryStruct.id (((Functor.id (Monad C)).obj x✝).obj x✝¹)
@[simp]
theorem
CategoryTheory.Monad.monadMonEquiv_unitIso_inv_app_toNatTrans_app
(C : Type u)
[Category.{v, u} C]
(x✝ : Monad C)
(x✝¹ : C)
:
((monadMonEquiv C).unitIso.inv.app x✝).app x✝¹ = CategoryStruct.id ((((monadToMon C).comp (monToMonad C)).obj x✝).obj x✝¹)
@[simp]
theorem
CategoryTheory.Monad.monadMonEquiv_counitIso_inv_app_hom
(C : Type u)
[Category.{v, u} C]
(x✝ : Mon_ (Functor C C))
:
((monadMonEquiv C).counitIso.inv.app x✝).hom = CategoryStruct.id ((Functor.id (Mon_ (Functor C C))).obj x✝).X
@[simp]
theorem
CategoryTheory.Monad.monadMonEquiv_counitIso_hom_app_hom
(C : Type u)
[Category.{v, u} C]
(x✝ : Mon_ (Functor C C))
:
((monadMonEquiv C).counitIso.hom.app x✝).hom = CategoryStruct.id (((monToMonad C).comp (monadToMon C)).obj x✝).X
@[simp]
theorem
CategoryTheory.Monad.monadMonEquiv_inverse
(C : Type u)
[Category.{v, u} C]
:
(monadMonEquiv C).inverse = monToMonad C
@[simp]
theorem
CategoryTheory.Monad.monadMonEquiv_functor
(C : Type u)
[Category.{v, u} C]
:
(monadMonEquiv C).functor = monadToMon C