| Safe Haskell | None |
|---|---|
| Language | Haskell98 |
Data.Random.Lift
- class Lift m n where
Documentation
A class for "liftable" data structures. Conceptually
an extension of MonadTrans to allow deep lifting,
but lifting need not be done between monads only. Eg lifting
between Applicatives is allowed.
For instances where m and n have 'return'/'pure' defined,
these instances must satisfy
lift (return x) == return x.
This form of lift has an extremely general type and is used primarily to
support sample. Its excessive generality is the main reason it's not
exported from Data.Random. RVarT is, however, an instance of
MonadTrans, which in most cases is the preferred way
to do the lifting.
Minimal complete definition
Instances
| Lift m m Source # | |
| Monad m => Lift Identity m Source # | This instance is incoherent with the others. However,
by the law |
| (Monad m, MonadTrans t) => Lift m (t m) Source # | |
| MonadTrans t => Lift Identity (t Identity) Source # | This instance is again incoherent with the others, but provides a
more-specific instance to resolve the overlap between the
|
| Lift (RVarT Identity) (RVarT m) Source # | |