open import Cat.Functor.Naturality
open import Cat.Monoidal.Diagonals
open import Cat.Instances.Product
open import Cat.Monoidal.Braided
open import Cat.Monoidal.Base
open import Cat.Prelude

import Cat.Functor.Reasoning
import Cat.Reasoning
module Cat.Monoidal.Functor {oc β„“c od β„“d}
  {C : Precategory oc β„“c} (Cᡐ : Monoidal-category C)
  {D : Precategory od β„“d} (Dᡐ : Monoidal-category D)
  where

Monoidal functorsπŸ”—

open Cat.Reasoning D

private
  module C = Monoidal-category Cᡐ
  module D = Monoidal-category Dᡐ

Categorifying the fact that a morphism between monoids is expected to preserve the unit and multiplication, a functor between monoidal categories should come equipped with natural isomorphisms

witnessing that it preserves the tensor product and unit.

However, just like for lax functors between bicategories, we have the option of requiring only a natural transformation in one direction or the other. If we choose the forward direction we obtain the notion of a lax monoidal functor; choosing the opposite direction instead would yield an oplax monoidal functor.

We begin by defining the structure of a lax monoidal functor on a given functor this consists of the aforementioned morphisms, as well as some coherence conditions similar to the ones for a lax functor.

record Lax-monoidal-functor-on (F : Functor C D) : Type (oc βŠ” β„“c βŠ” od βŠ” β„“d) where
  private module F = Cat.Functor.Reasoning F

  field
    Ξ΅ : Hom D.Unit (F.β‚€ C.Unit)
    F-mult : D.-βŠ—- F∘ (F FΓ— F) => F F∘ C.-βŠ—-

  module Ο† = _=>_ F-mult

  Ο† : βˆ€ {A B} β†’ Hom (F.β‚€ A D.βŠ— F.β‚€ B) (F.β‚€ (A C.βŠ— B))
  Ο† = Ο†.Ξ· _

  field
    F-Ξ±β†’ : βˆ€ {A B C}
      β†’ F.₁ (C.Ξ±β†’ A B C) ∘ Ο† ∘ (Ο† D.βŠ—β‚ id) ≑ Ο† ∘ (id D.βŠ—β‚ Ο†) ∘ D.Ξ±β†’ _ _ _
    F-λ← : βˆ€ {A} β†’ F.₁ (C.λ← {A}) ∘ Ο† ∘ (Ξ΅ D.βŠ—β‚ id) ≑ D.λ←
    F-ρ← : βˆ€ {A} β†’ F.₁ (C.ρ← {A}) ∘ Ο† ∘ (id D.βŠ—β‚ Ξ΅) ≑ D.ρ←
  F-α← : βˆ€ {A B C}
    β†’ F.₁ (C.α← A B C) ∘ Ο† ∘ (id D.βŠ—β‚ Ο†) ≑ Ο† ∘ (Ο† D.βŠ—β‚ id) ∘ D.α← _ _ _
  F-α← = swizzle (sym (F-Ξ±β†’ βˆ™ assoc _ _ _)) (D.Ξ±β‰… .invl) (F.F-map-iso C.Ξ±β‰… .invr)
    βˆ™ sym (assoc _ _ _)

private unquoteDecl eqv = declare-record-iso eqv (quote Lax-monoidal-functor-on)
Lax-monoidal-functor-on-path
  : βˆ€ {F} {l l' : Lax-monoidal-functor-on F}
  β†’ l .Lax-monoidal-functor-on.Ξ΅ ≑ l' .Lax-monoidal-functor-on.Ξ΅
  β†’ l .Lax-monoidal-functor-on.F-mult ≑ l' .Lax-monoidal-functor-on.F-mult
  β†’ l ≑ l'
Lax-monoidal-functor-on-path p q = Iso.injective eqv
  (Ξ£-pathp p (Ξ£-prop-pathp (Ξ» _ _ β†’ hlevel 1) q))
Lax-monoidal-functor : Type (oc βŠ” β„“c βŠ” od βŠ” β„“d)
Lax-monoidal-functor = Ξ£ (Functor C D) Lax-monoidal-functor-on

A monoidal functor, or strong monoidal functor1, is then simply a lax monoidal functor whose structure morphisms are invertible.

record Monoidal-functor-on (F : Functor C D) : Type (oc βŠ” β„“c βŠ” od βŠ” β„“d) where
  field
    lax : Lax-monoidal-functor-on F

  open Lax-monoidal-functor-on lax public

  field
    Ξ΅-inv : is-invertible Ξ΅
    F-mult-inv : is-invertibleⁿ F-mult

Monoidal-functor : Type (oc βŠ” β„“c βŠ” od βŠ” β„“d)
Monoidal-functor = Ξ£ (Functor C D) Monoidal-functor-on

Braided and symmetric monoidal functorsπŸ”—

A monoidal functor between braided monoidal categories can additionally preserve the braiding in the sense that the following diagram commutes, yielding the notion of a braided monoidal functor.

module _
  (Cᡇ : Braided-monoidal Cᡐ)
  (Dᡇ : Braided-monoidal Dᡐ)
  where
  module Cᡇ = Braided-monoidal Cᡇ
  module Dᡇ = Braided-monoidal Dᡇ
  is-braided-functor : Lax-monoidal-functor β†’ Type (oc βŠ” β„“d)
  is-braided-functor (F , lax) = βˆ€ {A B} β†’ Ο† ∘ Dᡇ.Ξ²β†’ ≑ F.₁ Cᡇ.Ξ²β†’ ∘ Ο† {A} {B}
    where
      module F = Functor F
      open Lax-monoidal-functor-on lax

A symmetric monoidal functor between symmetric monoidal categories is just a braided monoidal functor, since there is no extra structure to preserve.

module _
  (C˒ : Symmetric-monoidal Cᡐ)
  (D˒ : Symmetric-monoidal Dᡐ)
  where
  open Symmetric-monoidal CΛ’ using (Cᡇ)
  open Symmetric-monoidal DΛ’ using () renaming (Cᡇ to Dᡇ)
  is-symmetric-functor : Lax-monoidal-functor β†’ Type (oc βŠ” β„“d)
  is-symmetric-functor = is-braided-functor Cᡇ Dᡇ

Diagonal monoidal functorsπŸ”—

If the source and target categories are equipped with diagonal morphisms, then a diagonal monoidal functor, or idempotent monoidal functor is a monoidal functor that makes the following diagram commute:

module _
  (Cᡈ : Diagonals Cᡐ)
  (Dᡈ : Diagonals Dᡐ)
  where
  module Cᡈ = Diagonals Cᡈ
  module Dᡈ = Diagonals Dᡈ
  is-diagonal-functor : Lax-monoidal-functor β†’ Type (oc βŠ” β„“d)
  is-diagonal-functor (F , lax) = βˆ€ {A} β†’ Ο† ∘ Dᡈ.Ξ΄ ≑ F.₁ (Cᡈ.Ξ΄ {A})
    where
      module F = Functor F
      open Lax-monoidal-functor-on lax

The β€œidempotent” terminology comes from the semantics of programming languages, where lax monoidal functors are used to model certain kinds of effectful computations, as a β€œstatic” alternative to monads. In that setting, an idempotent monoidal functor (or β€œidempotent applicative functor”) represents an effect that can be executed multiple times with the same effect as executing it once: for example, reading from an immutable data source or throwing an exception.

Monoidal natural transformationsπŸ”—

The notion of natural transformation between functors can also be refined in the case of monoidal functors: a monoidal natural transformation is one such that the following diagrams commute.

module _ ((F , F-monoidal) (G , G-monoidal) : Lax-monoidal-functor) where
  module FM = Lax-monoidal-functor-on F-monoidal
  module GM = Lax-monoidal-functor-on G-monoidal
  open _=>_
  record is-monoidal-transformation (Ξ± : F => G) : Type (oc βŠ” β„“c βŠ” β„“d) where
    field
      nat-Ξ΅ : Ξ± .Ξ· C.Unit ∘ FM.Ξ΅ ≑ GM.Ξ΅
      nat-Ο† : βˆ€ {A B} β†’ Ξ± .Ξ· _ ∘ FM.Ο† {A} {B} ≑ GM.Ο† ∘ (Ξ± .Ξ· _ D.βŠ—β‚ Ξ± .Ξ· _)

Note that, since monoidal categories can be thought of as one-object bicategories, we may expect to also have modifications between monoidal natural transformations, but this is not the case: the categorical ladder ends here. This is analogous to the fact that monoids only form a category and not a bicategory, even when viewed as one-object categories: there simply aren’t enough objects to have interesting 3-cells (resp. 2-cells)!


  1. Not to be confused with a strong monoidal functor, in the sense of a monoidal functor equipped with a strength.β†©οΈŽ