English

Selective Lambda Lifting

Programming Languages 2019-10-29 v2

Abstract

Lambda lifting is a well-known transformation, traditionally employed for compiling functional programs to supercombinators. However, more recent abstract machines for functional languages like OCaml and Haskell tend to do closure conversion instead for direct access to the environment, so lambda lifting is no longer necessary to generate machine code. We propose to revisit selective lambda lifting in this context as an optimising code generation strategy and conceive heuristics to identify beneficial lifting opportunities. We give a static analysis for estimating impact on heap allocations of a lifting decision. Performance measurements of our implementation within the Glasgow Haskell Compiler on a large corpus of Haskell benchmarks suggest modest speedups.

Keywords

Cite

@article{arxiv.1910.11717,
  title  = {Selective Lambda Lifting},
  author = {Sebastian Graf and Simon Peyton Jones},
  journal= {arXiv preprint arXiv:1910.11717},
  year   = {2019}
}

Comments

Rejected from ICFP 2019