module Cat.Diagram.Monad.Limits {o ℓ} {C : Precategory o ℓ} {M : Monad C} where

Limits in categories of algebras🔗

Suppose that be a category, be a monad on and be a diagram of (that is, a functor into the Eilenberg-Moore category of M). Suppose that an evil wizard has given you a limit for the diagram in which underlies but they have not (being evil and all) told you whether admits an algebra structure at all.

Perhaps we can make this situation slightly more concrete, by working in a category equivalent to an Eilenberg-Moore category: If we have two groups considered as a discrete diagram, then the limit our evil wizard would give us is the product in But we already know we can equip this product with a “pointwise” group structure! Does this result generalise?

The answer is positive, though this is one of those cases where abstract nonsense can not help us: gotta roll up our sleeves and calculate away. Suppose we have a diagram as in the setup — we’ll show that the functor both preserves and reflects limits, in that is a limiting cone if, and only if, is.

That preserves limits follows immediately from the fact that it is a right adjoint: the non-trivial part is showing that it reflects them.

  Forget-EM-preserves-limits : preserves-limit Forget-EM F
  Forget-EM-preserves-limits = right-adjoint-is-continuous Free-EM⊣Forget-EM

We begin with the following key lemma: Write for the limit of a diagram If carries an structure and the limit projections are morphisms, then is the limit of in

  make-algebra-limit
    :  {K : Functor ⊤Cat C} {eps : K F∘ !F => Forget-EM F∘ F}
     (lim : is-ran !F (Forget-EM F∘ F) K eps)
     (nu : Algebra-on C M (K .F₀ tt))
     (∀ j  is-limit.ψ lim j C.∘ nu .ν ≡ FAlg.ν j C.∘ M.M₁ (is-limit.ψ lim j))
     make-is-limit F (K .F₀ tt , nu)
  make-algebra-limit lim apex-alg comm = em-lim where
    module lim = is-limit lim
    open make-is-limit
    module apex = Algebra-on apex-alg
    open _=>_

The assumptions to this lemma are actually rather hefty: they pretty much directly say that was already the limit of However, with this more “elementary” rephrasing, we gain a bit of extra control which will be necessary for constructing limits in out of limits in later.

    em-lim : make-is-limit F _
    em-lim .ψ j .hom = lim.ψ j
    em-lim .ψ j .preserves = comm j
    em-lim .commutes f    = ext (lim.commutes f)
    em-lim .universal eps p .hom =
      lim.universal  j  eps j .hom)  f i  p f i .hom)
    em-lim .factors eps p =
      ext (lim.factors _ _)
    em-lim .unique eps p other q =
      ext (lim.unique _ _ _ λ j i  q j i .hom)
    em-lim .universal eps p .preserves = lim.unique₂ _
       f  C.pulll (F.F₁ f .preserves)
           ∙ C.pullr (sym (M.M-∘ _ _) ∙ ap M.M₁ (ap hom (p f))))
       j  C.pulll (lim.factors _ _)
           ∙ eps j .preserves)
       j  C.pulll (comm j)
           ∙ C.pullr (sym (M.M-∘ _ _) ∙ ap M.M₁ (lim.factors _ _)))

This key lemma also doubles as a proof that the underlying object functor reflects limits: We already had an algebra structure “upstairs”!

  Forget-reflects-limits : reflects-limit Forget-EM F
  Forget-reflects-limits {K} {eps} lim = to-is-limitp
    (make-algebra-limit lim (K .F₀ tt .snd)  j  eps .η j .preserves))
    trivial!

Having shown that reflects the property of being a limit, we now turn to showing it reflects limits in general. Using our key lemma, it will suffice to construct an algebra structure on then show that the projection maps extend to algebra homomorphisms.

  Forget-lift-limit : Limit (Forget-EM F∘ F)  Limit F
  Forget-lift-limit lim-over = to-limit $ to-is-limit $ make-algebra-limit
    (Limit.has-limit lim-over) apex-algebra  j  lim-over.factors _ _)
    where
    module lim-over = Limit lim-over
    module lim = Ran lim-over

An algebra structure consists, centrally, of a map a map into the limit. Maps into limits are the happy case, since is essentially defined by a (natural) isomorphism between the sets and the latter limit being computed in We understand limits of sets very well: they’re (subsets of) sets of tuples!

Our algebra map is thus defined componentwise: Since we have a bunch of maps coming from the algebra structures on each we can “tuple” them into a big map Abusing notation slightly, we’re defining to be

    apex-algebra : Algebra-on C M lim-over.apex
    apex-algebra .ν =
      lim-over.universal  j  FAlg.ν j C.∘ M.M₁ (lim-over.ψ j)) comm where abstract
      comm :  {x y} (f : J.Hom x y)
             F.₁ f .hom C.∘ FAlg.ν x C.∘ M.M₁ (lim-over.ψ x)
            ≡ FAlg.ν y C.∘ M.M₁ (lim-over.ψ y)
      comm {x} {y} f =
        F.₁ f .hom C.∘ FAlg.ν x C.∘ M.M₁ (lim-over.ψ x)        ≡⟨ C.extendl (F.₁ f .preserves)
        FAlg.ν y C.∘ M.M₁ (F.₁ f .hom) C.∘ M.M₁ (lim-over.ψ x) ≡˘⟨ C.refl⟩∘⟨ M.M-∘ _ _
        FAlg.ν y C.∘ M.M₁ (F.₁ f .hom C.∘ lim-over.ψ x)        ≡⟨ C.refl⟩∘⟨ ap M.M₁ (lim-over.commutes f)
        FAlg.ν y C.∘ M.M₁ (lim-over.ψ y)

To show that really is an algebra structure, we’ll reason componentwise, too: we must show that is the identity map: but we can compute

The other condition, compatibility with multiplication, is analogous. Formally, the computation is a bit less pretty, but it’s no more complicated.
    apex-algebra .ν-unit = lim-over.unique₂ _ lim-over.commutes
       j  C.pulll (lim-over.factors _ _)
          ·· C.pullr (sym $ M.unit.is-natural _ _ _)
          ·· C.cancell (FAlg.ν-unit j))
       j  C.idr _)
    apex-algebra .ν-mult = lim-over.unique₂ _
       f  C.pulll $ C.pulll (F.₁ f .preserves)
           ∙ C.pullr (sym (M.M-∘ _ _) ∙ ap M.M₁ (lim-over.commutes f)))
       j  C.pulll (lim-over.factors _ _)
          ·· C.pullr (sym (M.M-∘ _ _) ∙ ap M.M₁ (lim-over.factors _ _) ∙ M.M-∘ _ _)
          ·· C.extendl (FAlg.ν-mult j)
          ·· ap (FAlg.ν j C._) (M.mult.is-natural _ _ _)
          ·· C.assoc _ _ _)
       j  C.pulll (lim-over.factors _ _))

Putting our previous results together, we conclude by observing that, if is a complete category, then so is regardless of how ill-behaved the monad might be.

Eilenberg-Moore-is-complete
  :  {a b}  is-complete a b C  is-complete a b (Eilenberg-Moore M)
Eilenberg-Moore-is-complete complete F =
  Forget-lift-limit F (complete _)