做了个极简的 λ 演算(lambda calculus)的解释器

2018-02-18 16:06:27 +08:00
 geelaw

前情提要:/t/430679

自从上次以来,修复了一些 bug 并重构了代码,为实现 规范顺序归约、记忆化懒惰求值 做准备。实现了 η-变换和 β-归约,并完成了一个简单的 interactive interpreter。实现这个版本的 β-规约的方法论是三步,每一步都很自然:

  1. 在做 β-归约时,把所有要替换的绑定变量替换为被替换的东西,并且共享对象引用(这样下次 β-归约这个被替换对象的时候,就可以一下子归约很多地方,提高效率);
  2. 在 β-归约 (λx. M) N 的时候,语法树里面的 M 需要被 深复制 才能替换 x 为 N,这是因为前面一个方法导致的(或是因为一些子项来自常数表导致的)共享对象会导致 M 可能和 N 共享一些引用,如果不深复制(比如,原地修改),可能会意外改变 N 里面的东西,更惨的是可能改变这个子项之外的东西;
  3. 要确保一次 β-归约被最佳利用,需要在 (λx. M) N 被归约后把所有 (λx. M) N 的引用都替换为归约结果。

你可以查看我的 blog 原文

还可以从这个 GitHub 仓库 访问代码,现已按 MIT License 提供授权。


2740 次点击
所在节点    分享创造
2 条回复
cholerae
2018-02-18 22:12:52 +08:00
呃,没必要更新一次发个帖子吧
geelaw
2018-02-19 03:20:10 +08:00
@cholerae 并不是更新一次发一个帖子 - - 这是一篇新的 blog entry 了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/431134

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX