首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么没有repa数组的mapM?

为什么没有repa数组的mapM?
EN

Stack Overflow用户
提问于 2014-09-17 12:22:06
回答 1查看 172关注 0票数 5

背景

我更多地使用repa作为“管理”工具。我通过reactive-bananaAddHandlersArrayArray D DIM2 (AddHandler Bool)中传递。

目前,我正在使用这一技术:

代码语言:javascript
复制
mapMArray :: (Monad m, R.Source r a, R.Shape sh)  => (a -> m b) -> Array r sh a -> m (Array D sh b)
mapMArray f a = do
    l <- mapM f . R.toList $ a
    return $ R.fromFunction sh (\i -> l !! R.toIndex sh i)
  where sh = R.extent a

所以我可以做这样的事:

代码语言:javascript
复制
makeNetworkDesc :: Frameworks t => Array D DIM2 (AddHandler Bool) -> Moment t ()
makeNetworkDesc events = do

    -- inputs
    aes <- mapMArray fromAddHandler events

    -- outputs
    _ <- mapMArray (reactimate . (print <$>)) aes

问题

是否有理由在repa中不包括这一点?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-09-17 12:59:33

基本上,出于同样的原因,没有什么能像 in parallel那样:mapMmapM_ (或一般的一元操作)破坏并行性。下面是一个简单的例子:

代码语言:javascript
复制
next :: State Int Int
next = modify (+1) >> get

现在,假设的repaMapM需要对State单体中的所有步骤进行排序,如果要使用repaMapM (const next)的话。由于这显然不符合并行性(而且还可能导致低性能),所以它不是repa的一部分。毕竟,在repa的描述中,高性能和并行性就在这里(强调我的描述):

Repa提供了高性能、规则的、多维的、形状多态的并行阵列.

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25890459

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档