{-# LANGUAGE CPP #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE Rank2Types #-}
#if __GLASGOW_HASKELL__ >= 706
{-# LANGUAGE PolyKinds #-}
#endif
#if __GLASGOW_HASKELL__ >= 702 && __GLASGOW_HASKELL__ < 710
{-# LANGUAGE Trustworthy #-}
#endif
module Data.Functor.Kan.Lan
(
Lan(..)
, toLan, fromLan
, glan
, composeLan, decomposeLan
, adjointToLan, lanToAdjoint
, composedAdjointToLan, lanToComposedAdjoint
) where
import Control.Applicative
import Data.Functor.Adjunction
import Data.Functor.Apply
import Data.Functor.Composition
import Data.Functor.Identity
data Lan g h a where
Lan :: (g b -> a) -> h b -> Lan g h a
instance Functor (Lan f g) where
fmap :: (a -> b) -> Lan f g a -> Lan f g b
fmap a -> b
f (Lan f b -> a
g g b
h) = (f b -> b) -> g b -> Lan f g b
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan (a -> b
f (a -> b) -> (f b -> a) -> f b -> b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. f b -> a
g) g b
h
{-# INLINE fmap #-}
instance (Functor g, Apply h) => Apply (Lan g h) where
Lan g b -> a -> b
kxf h b
x <.> :: Lan g h (a -> b) -> Lan g h a -> Lan g h b
<.> Lan g b -> a
kya h b
y =
(g (b, b) -> b) -> h (b, b) -> Lan g h b
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan (\g (b, b)
k -> g b -> a -> b
kxf (((b, b) -> b) -> g (b, b) -> g b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap (b, b) -> b
forall a b. (a, b) -> a
fst g (b, b)
k) (g b -> a
kya (((b, b) -> b) -> g (b, b) -> g b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap (b, b) -> b
forall a b. (a, b) -> b
snd g (b, b)
k))) ((,) (b -> b -> (b, b)) -> h b -> h (b -> (b, b))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> h b
x h (b -> (b, b)) -> h b -> h (b, b)
forall (f :: * -> *) a b. Apply f => f (a -> b) -> f a -> f b
<.> h b
y)
{-# INLINE (<.>) #-}
instance (Functor g, Applicative h) => Applicative (Lan g h) where
pure :: a -> Lan g h a
pure a
a = (g () -> a) -> h () -> Lan g h a
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan (a -> g () -> a
forall a b. a -> b -> a
const a
a) (() -> h ()
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
{-# INLINE pure #-}
Lan g b -> a -> b
kxf h b
x <*> :: Lan g h (a -> b) -> Lan g h a -> Lan g h b
<*> Lan g b -> a
kya h b
y =
(g (b, b) -> b) -> h (b, b) -> Lan g h b
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan (\g (b, b)
k -> g b -> a -> b
kxf (((b, b) -> b) -> g (b, b) -> g b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap (b, b) -> b
forall a b. (a, b) -> a
fst g (b, b)
k) (g b -> a
kya (((b, b) -> b) -> g (b, b) -> g b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap (b, b) -> b
forall a b. (a, b) -> b
snd g (b, b)
k))) ((b -> b -> (b, b)) -> h b -> h b -> h (b, b)
forall (f :: * -> *) a b c.
Applicative f =>
(a -> b -> c) -> f a -> f b -> f c
liftA2 (,) h b
x h b
y)
{-# INLINE (<*>) #-}
toLan :: Functor f => (forall a. h a -> f (g a)) -> Lan g h b -> f b
toLan :: (forall (a :: k). h a -> f (g a)) -> Lan g h b -> f b
toLan forall (a :: k). h a -> f (g a)
s (Lan g b -> b
f h b
v) = (g b -> b) -> f (g b) -> f b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap g b -> b
f (h b -> f (g b)
forall (a :: k). h a -> f (g a)
s h b
v)
{-# INLINE toLan #-}
fromLan :: (forall a. Lan g h a -> f a) -> h b -> f (g b)
fromLan :: (forall a. Lan g h a -> f a) -> h b -> f (g b)
fromLan forall a. Lan g h a -> f a
s = Lan g h (g b) -> f (g b)
forall a. Lan g h a -> f a
s (Lan g h (g b) -> f (g b))
-> (h b -> Lan g h (g b)) -> h b -> f (g b)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. h b -> Lan g h (g b)
forall k (h :: k -> *) (a :: k) (g :: k -> *). h a -> Lan g h (g a)
glan
{-# INLINE fromLan #-}
adjointToLan :: Adjunction f g => g a -> Lan f Identity a
adjointToLan :: g a -> Lan f Identity a
adjointToLan = (f (g a) -> a) -> Identity (g a) -> Lan f Identity a
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan f (g a) -> a
forall (f :: * -> *) (u :: * -> *) a.
Adjunction f u =>
f (u a) -> a
counit (Identity (g a) -> Lan f Identity a)
-> (g a -> Identity (g a)) -> g a -> Lan f Identity a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. g a -> Identity (g a)
forall a. a -> Identity a
Identity
{-# INLINE adjointToLan #-}
lanToAdjoint :: Adjunction f g => Lan f Identity a -> g a
lanToAdjoint :: Lan f Identity a -> g a
lanToAdjoint (Lan f b -> a
f Identity b
v) = (f b -> a) -> b -> g a
forall (f :: * -> *) (u :: * -> *) a b.
Adjunction f u =>
(f a -> b) -> a -> u b
leftAdjunct f b -> a
f (Identity b -> b
forall a. Identity a -> a
runIdentity Identity b
v)
{-# INLINE lanToAdjoint #-}
lanToComposedAdjoint :: (Functor h, Adjunction f g) => Lan f h a -> h (g a)
lanToComposedAdjoint :: Lan f h a -> h (g a)
lanToComposedAdjoint (Lan f b -> a
f h b
v) = (b -> g a) -> h b -> h (g a)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((f b -> a) -> b -> g a
forall (f :: * -> *) (u :: * -> *) a b.
Adjunction f u =>
(f a -> b) -> a -> u b
leftAdjunct f b -> a
f) h b
v
{-# INLINE lanToComposedAdjoint #-}
composedAdjointToLan :: Adjunction f g => h (g a) -> Lan f h a
composedAdjointToLan :: h (g a) -> Lan f h a
composedAdjointToLan = (f (g a) -> a) -> h (g a) -> Lan f h a
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan f (g a) -> a
forall (f :: * -> *) (u :: * -> *) a.
Adjunction f u =>
f (u a) -> a
counit
{-# INLINE composedAdjointToLan #-}
composeLan :: (Composition compose, Functor f) => Lan f (Lan g h) a -> Lan (compose f g) h a
composeLan :: Lan f (Lan g h) a -> Lan (compose f g) h a
composeLan (Lan f b -> a
f (Lan g b -> b
g h b
h)) = (compose f g b -> a) -> h b -> Lan (compose f g) h a
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan (f b -> a
f (f b -> a) -> (compose f g b -> f b) -> compose f g b -> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (g b -> b) -> f (g b) -> f b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap g b -> b
g (f (g b) -> f b)
-> (compose f g b -> f (g b)) -> compose f g b -> f b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. compose f g b -> f (g b)
forall (o :: (* -> *) -> (* -> *) -> * -> *) (f :: * -> *)
(g :: * -> *) x.
Composition o =>
o f g x -> f (g x)
decompose) h b
h
{-# INLINE composeLan #-}
decomposeLan :: Composition compose => Lan (compose f g) h a -> Lan f (Lan g h) a
decomposeLan :: Lan (compose f g) h a -> Lan f (Lan g h) a
decomposeLan (Lan compose f g b -> a
f h b
h) = (f (g b) -> a) -> Lan g h (g b) -> Lan f (Lan g h) a
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan (compose f g b -> a
f (compose f g b -> a) -> (f (g b) -> compose f g b) -> f (g b) -> a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. f (g b) -> compose f g b
forall (o :: (* -> *) -> (* -> *) -> * -> *) (f :: * -> *)
(g :: * -> *) x.
Composition o =>
f (g x) -> o f g x
compose) ((g b -> g b) -> h b -> Lan g h (g b)
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan g b -> g b
forall a. a -> a
id h b
h)
{-# INLINE decomposeLan #-}
glan :: h a -> Lan g h (g a)
glan :: h a -> Lan g h (g a)
glan = (g a -> g a) -> h a -> Lan g h (g a)
forall k (g :: k -> *) (b :: k) a (h :: k -> *).
(g b -> a) -> h b -> Lan g h a
Lan g a -> g a
forall a. a -> a
id
{-# INLINE glan #-}