Full functional verification of linked data structures
Autor: | RinardMartin, KuncakViktor, ZeeKaren |
---|---|
Rok vydání: | 2008 |
Předmět: |
Source code
Correctness Theoretical computer science Java Computer science media_common.quotation_subject computer.software_genre Execution time data structures Computer Science::Logic in Computer Science Formal specification Implementation media_common computer.programming_language Reasoning system High-level verification Functional verification Programming language Runtime verification Linked data Data structure Computer Graphics and Computer-Aided Design Hash table Graph Range (mathematics) Automated theorem proving TheoryofComputation_MATHEMATICALLOGICANDFORMALLANGUAGES Proof theory Jahob Linked data structure verification computer Software |
Zdroj: | PLDI |
DOI: | 10.1145/1375581.1375624 |
Popis: | We present the first verification of full functional correctness for a range of linked data structure implementations, including mutable lists, trees, graphs, and hash tables. Specifically, we present the use of the Jahob verification system to verify formal specifications, written in classical higher-order logic, that completely capture the desired behavior of the Java data structure implementations (with the exception of properties involving execution time and/or memory consumption). Given that the desired correctness properties include intractable constructs such as quantifiers, transitive closure, and lambda abstraction, it is a challenge to successfully prove the generated verification conditions. Our Jahob verification system uses integrated reasoning to split each verification condition into a conjunction of simpler subformulas, then apply a diverse collection of specialized decision procedures, first-order theorem provers, and, in the worst case, interactive theorem provers to prove each subformula. Techniques such as replacing complex subformulas with stronger but simpler alternatives, exploiting structure inherently present in the verification conditions, and, when necessary, inserting verified lemmas and proof hints into the imperative source code make it possible to seamlessly integrate all of the specialized decision procedures and theorem provers into a single powerful integrated reasoning system. By appropriately applying multiple proof techniques to discharge different subformulas, this reasoning system can effectively prove the complex and challenging verification conditions that arise in this context. |
Databáze: | OpenAIRE |
Externí odkaz: |