On inter-deriving small-step and big-step semantics: A case study for storeless call-by-need evaluation

  • Authors:
  • Olivier Danvy;Kevin Millikin;Johan Munk;Ian Zerny

  • Affiliations:
  • Department of Computer Science, Aarhus University, Aabogade 34, DK-8200 Aarhus N, Denmark;Google, Aabogade 15, DK-8200 Aarhus N, Denmark;Arctic Lake Systems, Aabogade 15, DK-8200 Aarhus N, Denmark;Department of Computer Science, Aarhus University, Aabogade 34, DK-8200 Aarhus N, Denmark

  • Venue:
  • Theoretical Computer Science
  • Year:
  • 2012

Quantified Score

Hi-index 5.23

Visualization

Abstract

Starting from the standard call-by-need reduction for the @l-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.