我需要使用list monad转换器.我读过,有潜在问题ListT IO的Control.Monad.List,因为IO是不可交换的,所以我期待在ListT做的权利.但我得到了一些意想不到的行为.
考虑这个简单的测试:
test = runListT $ do
x <- liftList [1..3]
liftIO $ print x
y <- liftList [6..8]
liftIO $ print (x,y)
Run Code Online (Sandbox Code Playgroud)
使用Control.Monad.List:
Main> test
1
(1,6)
(1,7)
(1,8)
2
(2,6)
(2,7)
(2,8)
3
(3,6)
(3,7)
(3,8)
[(),(),(),(),(),(),(),(),()]
Run Code Online (Sandbox Code Playgroud)
使用"ListT右对齐":
Main> test
1
(1,6)
Run Code Online (Sandbox Code Playgroud)
这是"ListT做得对"的问题,还是我只是错误使用它?有首选替代方案吗?
谢谢!
我刚刚在32位linux上从GHC 7.2.2升级到7.4.1.安装很顺利,但cabal-install并不开心:
$ cabal update
Downloading the latest package list from hackage.haskell.org
$ cabal install repa
Resolving dependencies...
cabal: Couldn't read cabal file "bytestring/0.9.2.1/bytestring.cabal"
Run Code Online (Sandbox Code Playgroud)
这是我正在运行的cabal版本:
$ cabal --version
cabal-install version 0.10.2
using version 1.10.1.0 of the Cabal library
Run Code Online (Sandbox Code Playgroud)
谢谢!
在高性能计算中,总和,产品等通常使用"并行缩减"来计算,该"并行缩减"采用n个元素并在O(log n)时间内完成(给定足够的并行度).在Haskell中,我们通常使用折叠进行此类计算,但评估时间在列表长度中始终是线性的.
Data Parallel Haskell内置了一些内容,但是在列表的通用框架中呢?我们能做到Control.Parallel.Strategies吗?
所以,假设f是关联的,我们如何写
parFold :: (a -> a -> a) -> [a] -> a
那么parFold f xs只需要时间对数length xs吗?