[Haskell-cafe] questions on lazy pattern, StateT monad

Wolfgang Jeltsch wolfgang at jeltsch.net
Thu Nov 24 15:34:11 EST 2005


Am Donnerstag, 24. November 2005 21:19 schrieben Sie:
> [...]

> Here I want to correct a statement I made previously about:
>
>   mplus m1 m2       = do  ...
>                         ~(a,s') <- lift (mplus m1' m2')
>
> In one of my emails to the thread I mentioned m1/m2 and m1'/m2' could
> be different Monads so mplus works differently (so that this is not
> exactly a recusrive data structure), but even so the lazy pattern
> works. The problem is when m1/m2 and m1'/m2' are of the same Monad
> type, then the problem of recursive definition comes up and this is
> the place lazy patterns are particularly useful.

They cannot belong to the same monad.  If s is the state type and m1' and m2' 
belong to the monad m then m1 and m2 belong to the monad StateT s m.

> Thanks,
> Fan

Best wishes,
Wolfgang


More information about the Haskell-Cafe mailing list