Diffracting trees

  • Authors:
  • Nir Shavit;Asaph Zemach

  • Affiliations:
  • Tel-Aviv Univ., Tel-Aviv, Israel;Tel-Aviv Univ., Tel-Aviv, Israel

  • Venue:
  • ACM Transactions on Computer Systems (TOCS)
  • Year:
  • 1996

Quantified Score

Hi-index 0.02

Visualization

Abstract

Shared counters are among the most basic coordination structures in multiprocessor conputation, with applications ranging from barrier synchronization to concurrent-data-structure design. This article introduces diffracting trees, novel data structures for share counting and load balancing in a distributed/parallel environment. Empirical evidence, collected on a simulated distributed shared-memory machine and several simulated message-passing architectures, shows that diffracting trees scale better and are more robust than both combining trees and counting networks, currently the most effective known methods for implementing concurrent counters in software. The use of a randomized coordination method together with a combinatorial data structure overcomes the resiliency drawbacks of combining trees. Our simulations show that to handle the same load, diffracting trees and counting networks should have a similar width w, yet the depth of a diffracting tree is O(log w), whereas counting networks have depth O(log2 w). Diffracting trees have already been used to implement highly efficient producer/consumer queues, and we believe diffraction will prove to be an effective alternative paradigm to combining and queue-locking in the design of many concurrent data structures.