Download presentation
Presentation is loading. Please wait.
1
Collective Communication Operations
Adapted by Shirley Moore from Ananth Grama, Anshul Gupta, George Karypis, and Vipin Kumar, “Introduction to Parallel Computing”, Addison Wesley, 2003, Ch 4,6 UTEP CS5334/4390 March 23, 2017
2
Topic Overview Motivation for collective communication
One-to-All Broadcast and All-to-One Reduction All-to-All Broadcast and Reduction All-Reduce and Prefix-Sum Operations Scatter and Gather All-to-All Personalized Communication
3
Collective Communication: Motivation
Many interactions in practical parallel programs occur in well-defined patterns involving groups of processors. Efficient implementations of these operations can improve performance, reduce development effort and cost, and improve software quality. Efficient implementations leverage the underlying architecture.
4
Collective Communication: Assumptions
Group communication operations are built using point-to-point messaging primitives. Recall that communicating a message of size m over an uncongested network takes time ts +twm. Where necessary, we can take congestion into account explicitly by scaling the tw term. We assume that the network is bidirectional and that communication is single-ported.
5
One-to-All Broadcast and All-to-One Reduction
One processor has a piece of data (of size m) it needs to send to everyone. The dual of one-to-all broadcast is all-to-one reduction. In all-to-one reduction, each processor has m units of data. These data items must be combined piece-wise (using some associative operator, such as addition or min), and the result made available at a target processor.
6
One-to-All Broadcast and All-to-One Reduction
One-to-all broadcast and all-to-one reduction among processors.
7
Broadcast and Reduction: Example
Consider the problem of multiplying a matrix with a vector. The n x n matrix is assigned to an n x n (virtual) processor grid. The vector is assumed to be on the first row of processors. The first step of the product requires a one-to-all broadcast of the vector element along the corresponding column of processors. This can be done concurrently for all n columns. The processors compute the local product of the vector element and the local matrix entry. In the final step, the results of these products are accumulated to the first column using n concurrent all-to-one reduction operations along the rows (using the sum operation).
8
Broadcast and Reduction: Matrix-Vector Multiplication Example
One-to-all broadcast and all-to-one reduction in the multiplication of a 4 x 4 matrix with a 4 x 1 vector.
9
Question for Thought: Communication Cost?
What is the communication cost of an efficient implementation of one-to-all broadcast (all-to-one reduction)? Ignore network congestion
10
Cost Analysis The broadcast or reduction procedure involves log p point-to-point message steps, each at a time cost of ts + twm. The total parallel communication time is therefore given by:
11
MPI Collective Communication Operations
The barrier synchronization operation is performed in MPI using: int MPI_Barrier(MPI_Comm comm) The one-to-all broadcast operation is: int MPI_Bcast(void *buf, int count, MPI_Datatype datatype, int source, MPI_Comm comm) The all-to-one reduction operation is: int MPI_Reduce(void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, int target, MPI_Comm comm) See OpenMPI man pages for details
12
Predefined MPI Reduction Operations
13
Class Exercise: MPI_Reduce
Modify the Monte Carlo pi program from the Introduction to MPI class to use MPI_Reduce to aggregate the results.
14
All-to-All Broadcast and Reduction
Generalization of broadcast in which each processor is the source as well as destination. A process sends the same m-word message to every other process, but different processes may broadcast different messages.
15
All-to-All Broadcast and Reduction
All-to-all broadcast and all-to-all reduction.
16
MPI Collective Operations
MPI provides the MPI_Allgather function in which the data are gathered at all the processes – i.e., all-to-all broadcast int MPI_Allgather(void *sendbuf, int sendcount, MPI_Datatype senddatatype, void *recvbuf, int recvcount, MPI_Datatype recvdatatype, MPI_Comm comm) MPI provides the MPI_Reduce_scatter which is equivalent to a reduce followed by a scatter. int MPI_Reduce_scatter(const void *sendbuf, void *recvbuf, const int recvcounts[], MPI_Datatype datatype, MPI_Op op, MPI_Comm comm)
17
All-Reduce Operation In all-reduce, each node starts with a buffer of size m and the final results of the operation are identical buffers of size m on each node that are formed by combining the original p buffers using an associative operator. Identical to all-to-one reduction followed by a one-to-all broadcast (but this implementation is not the most efficient). Different from all-to-all reduction, in which p simultaneous all-to-one reductions take place, each with a different destination for the result.
18
The Prefix-Sum Operation
Given p numbers n0,n1,…,np-1 (one on each node), the problem is to compute the sums sk = ∑ik= 0 ni for all k between 0 and p-1 . Initially, nk resides on the node labeled k, and at the end of the procedure, the same node holds Sk.
19
MPI Collective Communication Operations
If the result of the reduction operation is needed by all processes, MPI provides: int MPI_Allreduce(void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm) To compute prefix-sums, MPI provides: int MPI_Scan(void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm)
20
Scatter and Gather In the scatter operation, a single node sends a unique message of size m to every other node (also called a one-to-all personalized communication). In the gather operation, a single node collects a unique message from each node. While the scatter operation is fundamentally different from broadcast, the algorithmic structure is similar, except for differences in message sizes (messages get smaller in scatter and stay constant in broadcast). The gather operation is exactly the inverse of the scatter operation and can be executed as such.
21
Gather and Scatter Operations
Scatter and gather operations.
22
Cost of Scatter and Gather
There are log p steps, in each step, the machine size halves and the data size halves. Thus the time for this operation is:
23
MPI Collective Operations
The gather operation is performed in MPI using: int MPI_Gather(void *sendbuf, int sendcount, MPI_Datatype senddatatype, void *recvbuf, int recvcount, MPI_Datatype recvdatatype, int target, MPI_Comm comm) The corresponding scatter operation is: int MPI_Scatter(void *sendbuf, int sendcount, int source, MPI_Comm comm)
24
All-to-All Personalized Communication
Each node has a distinct message of size m for every other node. This is unlike all-to-all broadcast, in which each node sends the same message to all other nodes. All-to-all personalized communication is also known as total exchange.
25
All-to-All Personalized Communication
26
All-to-All Personalized Communication: Example
Consider the problem of transposing a matrix. Each processor contains one full row of the matrix. The transpose operation in this case is identical to an all-to-all personalized communication operation.
27
All-to-All Personalized Communication: Example
All-to-all personalized communication in transposing a 4 x 4 matrix using four processes.
28
MPI Collective Operation
The all-to-all personalized communication operation is performed by: int MPI_Alltoall(void *sendbuf, int sendcount, MPI_Datatype senddatatype, void *recvbuf, int recvcount, MPI_Datatype recvdatatype, MPI_Comm comm)
29
Class Exercise Write an MPI program called rowsum to scatter the rows of a matrix from the root to all the processes, have each process compute the sum of its row, and gather the row sums back to the root process.
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.