We give optimally fast O(logp) time (per processor) algorithms for computing round-optimal broadcast schedules for message-passing parallel computing systems. This affirmatively answers the questions posed in Träff (2022). The problem is to broadcast n indivisible blocks of data from a given root processor to all other processors in a (subgraph of a) fully connected network of p processors with fully bidirectional, one-ported communication capabilities. In this model, nâ1+âlogâpâ communication rounds are required. Our new algorithms compute for each processor in the network receive and send schedules each of size âlogâpâ that determine uniquely in O(1) time for each communication round the new block that the processor will receive, and the already received block it has to send. Schedule computations are done independently per processor without communication. The broadcast communication subgraph is the same, easily computable, directed, âlogâpâ-regular circulant graph used in Träff (2022) and elsewhere. We show how the schedule computations can be done in optimal time and space of O(logp), improving significantly over previous results of O(plog²p) and O(logÂłp). The schedule computation and broadcast algorithms are simple to implement, but correctness and complexity are not obvious. All algorithms have been implemented, compared to previous algorithms, and briefly evaluated on a small 36Ă32 processor-core cluster.
en
Research Areas:
Computer Engineering and Software-Intensive Systems: 90% Computer Science Foundations: 10%