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.
CITATION STYLE
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
Mendeley helps you to discover research relevant for your work.