Proving pointer programs in higher-order logic

Farhad Mehta, Tobias Nipkow

Research output: Contribution to journalArticlepeer-review

38 Scopus citations

Abstract

This paper develops sound modelling and reasoning methods for imperative programs with pointers: heaps are modelled as mappings from addresses to values, and pointer structures are mapped to higher-level data types for verification. The programming language is embedded in higher-order logic, its Hoare logic is derived. The whole development is purely definitional and thus sound. The viability of this approach is demonstrated with a non-trivial case study. We show the correctness of the Schorr-Waite graph marking algorithm and present part of the readable proof in Isabelle/HOL.

Fingerprint

Dive into the research topics of 'Proving pointer programs in higher-order logic'. Together they form a unique fingerprint.

Cite this