不动点组合子

✍ dations ◷ 2025-11-11 09:01:36 #Lambda演算,不动点,组合子逻辑

不动点组合子(英语:Fixed-point combinator,或不动点算子)是计算其他函数的一个不动点的高阶函数。

函数 f 的不动点是将函数应用在输入值 x 时,会传回与输入值相同的值,使得 f(x) = x。例如,0 和 1 是函数 f(x) = x2 的不动点,因为 02 = 0 而 12 = 1。鉴于一阶函数(在简单值比如整数上的函数)的不动点是个一阶值,高阶函数 f 的不动点是另一个函数 g 使得 f(g) = g。那么,不动点算子 fix 的定义是

使得对于任何函数 f

不动点组合子它们可以用非递归的 lambda抽象来定义,在 lambda演算中的函数都是匿名的。然而在命令式编程语言中的递归,或许限制只能以呼叫函数名称作为参数来实作。在函数式编程语言中的不动点,以 lambda抽象来定义的Y组合子为:

则允许匿名函数足够逹成递归的作用,即递归函数。应用于带有一个变量的函数,Y组合子通常不会终止。将 Y组合子应用于二或更多个变量的函数,会获得更有趣的结果。第二个变量可当作计数器或索引。由此产生的函数行为,表现出如命令式语言中一个whilefor循环。

这个组合子也是 Curry悖论的核心,演示了无型别的 lambda演算是一个不稳固的推论系统,因由 Y组合子允许一个匿名表达式来表示零或者甚至许多值,这在数理逻辑上是不一致的。

在无类型lambda演算中众所周知的(可能是最简单的)不动点组合子叫做Y组合子。它是Haskell B. Curry发现的,定义为

注意Y组合子意图用于传名求值策略,因为 (Y g)在传值设置下会发散(对于任何g)。

在数学的特定形式化中,比如无类型lambda演算和组合演算中,所有表达式都被当作高阶函数。在这些形式化中,不动点组合子的存在性意味着“所有函数都至少有一个不动点”,函数可以有多于一个不同的不动点。

在其他系统中,比如简单类型lambda演算,不能写出有良好类型(well-typed)的不动点组合子。在这些系统中对递归的任何支持都必须明确的增加到语言中。带有扩展的递归类型的简单类型lambda演算,可以写出不动点算子,“有用的”不动点算子(它的应用总是会返回)的类型将是有限制的。

例如,在Standard ML中Y组合子的传值调用变体有类型∀a.∀b.((a→b)→(a→b))→(a→b),而传名调用变体有类型∀a.(a→a)→a。传名调用(正则序)变体在应用于传值调用的语言的时候将永远循环下去 -- 所有应用Y(f)展开为f(Y(f))。按传值调用语言的要求,到f的参数将接着展开,生成f(f(Y(f)))。这个过程永远重复下去(直到系统耗尽内存),而不会实际上求值f的主体。

考虑阶乘函数(使用邱奇数)。平常的递归数学等式

可以用lambda演算把这个递归的一个“单一步骤”表达为

这里的"f"是给阶乘函数的占位参数,用于传递给自身。函数F进行求值递归公式中的一个单一步骤。应用fix算子得到

Y组合子的可以在传值调用的应用序求值中使用的变体,由普通Y组合子的部分的η-展开给出:

Y组合子用SKI-演算表达为

另一个常见不动点组合子是图灵不动点组合子(阿兰·图灵发现的):

相关

  • 加州理工学院加州理工学院(California Institute of Technology,缩写:Caltech)是一所位于美国加利福尼亚州帕萨迪纳的私立研究型大学,创建于1891年,以自然科学及工程学著称,常被评为世界前十的
  • 主权公国联合尼德兰主权公国(荷兰语:Souvereine Vorstendom der Verëenigde Nederlanden),是一个在1813至1815年间存在的主权公国。该政权是打败拿破仑的领袖们重划欧洲势力范围时产生
  • 矮灵祭巴斯达隘(赛夏语:paSta'ay),俗称矮灵祭,是台湾原住民赛夏族的传统祭祀活动之一,每二年举行一次(西元的双数年),时间则落于秋收后农历十月中旬的月圆前后,每隔十年一次大祭。据赛夏族传
  • 陈镐民陈镐民,美籍华人,天使投资人,现任广东大晋对接信息科技有限公司董事长。毕业于美国威斯康辛大学硕士和博士学位。早年在美国贝尔实验室从事技术研究,并在16个国家获得了多项技术
  • 迈克尔·柯蒂茲迈克尔·柯蒂斯(英语:Michael Curtiz,1886年12月24日-1962年4月10日),生于奥匈帝国布达佩斯 ,犹太人,原籍匈牙利的美国电影导演。最成功的作品莫过于《北非谍影》,由此获得奥斯卡最佳
  • 普通合伙普通合伙是一种合伙制企业。所有合伙人为企业提供劳务和资金,在承担无限责任下共同负担盈亏。。
  • 华西凤尾蕨华西凤尾蕨(学名:),为凤尾蕨科凤尾蕨属下的一个植物种。
  • 文德林·维尔纳文德林·维尔纳(德语:Wendelin Werner,1968年9月23日-),法国数学家,菲尔兹奖得主。他生于西德科隆,1977年获得法国国籍。维尔纳于1987年至1991年就读于巴黎高等师范学院。1993年在巴
  • 柏贤妃柏贤妃(15世纪1459年前-1527年),名失考,为中国古代明朝皇族女性,明宪宗朱见深的贤妃,是宪宗次子悼恭太子朱祐极之母。生年没有记载,据其妹生年推算,当在天顺己卯年(1459年)之前。天顺八
  • 佩德罗·帕斯卡乔斯·佩德罗·巴尔马塞特·帕斯卡(英语:Jose Pedro Balmaceda Pascal,1975年4月2日-)或简称佩德罗·帕斯卡(英语:Pedro Pascal),是一位智利裔美国男演员。他最著名的是在HBO电视剧《