| Safe Haskell | None | 
|---|---|
| Language | Haskell2010 | 
Control.Algebra.Free
Contents
Synopsis
- class FreeAlgebra1 (m :: (k -> Type) -> k -> Type) where- liftFree :: AlgebraType0 m f => f a -> m f a
- foldNatFree :: forall d f a. (AlgebraType m d, AlgebraType0 m f) => (forall x. f x -> d x) -> m f a -> d a
- codom1 :: forall f. AlgebraType0 m f => Proof (AlgebraType m (m f)) (m f)
- forget1 :: forall f. AlgebraType m f => Proof (AlgebraType0 m f) (m f)
 
- newtype Proof (c :: Constraint) (a :: l) = Proof (Dict c)
- proof :: c => Proof (c :: Constraint) (a :: l)
- type family AlgebraType0 (f :: k) (a :: l) :: Constraint
- type family AlgebraType (f :: k) (a :: l) :: Constraint
- wrapFree :: forall (m :: (Type -> Type) -> Type -> Type) (f :: Type -> Type) a. (FreeAlgebra1 m, AlgebraType0 m f, Monad (m f)) => f (m f a) -> m f a
- foldFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType m f) => m f a -> f a
- unFoldNatFree :: (FreeAlgebra1 m, AlgebraType0 m f) => (forall x. m f x -> d x) -> f a -> d a
- hoistFree1 :: forall m f g a. (FreeAlgebra1 m, AlgebraType0 m g, AlgebraType0 m f) => (forall x. f x -> g x) -> m f a -> m g a
- hoistFreeH :: forall m n f a. (FreeAlgebra1 m, FreeAlgebra1 n, AlgebraType0 m f, AlgebraType0 n f, AlgebraType m (n f)) => m f a -> n f a
- joinFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType0 m f) => m (m f) a -> m f a
- bindFree1 :: forall m f g a. (FreeAlgebra1 m, AlgebraType0 m g, AlgebraType0 m f) => m f a -> (forall x. f x -> m g x) -> m g a
- assocFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType m f, Functor (m (m f))) => m f (m f a) -> m (m f) (f a)
- iterFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType0 m f, AlgebraType m Identity) => (forall x. f x -> x) -> m f a -> a
- cataFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType m f, Monad f, Traversable (m f)) => Fix (m f) -> f a
- newtype DayF f a = DayF {}
- dayToAp :: Applicative f => Day f f a -> Ap f a
- apToDay :: Applicative f => Ap f a -> Day f f a
- class Monad m => MonadList m where
- class MonadMaybe m where- point :: forall a. m a
 
Documentation
class FreeAlgebra1 (m :: (k -> Type) -> k -> Type) where Source #
Higher kinded version of FreeAlgebra
A lawful instance should guarantee that foldNatFreeunFoldNatFree
This guaranties that m is a left adjoint functor from the category of
 types of kind Type -> Type which satisfy AlgebraType0 mType -> Type which satisfy the AlgebraType mAlgebraType0m composed with this forgetful functor is a monad.
 In result we get monadic operations:
For m such that AlgebraType0Monad
- MFunctorvia- hoist = hoistFree1
- MMonadvia- embed = flip bindFree1
- MonadTransvia- lift = liftFree
Methods
liftFree :: AlgebraType0 m f => f a -> m f a Source #
Natural transformation that embeds generators into m.
Arguments
| :: (AlgebraType m d, AlgebraType0 m f) | |
| => (forall x. f x -> d x) | a natural transformation which embeds generators of  | 
| -> m f a -> d a | a morphism from  | 
The freeness property.
codom1 :: forall f. AlgebraType0 m f => Proof (AlgebraType m (m f)) (m f) Source #
A proof that AlgebraType m (m f)AlgebraType0 f => f.
 Together with hoistFree1FreeAlgebra m => m is
 a functor from the full subcategory of types of kind Type -> Type
 which satisfy AlgebraType0 m fAlgebraType
 m f
forget1 :: forall f. AlgebraType m f => Proof (AlgebraType0 m f) (m f) Source #
A proof that the forgetful functor from the full subcategory of types of
 kind Type -> Type satisfying AlgebraType m fAlgebraType0 m f
Instances
Type level witnesses
newtype Proof (c :: Constraint) (a :: l) Source #
A proof that constraint c holds for type a.
Higher algebra type
type family AlgebraType0 (f :: k) (a :: l) :: Constraint Source #
Type family which limits Hask to its full subcategory which satisfies
 a given constraints.  Some free algebras, like free groups, or free abelian
 semigroups have additional constraints on on generators, like Eq or Ord.
Instances
| type AlgebraType0 Coyoneda (g :: l) Source # | Algebras of the same type as  | 
| Defined in Control.Algebra.Free | |
| type AlgebraType0 DList (a :: l) Source # | |
| Defined in Data.Algebra.Free | |
| type AlgebraType0 Maybe (a :: l) Source # | |
| Defined in Data.Algebra.Free | |
| type AlgebraType0 [] (a :: l) Source # | |
| Defined in Data.Algebra.Free type AlgebraType0 [] (a :: l) = () | |
| type AlgebraType0 NonEmpty (a :: l) Source # | |
| Defined in Data.Algebra.Free | |
| type AlgebraType0 Identity (a :: l) Source # | |
| Defined in Data.Algebra.Free | |
| type AlgebraType0 (Free Group) (a :: l) Source # | |
| Defined in Data.Algebra.Free | |
| type AlgebraType0 (Free Monoid) (a :: l) Source # | |
| Defined in Data.Algebra.Free | |
| type AlgebraType0 (Free Semigroup) (a :: l) Source # | |
| Defined in Data.Algebra.Free | |
| type AlgebraType0 FreeGroupL (a :: Type) Source # | |
| Defined in Data.Group.Free | |
| type AlgebraType0 FreeGroup (a :: Type) Source # | |
| Defined in Data.Group.Free | |
| type AlgebraType0 FreeAbelianSemigroup (a :: Type) Source # | |
| Defined in Data.Semigroup.Abelian | |
| type AlgebraType0 FreeAbelianMonoid (a :: Type) Source # | |
| Defined in Data.Monoid.Abelian | |
| type AlgebraType0 FreeSemiLattice (a :: Type) Source # | |
| Defined in Data.Semigroup.SemiLattice | |
| type AlgebraType0 MaybeT (m :: Type -> Type) Source # | |
| Defined in Control.Algebra.Free | |
| type AlgebraType0 F (f :: Type -> Type) Source # | |
| Defined in Control.Algebra.Free | |
| type AlgebraType0 Free (f :: Type -> Type) Source # | Algebras of the same type as  | 
| Defined in Control.Algebra.Free | |
| type AlgebraType0 Ap (g :: Type -> Type) Source # | |
| Defined in Control.Algebra.Free | |
| type AlgebraType0 Ap (g :: Type -> Type) Source # | |
| Defined in Control.Algebra.Free | |
| type AlgebraType0 Ap (g :: Type -> Type) Source # | Algebras of the same type as  | 
| Defined in Control.Algebra.Free | |
| type AlgebraType0 Alt (f :: Type -> Type) Source # | |
| Defined in Control.Algebra.Free | |
| type AlgebraType0 ListT (f :: Type -> Type) Source # | |
| Defined in Control.Algebra.Free | |
| type AlgebraType0 DayF (g :: Type -> Type) Source # | Algebras of the same type as  | 
| Defined in Control.Algebra.Free | |
| type AlgebraType0 (FreeMAction m :: (Type -> Type) -> Type -> Type) (f :: Type -> Type) Source # | |
| Defined in Control.Monad.Action | |
| type AlgebraType0 (ExceptT e :: (Type -> Type) -> Type -> Type) (m :: Type -> Type) Source # | Algebras of the same type as  | 
| Defined in Control.Algebra.Free | |
| type AlgebraType0 (StateT s :: (Type -> Type) -> Type -> Type) (m :: Type -> Type) Source # | Algebras of the same type as  | 
| Defined in Control.Algebra.Free | |
| type AlgebraType0 (StateT s :: (Type -> Type) -> Type -> Type) (m :: Type -> Type) Source # | Algebras of the same type as  | 
| Defined in Control.Algebra.Free | |
| type AlgebraType0 (WriterT w :: (Type -> Type) -> Type -> Type) (m :: Type -> Type) Source # | Algebras of the same type as  | 
| type AlgebraType0 (WriterT w :: (Type -> Type) -> Type -> Type) (m :: Type -> Type) Source # | Algebras of the same type as  | 
| type AlgebraType0 (ReaderT r :: (k -> Type) -> k -> Type) (m :: Type -> Type) Source # | Algebras of the same type as  TODO: take advantage of poly-kinded  | 
| Defined in Control.Algebra.Free | |
| type AlgebraType0 (RWST r w s :: (Type -> Type) -> Type -> Type) (m :: Type -> Type) Source # | |
| type AlgebraType0 (RWST r w s :: (Type -> Type) -> Type -> Type) (m :: Type -> Type) Source # | |
type family AlgebraType (f :: k) (a :: l) :: Constraint Source #
Type family which for each free algebra m returns a type level lambda from
 types to constraints.  It is describe the class of algebras for which this
 free algebra is free.
A lawful instance for this type family must guarantee
 that the constraint AlgebraType0 m fAlgebraType
 m f* -> * which satisfy AlgebraType m* -> * which satisfy the
 'AlgebraType0 m constraint.
Instances
Combinators
wrapFree :: forall (m :: (Type -> Type) -> Type -> Type) (f :: Type -> Type) a. (FreeAlgebra1 m, AlgebraType0 m f, Monad (m f)) => f (m f a) -> m f a Source #
Anything that carries FreeAlgebra1MonadFreewrapMonadFreeContTFreeAlgebra1MonadFree
The Monad'AlgebraType m' constraint.
foldFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType m f) => m f a -> f a Source #
FreeAlgebra1 mm f is a foldable.
foldFree1.liftFree==id:: f a -> f a
foldFree1 is the
 unit of the
 adjunction imposed by FreeAlgebra1 constraint.
It can be specialized to:
- lowerCoyoneda::- Functorf =>- Coyonedaf a -> f a
- retractAp::- Applicativef =>- Apf a -> f a
- foldFree::- Monadm => (forall x. f x -> m x) ->- Freef a -> m a
unFoldNatFree :: (FreeAlgebra1 m, AlgebraType0 m f) => (forall x. m f x -> d x) -> f a -> d a Source #
unFoldNatFreefoldNatFree
unFoldNatFree id = ruturnFree1
Note that unFoldNatFree idFreeAlgebra1
Arguments
| :: (FreeAlgebra1 m, AlgebraType0 m g, AlgebraType0 m f) | |
| => (forall x. f x -> g x) | a natural transformation  | 
| -> m f a | |
| -> m g a | 
This is a functor instance for m when considered as an endofuctor of some
 subcategory of Type -> Type (e.g. endofunctors of _Hask_).
It can be specialized to:
hoistFreeH :: forall m n f a. (FreeAlgebra1 m, FreeAlgebra1 n, AlgebraType0 m f, AlgebraType0 n f, AlgebraType m (n f)) => m f a -> n f a Source #
joinFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType0 m f) => m (m f) a -> m f a Source #
Arguments
| :: (FreeAlgebra1 m, AlgebraType0 m g, AlgebraType0 m f) | |
| => m f a | |
| -> (forall x. f x -> m g x) | natural transformation  | 
| -> m g a | 
Bind operator for the joinFree1foldNatFree
For StateTWriterTReaderTFreeAlgebra1 m => mAlgebraType0 mMonad m>>= version of
 Control.Monad.Morph.embed.
assocFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType m f, Functor (m (m f))) => m f (m f a) -> m (m f) (f a) Source #
iterFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType0 m f, AlgebraType m Identity) => (forall x. f x -> x) -> m f a -> a Source #
Specialization of foldNatFree @_ @Identity
- \_ -> - runIdentity.- lowerCoyoneda
- iterAp::- Functorg => (g a -> a) ->- Apg a -> a
- iter::- Functorf => (f a -> a) ->- Freef a -> a
cataFree1 :: forall m f a. (FreeAlgebra1 m, AlgebraType m f, Monad f, Traversable (m f)) => Fix (m f) -> f a Source #
Fix (m f)AlgebraType mAlgebraType0 f
Day convolution
Day f fAp ff via dayToApapToDay
Instances
| Functor (DayF f) Source # | |
| Applicative f => Applicative (DayF f) Source # | |
| FreeAlgebra1 DayF Source # | 
 | 
| Defined in Control.Algebra.Free Methods liftFree :: AlgebraType0 DayF f => f a -> DayF f a Source # foldNatFree :: (AlgebraType DayF d, AlgebraType0 DayF f) => (forall (x :: k). f x -> d x) -> DayF f a -> d a Source # codom1 :: AlgebraType0 DayF f => Proof (AlgebraType DayF (DayF f)) (DayF f) Source # forget1 :: AlgebraType DayF f => Proof (AlgebraType0 DayF f) (DayF f) Source # | |
| type AlgebraType0 DayF (g :: Type -> Type) Source # | Algebras of the same type as  | 
| Defined in Control.Algebra.Free | |
| type AlgebraType DayF (g :: Type -> Type) Source # | |
| Defined in Control.Algebra.Free | |