2023-08-19 12:15:34 +02:00
|
|
|
|
<!--
|
|
|
|
|
```agda
|
|
|
|
|
open import Level
|
2023-10-28 13:59:23 +02:00
|
|
|
|
open import Categories.FreeObjects.Free using (FreeObject; FO⇒Functor; FO⇒LAdj)
|
|
|
|
|
open import Categories.Functor.Core using (Functor)
|
|
|
|
|
open import Categories.Adjoint using (_⊣_)
|
|
|
|
|
open import Categories.Adjoint.Properties using (adjoint⇒monad)
|
|
|
|
|
open import Categories.Monad using (Monad)
|
|
|
|
|
open import Categories.Monad.Relative using () renaming (Monad to RMonad)
|
2023-09-12 16:03:20 +02:00
|
|
|
|
open import Category.Instance.AmbientCategory using (Ambient)
|
2023-10-28 13:59:23 +02:00
|
|
|
|
open import Categories.Monad.Construction.Kleisli
|
2023-08-19 12:15:34 +02:00
|
|
|
|
```
|
|
|
|
|
-->
|
|
|
|
|
|
2023-10-28 13:59:23 +02:00
|
|
|
|
# The monad K
|
2023-08-19 12:15:34 +02:00
|
|
|
|
|
|
|
|
|
```agda
|
2023-09-12 16:03:20 +02:00
|
|
|
|
module Monad.Instance.K {o ℓ e} (ambient : Ambient o ℓ e) where
|
|
|
|
|
open Ambient ambient
|
2023-11-22 08:48:53 +01:00
|
|
|
|
open import Category.Construction.ElgotAlgebras ambient using (Elgot-Algebras)
|
|
|
|
|
open import Algebra.Elgot ambient using (Elgot-Algebra)
|
|
|
|
|
open import Algebra.Elgot.Free ambient using (FreeElgotAlgebra; elgotForgetfulF; IsStableFreeElgotAlgebra)
|
2023-08-19 12:15:34 +02:00
|
|
|
|
|
2023-10-05 16:22:05 +02:00
|
|
|
|
open Equiv
|
2023-10-25 18:18:30 +02:00
|
|
|
|
open MR C
|
|
|
|
|
open M C
|
2023-10-12 18:11:28 +02:00
|
|
|
|
open HomReasoning
|
2023-08-19 12:15:34 +02:00
|
|
|
|
```
|
|
|
|
|
|
2023-10-28 13:59:23 +02:00
|
|
|
|
## Definition
|
|
|
|
|
|
|
|
|
|
The monad is defined by existence of free uniform-iteration algebras.
|
|
|
|
|
Since free objects yield and adjunctions, this yields a monad.
|
2023-08-19 12:15:34 +02:00
|
|
|
|
|
|
|
|
|
```agda
|
|
|
|
|
record MonadK : Set (suc o ⊔ suc ℓ ⊔ suc e) where
|
|
|
|
|
field
|
2023-11-22 08:48:53 +01:00
|
|
|
|
freealgebras : ∀ X → FreeElgotAlgebra X
|
|
|
|
|
stable : ∀ X → IsStableFreeElgotAlgebra (freealgebras X)
|
2023-10-28 13:59:23 +02:00
|
|
|
|
|
2023-11-22 08:48:53 +01:00
|
|
|
|
-- helper for accessing elgot algebras
|
|
|
|
|
algebras : ∀ (X : Obj) → Elgot-Algebra
|
2023-10-28 13:59:23 +02:00
|
|
|
|
algebras X = FreeObject.FX (freealgebras X)
|
2023-08-19 12:15:34 +02:00
|
|
|
|
|
2023-11-22 08:48:53 +01:00
|
|
|
|
freeF : Functor C Elgot-Algebras
|
|
|
|
|
freeF = FO⇒Functor elgotForgetfulF freealgebras
|
2023-08-19 12:15:34 +02:00
|
|
|
|
|
2023-11-22 08:48:53 +01:00
|
|
|
|
adjoint : freeF ⊣ elgotForgetfulF
|
|
|
|
|
adjoint = FO⇒LAdj elgotForgetfulF freealgebras
|
2023-08-19 12:15:34 +02:00
|
|
|
|
|
2023-10-28 13:59:23 +02:00
|
|
|
|
monadK : Monad C
|
|
|
|
|
monadK = adjoint⇒monad adjoint
|
|
|
|
|
module monadK = Monad monadK
|
2023-10-25 18:18:30 +02:00
|
|
|
|
|
2023-10-28 13:59:23 +02:00
|
|
|
|
kleisliK : KleisliTriple C
|
|
|
|
|
kleisliK = Monad⇒Kleisli C monadK
|
|
|
|
|
module kleisliK = RMonad kleisliK
|
2023-10-25 18:18:30 +02:00
|
|
|
|
|
2023-10-28 13:59:23 +02:00
|
|
|
|
module K = Functor monadK.F
|
2023-10-09 16:45:55 +02:00
|
|
|
|
```
|