Intro
Recently I started looking into the origin of computer science monad, and found out that at least some of them originate in pretty simple things. Like segments of simplicial category Δ (for a better explanation/definition, see MacLane, p.175). Here I'll give a couple of examples, Option and Reader monads, how they derive from a very simple subcategory of Δ.
0, 1, 1+1
I'm going to introduce a very simple category, consisting of three, well, sets: empty, singleton and a union of two singletons (1+1), together with two arrows,
0 → 1
and 1+1 → 1
:data:image/s3,"s3://crabby-images/0596e/0596e9ece4d13a1d63fee2ce4513db55c20fc357" alt="click to go to presheaf.com for editing"
There's not much to talk about this category; you can think of it as living in the category of all sets, but actually any category with finite limits and colimits contains it.
Now I'll show how it generates two popular monads.
Option Monad
Given an object
X
, if we add X
to each part of the diagram (a)
, we get this:data:image/s3,"s3://crabby-images/222ca/222caa0f198b8f9bd46222bf59062f08b0a6cbfe" alt="click to go to presheaf.com for editing"
which is exactly Option Monad.
Exception Monad
First, we multiply the diagram
(a)
by E
:data:image/s3,"s3://crabby-images/a13fa/a13fab560194682ef19e582ecc9570a4670fa228" alt="click to go to presheaf.com for editing"
Then we can do the same trick as in Option Monad, add an
X
:data:image/s3,"s3://crabby-images/7b42f/7b42f7d85a232f8fdfc3f224d540d42373b9f511" alt="click to go to presheaf.com for editing"
This is Exception Monad.
Reader Monad
Given an
X
, we can build the following diagram by applying X-
functor to the diagram (a)
:data:image/s3,"s3://crabby-images/b8814/b8814a6954ea5550c811332b8aade1718c70406e" alt="click to go to presheaf.com for editing"
Which is, simply speaking, just
data:image/s3,"s3://crabby-images/6857a/6857ab9a1d5fe08b79df7f6540cc02ef690fd232" alt="click to go to presheaf.com for editing"
Now this can be used to build the following diagram, for any
A
:data:image/s3,"s3://crabby-images/77412/77412e7af132ccb93fc7a58b47e25c9c9b547284" alt="click to go to presheaf.com for editing"
Do you see Reader diagram? It is the functor
data:image/s3,"s3://crabby-images/403fc/403fc90b58310ae4522106c1d474babff8c0c9be" alt="click to go to presheaf.com for editing"
This post is work in progress; comments are very welcome.
No comments:
Post a Comment