Ready, Set, Verify! Applying hs-to-coq to real-world Haskell code

7Citations
Citations of this article
14Readers
Mendeley users who have this article in their library.

Abstract

Good tools can bring mechanical verification to programs written in mainstream functional languages. We use hs-to-coq to translate significant portions of Haskell's containers library into Coq, and verify it against specifications that we derive from a variety of sources including type class laws, the library's test suite, and interfaces from Coq's standard library. Our work shows that it is feasible to verify mature, widely used, highly optimized, and unmodified Haskell code. We also learn more about the theory of weight-balanced trees, extend hs-to-coq to handle partiality, and - since we found no bugs - attest to the superb quality of well-tested functional code.

Cite

CITATION STYLE

APA

Breitner, J., Spector-Zabusky, A., Li, Y., Rizkallah, C., Wiegley, J., Cohen, J., & Weirich, S. (2021). Ready, Set, Verify! Applying hs-to-coq to real-world Haskell code. Journal of Functional Programming. https://doi.org/10.1017/S0956796820000283

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