Complete First-Order Reasoning for Properties of Functional Programs

Published: 16 Oct 2023, Last Modified: 07 May 2026Proceedings of the ACM on Programming LanguagesEveryoneRevisionsCC BY-SA 4.0
Abstract: Several practical tools for automatically verifying functional programs (e.g., Liquid Haskell and Leon for Scala programs) rely on a heuristic based on unrolling recursive function definitions followed by quantifier-free reasoning using SMT solvers. We uncover foundational theoretical properties of this heuristic, revealing that it can be generalized and formalized as a technique that is in fact complete for reasoning with combined First-Order theories of algebraic datatypes and background theories, where background theories support decidable quantifier-free reasoning. The theory developed in this paper explains the efficacy of these heuristics when they succeed, explain why they fail when they fail, and the precise role that user help plays in making proofs succeed.
External IDs:doi:10.1145/3622835
Loading