Verification and falsification of programs with loops using predicate abstraction - Archive ouverte HAL Accéder directement au contenu
Article Dans Une Revue Formal Aspects of Computing Année : 2009

Verification and falsification of programs with loops using predicate abstraction

Résumé

Predicate abstraction is a major abstraction technique for the verification of software. Data is abstracted by means of Boolean variables, which keep track of predicates over the data. In many cases, predicate abstraction suffers from the need for at least one predicate for each iteration of a loop construct in the program. We propose to extract from the abstract model, and to parametrise the simulation instance in the number of loop iterations. We present a novel technique that speeds up the detection of long counterexamples as well as the verification of programs with loops.

Mots clés

Fichier principal
Vignette du fichier
PEER_stage2_10.1007%2Fs00165-009-0110-2.pdf (1.33 Mo) Télécharger le fichier
Origine : Fichiers produits par l'(les) auteur(s)
Loading...

Dates et versions

hal-00534924 , version 1 (11-11-2010)

Identifiants

Citer

Daniel Kroening, Georg Weissenbacher. Verification and falsification of programs with loops using predicate abstraction. Formal Aspects of Computing, 2009, 22 (2), pp.105-128. ⟨10.1007/s00165-009-0110-2⟩. ⟨hal-00534924⟩

Collections

PEER
47 Consultations
217 Téléchargements

Altmetric

Partager

Gmail Facebook X LinkedIn More