Optimal parallel algorithms in the binary-forking model
Proceedings of the 32nd ACM Symposium on Parallelism in Algorithms and …, 2020•dl.acm.org
In this paper we develop optimal algorithms in the binary-forking model for a variety of
fundamental problems, including sorting, semisorting, list ranking, tree contraction, range
minima, and ordered set union, intersection and difference. In the binary-forking model,
tasks can only fork into two child tasks, but can do so recursively and asynchronously. The
tasks share memory, supporting reads, writes and test-and-sets. Costs are measured in
terms of work (total number of instructions), and span (longest dependence chain). The …
fundamental problems, including sorting, semisorting, list ranking, tree contraction, range
minima, and ordered set union, intersection and difference. In the binary-forking model,
tasks can only fork into two child tasks, but can do so recursively and asynchronously. The
tasks share memory, supporting reads, writes and test-and-sets. Costs are measured in
terms of work (total number of instructions), and span (longest dependence chain). The …
In this paper we develop optimal algorithms in the binary-forking model for a variety of fundamental problems, including sorting, semisorting, list ranking, tree contraction, range minima, and ordered set union, intersection and difference. In the binary-forking model, tasks can only fork into two child tasks, but can do so recursively and asynchronously. The tasks share memory, supporting reads, writes and test-and-sets. Costs are measured in terms of work (total number of instructions), and span (longest dependence chain).
The binary-forking model is meant to capture both algorithm performance and algorithm-design considerations on many existing multithreaded languages, which are also asynchronous and rely on binary forks either explicitly or under the covers. In contrast to the widely studied PRAM model, it does not assume arbitrary-way forks nor synchronous operations, both of which are hard to implement in modern hardware. While optimal PRAM algorithms are known for the problems studied herein, it turns out that arbitrary-way forking and strict synchronization are powerful, if unrealistic, capabilities. Natural simulations of these PRAM algorithms in the binary-forking model (i.e., implementations in existing parallel languages) incur an Ω(log n) overhead in span. This paper explores techniques for designing optimal algorithms when limited to binary forking and assuming asynchrony. All algorithms described in this paper are the first algorithms with optimal work and span in the binary-forking model. Most of the algorithms are simple. Many are randomized.
ACM Digital Library