Dzung Phan, Vinicius Lima
INFORMS 2023
Many fundamental multi-processor coordination problems can be expressed as counting problems: Processes must cooperate to assign successive values from a given range, such as addresses in memory or destinations on an interconnection network. Conventional solutions to these problems perform poorly because of synchronization bottlenecks and high memory contention. Motivated by observations on the behavior of sorting networks, we offer a new approach to solving such problems, by introducing counting networks, a new class of networks that can be used to count. We give two counting network constructions, one of depth log n1994/2 using n log (1 + logn)/4 “gates,” and a second of depth log2 n using n log2 n/2 gates. These networks avoid the sequential bottlenecks inherent to earlier solutions and substantially lower the memory contention. Finally, to show that counting networks are not merely mathematical creatures, we provide experimental evidence that they outperform conventional synchronization techniques under a variety of circumstances. © 1994, ACM. All rights reserved.
Dzung Phan, Vinicius Lima
INFORMS 2023
S. Winograd
Journal of the ACM
Jehanzeb Mirza, Leonid Karlinsky, et al.
NeurIPS 2023
Albert Atserias, Anuj Dawar, et al.
Journal of the ACM