We study the equivalence of eval-readback and eval-apply big-step evaluators in the general setting of the pure lambda calculus. The equivalence extends to evaluators in typed lambda calculi if the strategy (the evaluation order of redexes) is realisable. We present a proof that one-step equivalence holds when (1) the `readback' stage satisfies straightforward well-formedness provisos, (2) the `eval' stage implements a `uniform' strategy, and (3) the eval-apply evaluator implements a `balanced hybrid' strategy that has `eval' as a subsidiary strategy. The proof proceeds by application of the `lightweight fusion by fixed-point promotion' program transformation on evaluator implementations to fuse readback and eval into the balanced hybrid. The proof can be followed with no previous knowledge of the transformation. We use Haskell as the implementation language, with all evaluators written in monadic style to guarantee semantics (strategy) preservation, but the choice of implementation language is immaterial. To determine the extent of the equivalence, we provide a comprehensive survey of the strategy space using canonical eval-apply evaluators. We discuss the strategies' properties and uses. We improve the formal definition of uniform and hybrid strategy, and use it to regiment the strategy space and to obtain the generic higher-order evaluators used in the proof that deliver all plain evaluators as fixed-points by instantiation. We introduce a systematic notation for both evaluator styles and use it to summarise strategy and evaluator equivalences, including (non-)equivalences within a style and (non-)equivalences between styles not proven by the transformation.
翻译:我们研究了在纯羊羔微积分的总体设置中,eval-Repack和eval-appla-pall 大型评价员的等值。如果战略(redexes的评价顺序)是真实的,这种等值就延及在 samped lambda calculi 中输入 lambda calculi 中的评价员。我们提出的一个证据是,当(1) “refack” 阶段满足了直截了当的完善的附带条件,(2) “eval” 阶段执行“uniforform”战略,(3) eval-pplipple 执行“alfal complend”战略的等值等值相等评价员的等值。为了确定“eight level- levelment” 战略的“equess muint”,我们用“ we val- levelmental-deal levelopmental 战略(我们用的是直径直径) 和直观战略,我们用直径地评估战略,我们用的是直径评估战略,我们用直观和直径评估战略,我们用直径评估战略,我们用直径评估战略,我们使用。