Skip to content

Latest commit

 

History

History
21 lines (16 loc) · 914 Bytes

File metadata and controls

21 lines (16 loc) · 914 Bytes

Message chain

See the earlier message chain exercise for the description of the message chain.

Message chain with non-blocking communication

  1. Implement the program using non-blocking communication, i.e. MPI_Isend, MPI_Irecv, and MPI_Wait. Utilize MPI_PROC_NULL when treating the special cases of the first and the last task. You may start from scratch, or use the skeleton code or your solution from the earlier message chain exercise as a starting point.

  2. The skeleton code prints out the time spent in communication. Investigate the timings with different numbers of MPI tasks (e.g. 2, 4, 8, 16, ...). Compare the results to the implementation with MPI_Sends and MPI_Recv's and pay attention especially to rank 0. Can you explain the behaviour?

  3. Write a version that uses MPI_Waitall instead of MPI_Waits.