| Portability | Type-Families |
|---|---|
| Stability | provisional |
| Maintainer | Edward Kmett <ekmett@gmail.com> |
| Safe Haskell | Trustworthy |
Data.Profunctor.Rep
Description
- class (Functor (Rep p), Profunctor p) => Representable p where
- tabulated :: (Profunctor r, Functor f, Representable p, Representable q) => r (p d c) (f (q d' c')) -> r (d -> Rep p c) (f (d' -> Rep q c'))
- class (Functor (Corep p), Profunctor p) => Corepresentable p where
- type Corep p :: * -> *
- cotabulate :: (Corep p d -> c) -> p d c
- corep :: p d c -> Corep p d -> c
- cotabulated :: (Profunctor r, Functor h, Corepresentable p, Corepresentable q) => r (p d c) (h (q d' c')) -> r (Corep p d -> c) (h (Corep q d' -> c'))
Representable Profunctors
class (Functor (Rep p), Profunctor p) => Representable p whereSource
A Profunctor p is Representable if there exists a Functor f such that
p d c is isomorphic to d -> f c.
Instances
| Representable (->) | |
| (Monad m, Functor m) => Representable (Kleisli m) | |
| Functor f => Representable (UpStar f) | |
| (Representable p, Representable q) => Representable (Procompose p q) | The composition of two |
tabulated :: (Profunctor r, Functor f, Representable p, Representable q) => r (p d c) (f (q d' c')) -> r (d -> Rep p c) (f (d' -> Rep q c'))Source
tabulate and rep form two halves of an isomorphism.
This can be used with the combinators from the lens package.
tabulated::Representablep =>Iso'(d ->Repp c) (p d c)
Corepresentable Profunctors
class (Functor (Corep p), Profunctor p) => Corepresentable p whereSource
A Profunctor p is Corepresentable if there exists a Functor f such that
p d c is isomorphic to f d -> c.
Instances
| Corepresentable (->) | |
| Functor w => Corepresentable (Cokleisli w) | |
| Functor f => Corepresentable (DownStar f) | |
| Corepresentable (Tagged *) | |
| (Corepresentable p, Corepresentable q) => Corepresentable (Procompose p q) |
cotabulated :: (Profunctor r, Functor h, Corepresentable p, Corepresentable q) => r (p d c) (h (q d' c')) -> r (Corep p d -> c) (h (Corep q d' -> c'))Source
cotabulate and corep form two halves of an isomorphism.
This can be used with the combinators from the lens package.
tabulated::Corepf p =>Iso'(f d -> c) (p d c)