pith. sign in

Mirroring Call-by-Need, or Values Acting Silly

1 Pith paper cite this work. Polarity classification is still indexing.

1 Pith paper citing it
abstract

Call-by-need evaluation for the lambda-calculus can be seen as merging the best of call-by-name and call-by-value, namely the wise erasing behaviour of the former and the wise duplicating behaviour of the latter. To better understand how duplication and erasure can be combined, we design a degenerated calculus, dubbed call-by-silly, that is symmetric to call-by-need in that it merges the worst of call-by-name and call-by-value, namely silly duplications by-name and silly erasures by-value. We validate the design of the call-by-silly calculus via rewriting properties and multi types. In particular, we mirror the main theorem about call-by-need -- that is, its operational equivalence with call-by-name -- showing that call-by-silly and call-by-value induce the same contextual equivalence. This fact shows the blindness with respect to efficiency of call-by-value contextual equivalence. We also define a call-by-silly strategy and a call-by-silly abstract machine implementing the strategy. Moreover, we measure the number of steps taken by the strategy via tight multi types. Lastly, we prove that the call-by-silly strategy computes evaluation sequences of maximal length in the calculus.

fields

cs.LO 1

years

2024 1

verdicts

UNVERDICTED 1

representative citing papers

Mirroring Call-by-Need, or Values Acting Silly

cs.LO · 2024-02-19 · unverdicted · novelty 6.0

Defines a new call-by-silly calculus mirroring call-by-need, proves it shares contextual equivalence with call-by-value, and shows its strategy computes maximal-length sequences via multi types and rewriting.

citing papers explorer

Showing 1 of 1 citing paper.

  • Mirroring Call-by-Need, or Values Acting Silly cs.LO · 2024-02-19 · unverdicted · none · ref 21 · internal anchor

    Defines a new call-by-silly calculus mirroring call-by-need, proves it shares contextual equivalence with call-by-value, and shows its strategy computes maximal-length sequences via multi types and rewriting.