Analysing the Complexity of Functional Programs: Higher-Order Meets First-Order (Long Version)
Abstract
We show how the complexity of higher-order functional programs can be analysed automatically by applying program transformations to a defunctionalized versions of them, and feeding the result to existing tools for the complexity analysis of first-order term rewrite systems. This is done while carefully analysing complexity preservation and reflection of the employed transformations such that the complexity of the obtained term rewrite system reflects on the complexity of the initial program. Further, we describe suitable strategies for the application of the studied transformations and provide ample experimental data for assessing the viability of our method.
- Publication:
-
arXiv e-prints
- Pub Date:
- June 2015
- DOI:
- arXiv:
- arXiv:1506.05043
- Bibcode:
- 2015arXiv150605043A
- Keywords:
-
- Computer Science - Logic in Computer Science;
- Computer Science - Computational Complexity;
- F.3.2
- E-Print:
- Long version of paper presented at ICFP 2015