Affiliation:
1. University of Toronto, Toronto, Canada
2. University of Freiburg, Freiburg im Breisgau, Germany
Abstract
Commutativity
has proven to be a powerful tool in reasoning about concurrent programs. Recent work has shown that a commutativity-based
reduction
of a program may admit simpler proofs than the program itself. The framework of lexicographical program reductions was introduced to formalize a broad class of reductions which accommodate sequential (thread-local) reasoning as well as synchronous programs. Approaches based on this framework, however, were fundamentally limited to program models with a
fixed/bounded
number of threads. In this paper, we show that it is possible to define an effective parametric family of program reductions that can be used to find simple proofs for
parameterized programs
, i.e., for programs with an unbounded number of threads. We show that reductions are indeed useful for the simplification of proofs for parameterized programs, in a sense that can be made precise: A reduction of a parameterized program may admit a proof which uses
fewer
or
less sophisticated ghost variables
. The reduction may therefore be within reach of an automated verification technique, even when the original parameterized program is not. As our first technical contribution, we introduce a notion of reductions for parameterized programs such that the reduction
R
of a parameterized program
P
is again a parameterized program (the thread template of
R
is obtained by source-to-source transformation of the thread template of
P
). Consequently, existing techniques for the verification of parameterized programs can be directly applied to
R
instead of
P
. Our second technical contribution is that we define an appropriate family of
pairwise preference orders
which can be effectively used as a parameter to produce different lexicographical reductions. To determine whether this theoretical foundation amounts to a usable solution in practice, we have implemented the approach, based on a recently proposed framework for parameterized program verification. The results of our preliminary experiments on a representative set of examples are encouraging.
Publisher
Association for Computing Machinery (ACM)
Cited by
1 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. Commutativity Simplifies Proofs of Parameterized Programs;Proceedings of the ACM on Programming Languages;2024-01-05