Predicate Abstraction with Under-approximation Refinement
Abstract
We propose an abstraction-based model checking method which relies on refinement of an under-approximation of the feasible behaviors of the system under analysis. The method preserves errors to safety properties, since all analyzed behaviors are feasible by definition. The method does not require an abstract transition relation to be generated, but instead executes the concrete transitions while storing abstract versions of the concrete states, as specified by a set of abstraction predicates. For each explored transition the method checks, with the help of a theorem prover, whether there is any loss of precision introduced by abstraction. The results of these checks are used to decide termination or to refine the abstraction by generating new abstraction predicates. If the (possibly infinite) concrete system under analysis has a finite bisimulation quotient, then the method is guaranteed to eventually explore an equivalent finite bisimilar structure. We illustrate the application of the approach for checking concurrent programs.
- Publication:
-
arXiv e-prints
- Pub Date:
- January 2007
- DOI:
- 10.48550/arXiv.cs/0701140
- arXiv:
- arXiv:cs/0701140
- Bibcode:
- 2007cs........1140P
- Keywords:
-
- Computer Science - Computer Science and Game Theory;
- D.2.4;
- F.3.1
- E-Print:
- 22 pages, 3 figures, accepted for publication in Logical Methods in Computer Science journal (special issue CAV 2005)