\textsc{Diffy}: inductive reasoning of array programs using difference invariants

From MaRDI portal
Publication:832320

DOI10.1007/978-3-030-81688-9_42zbMATH Open1493.68101arXiv2105.14748OpenAlexW3183515470MaRDI QIDQ832320FDOQ832320


Authors: Supratik Chakraborty, Ashutosh Gupta, Divyesh Unadkat Edit this on Wikidata


Publication date: 25 March 2022

Abstract: We present a novel verification technique to prove interesting properties of a class of array programs with a symbolic parameter N denoting the size of arrays. The technique relies on constructing two slightly different versions of the same program. It infers difference relations between the corresponding variables at key control points of the joint control-flow graph of the two program versions. The desired post-condition is then proved by inducting on the program parameter N, wherein the difference invariants are crucially used in the inductive step. This contrasts with classical techniques that rely on finding potentially complex loop invaraints for each loop in the program. Our synergistic combination of inductive reasoning and finding simple difference invariants helps prove properties of programs that cannot be proved even by the winner of Arrays sub-category from SV-COMP 2021. We have implemented a prototype tool called diffy to demonstrate these ideas. We present results comparing the performance of diffy with that of state-of-the-art tools.


Full work available at URL: https://arxiv.org/abs/2105.14748




Recommendations



Cites Work


Cited In (3)

Uses Software





This page was built for publication: \textsc{Diffy}: inductive reasoning of array programs using difference invariants

Report a bug (only for logged in users!)Click here to report a bug for this page (MaRDI item Q832320)