@inproceedings{cdd7a98e335e48ef89079a39339518f5,
title = "Inductive data flow graphs",
abstract = "The correctness of a sequential program can be shown by the annotation of its control flow graph with inductive assertions. We propose inductive data flow graphs, data flow graphs with incorporated inductive assertions, as the basis of an approach to verifying concurrent programs. An inductive data flow graph accounts for a set of dependencies between program actions in interleaved thread executions, and therefore stands as a representation for the set of concurrent program traces which give rise to these dependencies. The approach first constructs an inductive data flow graph and then checks whether all program traces are represented. The size of the inductive data flow graph is polynomial in the number of data dependencies (in a sense that can be made formal); it does not grow exponentially in the number of threads unless the data dependencies do. The approach shifts the burden of the exponential explosion towards the check whether all program traces are represented, i.e., to a combinatorial problem (over finite graphs).",
keywords = "concurrency, static analysis, verification",
author = "Azadeh Farzan and Zachary Kincaid and Andreas Podelski",
year = "2013",
doi = "10.1145/2429069.2429086",
language = "English (US)",
isbn = "9781450318327",
series = "Conference Record of the Annual ACM Symposium on Principles of Programming Languages",
pages = "129--142",
booktitle = "POPL 2013 - Proceedings of 40th Annual ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages",
note = "40th Annual ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages, POPL 2013 ; Conference date: 23-01-2013 Through 25-01-2013",
}