On Inter-deriving Small-step and Big-step Semantics: A Case Study for Storeless Call-by-need Evaluation

Research output: Contribution to journal/Conference contribution in journal/Contribution to newspaperJournal articleResearchpeer-review

  • Olivier Danvy
  • Kevin Millikin, Google, Aarhus, Denmark
  • Johan Munk, Arctic Lake Systems, Aarhus, Denmark
  • Ian Zerny, Denmark
Starting from the standard call-by-need reduction for the λ-calculus that is common to Ariola, Felleisen, Maraist, Odersky, and Wadler, we inter-derive a series of hygienic semantic artifacts: a reduction-free storeless abstract machine, a continuation-passing evaluation function, and what appears to be the first heapless natural semantics for call-by-need evaluation. Furthermore we observe that the evaluation function implementing this natural semantics is in defunctionalized form. The refunctionalized counterpart of this evaluation function implements an extended direct semantics in the sense of Cartwright and Felleisen.

Overall, the semantic artifacts presented here are simpler than many other such artifacts that have been independently worked out, and which require ingenuity, skill, and independent soundness proofs on a case-by-case basis. They are also simpler to inter-derive because the inter-derivational tools (e.g., refocusing and defunctionalization) already exist.
Original languageEnglish
JournalTheoretical Computer Science
Pages (from-to)21–42
Number of pages23
Publication statusPublished - 2012

See relations at Aarhus University Citationformats

ID: 44466870