首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从箭头符号转换

从箭头符号转换
EN

Stack Overflow用户
提问于 2014-08-12 04:24:11
回答 2查看 360关注 0票数 6

我仍在试图了解箭头符号与Haskell中定义的箭头类型的语义之间的相似之处。特别是,this question似乎有一个非常典型的用箭头符号编写的小型计数器示例:

代码语言:javascript
运行
复制
counter :: ArrowCircuit a => a Bool Int
counter = proc reset -> do
        rec     output <- returnA -< if reset then 0 else next
                next <- delay 0 -< output+1
        returnA -< output

有人能告诉我如何在没有箭头符号的情况下将它转换回Haskell2010吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-08-12 08:44:50

代码语言:javascript
运行
复制
{- |
                     +---------+
 >Bool>-------------->         |
                     |         >------------------>Int>
       +---------+   |  arr f  |
  /----> delay 0 >--->         >---------\
  |    +---------+   |         |         |
  |                  +---------+         |
  |                                      |
  \--------------------------------------/ 

 -}
counter' :: ArrowCircuit a => a Bool Int
counter' = loop $ second (delay 0) >>> arr f
  where
    f (reset, next) = let output = if reset then 0 else next
                          next' = output + 1
                       in (output, next')

递归rec部分是使用loop实现的。使用resetoutput转换为output(并生成新的next值)的内部部分只是一个纯函数,具有两个输入和两个输出。

票数 11
EN

Stack Overflow用户

发布于 2014-08-12 13:55:21

函数代码中的并行性是使用状态op。折成一叠

代码语言:javascript
运行
复制
import Data.List

counter :: (Int, Int) -> Bool -> (Int, Int)
counter (_, previous_next) reset  =
   let output = if reset then 0 else previous_next
       next = output +1
   in (output, next)

runCounter :: [Bool] -> (Int, Int) 
runCounter = foldl' counter (0,1)

main = do
   let resets = [True, False, True, False, False]   
       result = fst $ runCounter resets
   print result 
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25256138

复制
相关文章

相似问题

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