Liquidate your assets: Reasoning about resource usage in liquid haskell

21Citations
Citations of this article
8Readers
Mendeley users who have this article in their library.

Abstract

Liquid Haskell is an extension to the type system of Haskell that supports formal reasoning about program correctness by encoding logical properties as refinement types. In this article, we show how Liquid Haskell can also be used to reason about program efficiency in the same setting. We use the system's existing verification machinery to ensure that the results of our cost analysis are valid, together with custom invariants for particular program contexts to ensure that the results of our analysis are precise. To illustrate our approach, we analyse the efficiency of a wide range of popular data structures and algorithms, and in doing so, explore various notions of resource usage. Our experience is that reasoning about efficiency in Liquid Haskell is often just as simple as reasoning about correctness, and that the two can naturally be combined.

Cite

CITATION STYLE

APA

Handley, M. A. T., Vazou, N., & Hutton, G. (2020). Liquidate your assets: Reasoning about resource usage in liquid haskell. Proceedings of the ACM on Programming Languages, 4(POPL). https://doi.org/10.1145/3371092

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free