Loop invariants: Analysis, classification, and examples

CA Furia, B Meyer, S Velder - ACM Computing Surveys (CSUR), 2014 - dl.acm.org
CA Furia, B Meyer, S Velder
ACM Computing Surveys (CSUR), 2014dl.acm.org
Software verification has emerged as a key concern for ensuring the continued progress of
information technology. Full verification generally requires, as a crucial step, equipping each
loop with a “loop invariant.” Beyond their role in verification, loop invariants help program
understanding by providing fundamental insights into the nature of algorithms. In practice,
finding sound and useful invariants remains a challenge. Fortunately, many invariants seem
intuitively to exhibit a common flavor. Understanding these fundamental invariant patterns …
Software verification has emerged as a key concern for ensuring the continued progress of information technology. Full verification generally requires, as a crucial step, equipping each loop with a “loop invariant.” Beyond their role in verification, loop invariants help program understanding by providing fundamental insights into the nature of algorithms. In practice, finding sound and useful invariants remains a challenge. Fortunately, many invariants seem intuitively to exhibit a common flavor. Understanding these fundamental invariant patterns could therefore provide help for understanding and verifying a large variety of programs.
We performed a systematic identification, validation, and classification of loop invariants over a range of fundamental algorithms from diverse areas of computer science. This article analyzes the patterns, as uncovered in this study, governing how invariants are derived from postconditions; it proposes a taxonomy of invariants according to these patterns; and it presents its application to the algorithms reviewed. The discussion also shows the need for high-level specifications based on “domain theory.” It describes how the invariants and the corresponding algorithms have been mechanically verified using an automated program prover; the proof source files are available. The contributions also include suggestions for invariant inference and for model-based specification.
ACM Digital Library