dpor: A generic implementation of dynamic partial-order reduction (DPOR) for testing arbitrary models of concurrency.

[ deprecated, library, mit, testing ] [ Propose Tags ]
Deprecated in favor of dejafu

We can characterise the state of a concurrent computation by considering the ordering of dependent events. This is a partial order: independent events can be performed in any order without affecting the result. DPOR is a technique for computing these partial orders at run-time, and only testing one total order for each partial order. This cuts down the amount of work to be done significantly. In particular, this package implemented bounded partial-order reduction, which is a further optimisation. Only schedules within some *bound* are considered.

  • DPOR with no schedule bounding is complete, it will find all distinct executions!

  • DPOR with schedule bounding is incomplete, it will only find all distinct executions within the bound!

Caution: The fundamental assumption behind DPOR is that the *only* source of nondeterminism in your program is the scheduler. Or, to put it another way, if you execute the same program with the same schedule twice, you get the same result. If you are using this library in combination with something which performs I/O, be *very* certain that this is the case!

See the README for more details.

For details on the algorithm, albeit presented in a very imperative way, see Bounded partial-order reduction, K. Coons, M. Musuvathi, and K. McKinley (2013), available at http://research.microsoft.com/pubs/202164/bpor-oopsla-2013.pdf


Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees


  • No Candidates
Versions [RSS],,
Dependencies base (>=4.8 && <5), containers (>=0.5 && <0.6), deepseq (>=1.3 && <1.5), random (>=1.0 && <1.2), semigroups (>=0.16 && <0.19) [details]
License MIT
Author Michael Walker
Maintainer mike@barrucadu.co.uk
Category Testing
Home page https://github.com/barrucadu/dejafu
Source repo head: git clone https://github.com/barrucadu/dejafu.git
this: git clone https://github.com/barrucadu/dejafu.git(tag dpor-
Uploaded by barrucadu at 2016-06-06T19:42:19Z
Reverse Dependencies 2 direct, 32 indirect [details]
Downloads 2490 total (7 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs available [build log]
Last success reported on 2016-06-06 [all 1 reports]