Strong monads, the topic of this post, are a somewhat technical looking topic at first glance, requiring more definitions and machinery than we have seen up until now. Unfortunately, they are key to some more interesting topics, both mathematically and in terms of computer science application. As usual when dealing with new abstract ideas, it is useful to focus on intuitions and examples to get a feeling for the formal definitions. This post is longer than might be ideal, but there are plenty of examples.

For those interested in the technical details I skip, some recommended reading:

**Monoidal categories**: “Categories for the Working Mathematician” by Mac Lane has a very readable account of monoidal categories, despite its reputation for requiring a lot of mathematical background.**Enriched categories**: Both volume 2 of Borceux’s “Handbook of Categorical Algebra”, and Riehl’s “Categorical Homotopy Theory” have brief introductions to monoidal categories, to set up a concise introduction to enriched category theory. The standard reference for enriched category theory is Kelly’s “Basic Concepts of Enriched Category Theory”, which also contains the necessary background on monoidal categories. This book can be difficult in places, but the material we require is covered at a reasonable pace.

## Monoidal Categories

A monoidal category is a category with a **monoidal product** bifunctor, typically denoted , and a **unit** object, . Intuitively, this is a generalization of the notion of monoid from sets to categories. There are isomorphisms

,

natural in , and referred to as the **left and right unitor** respectively. These encode that acts as a unit for the multiplication, up to isomorphism. There are also **associator** isomorphisms:

,

natural in , encoding associativity up to isomorphism. The unitors and associator are required to satisfy some compatibility equations (referred to as coherence conditions). We won’t need the details, but they can be found in any standard category theory reference.

A **symmetric monoidal category** is a monoidal category with a further **symmetry** isomorphisms encoding commutativity up to isomorphism:

natural in . Again, the symmetry is required to satisfy some coherence conditions (equations) with respect to the other structure. Finally, a (symmetric) **monoidal closed category** is a (symmetric) monoidal category such that for each object , there is an adjunction:

**Example**: Any category with products is a symmetric monoidal category, with

The left and right unitors, associator and symmetry are the “obvious” canonical maps induced by the universal property of products. If is Cartesian closed, then it is symmetric monoidal closed, with given by the exponential .

In particular, the category is symmetric monoidal closed with monoidal product given by Cartesian products, and given by the function space functor . This is the motivating example for much of what follows, and of practical interest in algebraic examples we shall see later. When working with , if not otherwise stated the monoidal structure is taken to be the Cartesian product structure.

## Strength

For a monoidal category , and endofunctor , a **strength** (sometimes referred to as a **tensorial strength**) for is a natural transformation

which satisfies two coherence conditions with respect to the monoidal structure. A **strong functor** is a functor with a chosen strength. A strong monad is monad with a strong underlying endofunctor, satisfying additional coherence conditions with respect to the monad unit and multiplication. Again, the actual coherence conditions can be found in standard sources, we shall focus on examples and intuitions.

**Example**: The list and powerset monads are both strong in a unique way, with strengths:

We shall shortly see that form (and uniqueness) of the strengths for the monads in the previous example are in no way special.

So a crude first sketch of a strength is that it is a well-behaved way of commuting an endofunctor and a monoidal product. You may notice that there are other ways you might imagine commuting an endofunctor with a monoidal product. We shall return to that thought in later posts.

To get a more principled mathematical perspective on strength, unfortunately we need to introduce further abstract machinery.

## Enriched Categories

Enriched category theory is a large and potentially complex topic. Fortunately we will only need a few of the basic definitions, and no deep theory. The idea of an enriched category is that often for a category , the homsets carry additional mathematical structure, and this structure interacts well with composition. For example:

**Example**: The homsets in the category of preorders and monotone maps actually carry a natural pointwise order:

.

This structure satisfies:

when the composites are well-defined. So the homsets are actually -objects, and the composition maps are -morphisms

A close relative of the previous example is the following:

**Example**: The homsets of the category of all (small) categories are themselves categories, with morphisms the natural transformations. Furthermore, the composition maps are bifunctors

An important trivial example is the following:

**Example**: The homsets of the category are -objects, and the composition maps are -morphisms

Finally, a slightly different example, which motivates the level of generalization of the formal definition.

**Example**: The homsets of the category of Abelian groups can be given the structure of Abelian groups pointwise. With this structure, the composition maps satisfy:

and the dual conditions for precomposition. This is *not* the same as saying the composition maps are morphisms:

This temporarily breaks the pattern with the previous examples. However, there is a monoidal structure on such that the composition maps are -morphisms

In fact this monoidal structure arises via some rather beautiful monad theory, which we will hopefully get to in later posts.

The final example motivates defining enriched categories so that the hom objects can live in monoidal categories.

For a monoidal category , a **-enriched category** has:

- A collection of objects
- For each pair of objects , a
**hom object**in . - For each object , a morphism . Intuitively, these encode the the identities in the category.
- For each triple of objects , a morphism . These encode composition of morphisms with the enriched category.

This data must satisfy some axioms, ensuring that composition is associative and has units the identities. In fact, some mathematical structures that are far away from our motivating examples are also enriched categories. The original surprising example was that a mild generalization of metric spaces can be seen as enriched categories, as shown by Lawvere.

**Example**: For any monoidal closed category , we can regard as a -category, with hom objects

The identity and composition maps are derived in a reasonably routine way, and can be found in standard sources. This is usually described as being **canonically enriched over itself**.

To connect the worlds of ordinary and enriched categories, note that any -category , has an **underlying ordinary category** , with the same objects, and homsets:

Composition and identities in are defined in a natural way. Strictly speaking, to give an enrichment for an ordinary category is to give a -category , and a specified isomorphism . Generally, this isomorphism is ignored when there is a natural choice.

Once we’ve defined a new class of objects, we should consider the morphisms between them. A **-functor** consists of:

- A mapping from -objects to -objects.
- For each pair of -objects, a -morphism . Intuitively, these describe the action on morphisms of the functor.

The morphism are required to satisfy axioms generalizing the usual idea that identities and composition are preserved.

**Example**: For the constructions we have seen previous:

- A -enriched functor is a functor which is monotone, in that .
- A -enriched functor is a (strict) 2-functor.
- A -functor is an ordinary functor.
- A -functor is a functor such that and .

Again, it is helpful to connect back to the world of ordinary category theory. A -functor induces an ordinary functor that agrees with on objects. Morphisms in are -morphisms . Then is given by:

.

A -functor is said to an **enrichment of ordinary functor** if .

Finally, a **-natural** transformation is a family of -morphisms satisfying an axiom generalizing the usual notion of naturality to the enriched setting.

## Strength and Enrichment

Finally, we are in a position to relate strength and enrichment. If is a monoidal *closed* category, and an ordinary endofunctor, giving a strength for is “the same thing as” giving a structure for as a -functor.

Lets unpack this a bit. As described above, we view as being canonically enriched over itself. Giving an enriched structure, sometimes referred to as a **functorial strength**, for is to give a *natural* family of morphisms:

compatible with the identity and composition maps. That these maps are natural in the sense of ordinary category is equivalent to being an enrichment of the ordinary functor is an important point that is often skimmed over.

To build such a family given a strength

we form the composite:

where is the counit of the adjunction, which can be seen as an evaluation morphism for function spaces. Taking the transpose of this morphism gives a map:

It takes some checking, but these form the components of an enrichment for as required. In the other direction, given an enrichment, we can form the composite:

where is the unit of the adjunction. Taking the transpose of this morphism gives a map:

Again, after a bit of checking, it can be seen that this results in a strength for . The passages in the two directions are mutually inverse, so **for monoidal closed category to give a strength for is equivalent to giving an enrichment for **. This dealt with the endofunctor component, but we are really interested in monads. Here, **to give a strength for a monad on monoidal closed is equivalent to giving an enrichment for **.

**Example**: As a special case of this result, as every monad is (trivially) enriched over in a unique way. Therefore, given the observations above, every monad has a unique strength. This has a concrete description as:

This formula can seem slightly magical if given without context, but it is arrived at by unravelling the strength derived from the unique enrichment. Here we use notion to define a simple function. The strengths given for the list and powerset monads in the earlier example arise via this construction.

As usual, it is useful to think about algebra examples. For a monad given by some equational presentation , the unique strength is given on representatives by:

where is the set of variables appearing in the representative term . As usual, square brackets are somewhat overloaded, denoting both equivalence classes and the substitution operation. In words – we replace each variable appearing in the representative term with the variable .

## One thought on “Strong Monads”