Proving Program Properties as First-Order Satisfiability
Abstract
Program semantics can often be expressed as a (many-sorted) first-order theory S, and program properties as sentences which are intended to hold in the canonical model of such a theory, which is often incomputable. Recently, we have shown that properties expressed as the existential closure of a boolean combination of atoms can be disproved by just finding a model of S and the negation of . Furthermore, this idea works quite well in practice due to the existence of powerful tools for the automatic generation of models for (many-sorted) first-order theories. In this paper we extend our previous result to arbitrary properties, expressed as sentences without any special restriction. Consequently, one can prove a program property by just finding a model of an appropriate theory (including S and possibly something else) and an appropriate first-order formula related to . Beyond its possible theoretical interest, we show that our results can also be of practical use in several respects.
Turn this paper into a lesson
ArcXiv compiles a structured reading guide from this paper's metadata: plain-English importance, contributions, prerequisite concepts, which sections to read first, flashcards, and a quiz. Grounded in the abstract, never invented.