Projects per year
Abstract
Dynamic Partial Order Reduction (DPOR) algorithms are used in stateless model checking of concurrent programs to avoid the exploration of equivalent execution sequences. In order to detect equivalence, DPOR relies on the notion of independence between execution steps. As this notion must be approximated, it can lose precision and thus treat execution steps as interfering when they are not. Our work is inspired by recent progress in the area that has introduced more accurate ways to exploit conditional notions of independence: Context-Sensitive DPOR considers two steps p and t independent in the current state if the states obtained by executing p⋅t and t⋅p are the same; Optimal DPOR with Observers makes their dependency conditional to the existence of future events that observe their operations. This article introduces a new algorithm, Optimal Context-Sensitive DPOR with Observers, that combines these two notions of conditional independence, and goes beyond them by exploiting their synergies. The implementation of our algorithm has been undertaken within the Nidhugg model checking tool. Our experimental evaluation, using benchmarks from the previous works, shows that our algorithm is able to effectively combine the benefits of both context-sensitive and observers-based independence and that it can produce exponential reductions over both of them.
Original language | English |
---|---|
Article number | 111730 |
Number of pages | 18 |
Journal | Journal of Systems and Software |
Volume | 202 |
DOIs | |
Publication status | Published - Aug 2023 |
Keywords
- Concurrent programs
- Partial order reduction
- Software verification
- Stateless model checking
Projects
- 1 Curtailed
-
Learning from learning solvers
Garcia De La Banda Garcia, M., Wallace, M. & Tack, G.
1/01/18 → 30/12/21
Project: Research