Abstract
Motivated by applications in automated verification of higher-order functional programs, we develop a notion of constrained Horn clauses in higher-order logic and a decision problem concerning their satisfiability. We show that, although satisfiable systems of higher-order clauses do not generally have least models, there is a notion of canonical model obtained through a reduction to a problem concerning a kind of monotone logic program. Following work in higher-order program verification, we develop a refinement type system in order to reason about and automate the search for models. This provides a sound but incomplete method for solving the decision problem. Finally, we show that there is a sense in which we can use refinement types to express properties of terms whilst staying within the higher-order constrained Horn clause framework.
Original language | English |
---|---|
Article number | 11 |
Number of pages | 28 |
Journal | Proceedings of the ACM on Programming Languages |
Volume | 2 |
Issue number | POPL |
Early online date | 27 Dec 2017 |
DOIs | |
Publication status | Published - 1 Jan 2018 |
Research Groups and Themes
- Programming Languages