首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >互递归函数的定点组合器?

互递归函数的定点组合器?
EN

Stack Overflow用户
提问于 2011-02-04 22:29:37
回答 2查看 3.7K关注 0票数 14

有没有一个用于创建相互递归函数的元组的定点组合器?也就是说,我正在寻找类似Y-Combinator的东西,但它接受多个“递归”*函数,并将返回一个函数元组?

*:当然不是真正的递归,因为它们是以通常的Y-Combinator方式将自己(和兄弟)作为参数编写的。

EN

回答 2

Stack Overflow用户

发布于 2013-08-24 07:47:44

下面的网页详细描述了用于相互递归的定点组合器(多变量固定点组合器)。它派生出目前为止最简单的组合子。http://okmij.org/ftp/Computation/fixed-point-combinators.html#Poly-variadic

为了便于参考,这里是Haskell中最简单的多变量组合器(单行)

代码语言:javascript
复制
fix_poly:: [[a]->a] -> [a]
fix_poly fl = fix (\self -> map ($ self) fl)
  where fix f = f (fix f)

这里是Scheme,一种严格的语言

代码语言:javascript
复制
 (define (Y* . l)
   ((lambda (u) (u u))
    (lambda (p)
       (map (lambda (li) (lambda x (apply (apply li (p p)) x))) l))))

有关示例和更多讨论,请参阅网页。

票数 8
EN

Stack Overflow用户

发布于 2011-04-13 01:57:44

我对这一点不是很确定。我还在努力寻找正式的证据。但在我看来你不需要。在Haskell中,如果你有这样的东西:

修复::(a -> a) -> a

fix f= let x=f x in x

main = let {x= ...Y ...;y= ...X ... }在x中

您可以将main重写为

fix main = fst $

$ (x,y) -> (...你...,..。X ...)

但就像我说的,我不是100%确定。

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

https://stackoverflow.com/questions/4899113

复制
相关文章

相似问题

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