English

Recurrence Extraction for Functional Programs through Call-by-Push-Value (Extended Version)

Programming Languages 2019-11-13 v1 Logic in Computer Science

Abstract

The main way of analyzing the complexity of a program is that of extracting and solving a recurrence that expresses its running time in terms of the size of its input. We develop a method that automatically extracts such recurrences from the syntax of higher-order recursive functional programs. The resulting recurrences, which are programs in a call-by-name language with recursion, explicitly compute the running time in terms of the size of the input. In order to achieve this in a uniform way that covers both call-by-name and call-by-value evaluation strategies, we use Call-by-Push-Value (CBPV) as an intermediate language. Finally, we use domain theory to develop a denotational cost semantics for the resulting recurrences.

Keywords

Cite

@article{arxiv.1911.04588,
  title  = {Recurrence Extraction for Functional Programs through Call-by-Push-Value (Extended Version)},
  author = {G. A. Kavvos and Edward Morehouse and Daniel R. Licata and Norman Danner},
  journal= {arXiv preprint arXiv:1911.04588},
  year   = {2019}
}

Comments

POPL 2020