English

Loop invariants: analysis, classification, and examples

Software Engineering 2014-01-14 v4

Abstract

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 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.

Keywords

Cite

@article{arxiv.1211.4470,
  title  = {Loop invariants: analysis, classification, and examples},
  author = {Carlo A. Furia and Bertrand Meyer and Sergey Velder},
  journal= {arXiv preprint arXiv:1211.4470},
  year   = {2014}
}
R2 v1 2026-06-21T22:40:53.734Z