Monade (categorietheorie)
In de categorietheorie, een tak van de wiskunde, is een monade een tripel dat bestaat uit een functor T van een categorie naar zichzelf (ookwel een endofunctor genoemd) en twee natuurlijke transformaties en die voldoen aan enkele voorwaarden, waaronder bijvoorbeeld associativiteit. Als en bijvoorbeeld geadjugeerde functoren zijn, dan is samen met bepaald door de geadjungeerde relatie een monade.
Kortweg gezegd is een monade een monoïde in de categorie van endofunctoren van een vaste categorie. Volgens John Baez kan een monade op minstens twee manieren worden beschouwd:
- Een monade is in zekere zin een gegeneraliseerde monoïde, aangezien een monade voor een gegeven categorie een monoïde is.
- Een monade is een hulpmiddel om algebraïsche structuren te bestuderen. Zo kan een groep kan bijvoorbeeld beschreven worden aan de hand van een bepaalde monade.
Monaden worden gebruikt in de theorie van koppels van geadjungeerde functoren en generaliseren sluitingsoperatoren op partieel geordende verzamelingen naar willekeurige categorieën. Monaden zijn ook nuttig in de typetheorie en de beschrijving van de denotationele semantiek van imperatieve programmeertalen. In het bijzonder binnen functionele programmeertalen zijn monaden relevant: talen zonder mutable state kunnen zo bijvoorbeeld bewerkingen met bijwerkingen en for-lussen nabootsen.
Inleiding en definitie
[bewerken | brontekst bewerken]Een monade is een specifiek soort endofunctor. Als en bijvoorbeeld een koppel geadjugeerde functoren zijn met linksadjunct aan , dan is hun samenstelling een monade. Als en invers zijn aan elkaar is de corresponderende monade de identieke functor. Over het algemeen zijn adjuncties geen equivalenties, aangezien ze categorieën van verschillende 'aard' met elkaar in relatie leggen. De theorie omtrent monaden is van belang als onderdeel van de poging om vast te leggen wat adjuncties 'bewaren'. De 'andere helft' van die optiek, van wat eveneens geleerd kan worden uit de beschouwing van , wordt besproken onder de duale theorie van comonaden.
Formele definitie
[bewerken | brontekst bewerken]Doorlopend in dit artikel is een categorie. Een monade op bestaat uit een endofunctor , samen met twee natuurlijke transformaties:
- (waarbij de identiteitsfunctor op is);
- (waarbij de functor is, die van naar gaat).
Deze moeten voldoen aan de volgende voorwaarden (soms ook wel coherentievoorwaarden genoemd):
- (als natuurlijke transformaties weergegeven: ); hier worden en gevormd door "horizontale compositie";
- (als natuurlijke transformaties: ); hier is de identieke transformatie aan van naar ).
We kunnen deze voorwaarden herschrijven aan de hand van de volgende commutatieve diagrammen:
Het eerste axioma doet denken aan de associativiteitsvereiste bij monoïden als we als de binaire werking van de monoïde beschouwen. Het tweede axioma is verwant aan het bestaan van een identiteitselement (dat we beschouwen als gegeven door ). Deze gelijkheden zijn niet louter toeval: men kan een monade op ook definiëren als een monoïde in de categorie , waarvan de objecten de endofunctoren zijn van en waarvan de morfismen de natuurlijke transformaties ertussen zijn. De monoïdale structuur is een gevolg van de werking van samenstelling van endofunctoren.
De machtsverzamelingsmonade
[bewerken | brontekst bewerken]De machtsverzamelingsmonade is een monade over de categorie . Gegeven een verzameling , zij de machtsverzameling van , en gegeven een functie , zij de functie tussen de machtsverzamelingen die worden geïnduceerd door het nemen van directe beelden onder . Voor elke verzameling bestaat er een afbeelding , die aan elke de singleton toekent. De functie neemt een verzameling van verzamelingen en beeldt deze af op de unie ervan. Deze gegevens beschrijven tezamen een monade.
Bemerkingen
[bewerken | brontekst bewerken]De axioma's van een monade zijn vergelijkbaar met de monoïdeaxioma's. Monaden zijn dan ook in feite speciale gevallen van monoïden: ze zijn immers precies de monoïden onder de endofunctoren , uitgerust met een vermenigvuldiging gegeven door de samenstelling van endofunctoren.
De samenstelling van monaden is over het algemeen geen monade. Zo laat de dubbele machtsverzamelingsfunctor geen enkele monadische structuur toe.