MPI_Isend/MPI_Recv vs. MPI_Send/MPI_Irecv









up vote
1
down vote

favorite












For asynchronous communication in MPI which of the following is better (in terms of performance, reliability, readability, etc.):



  • MPI_Isend with buffer and then MPI_Iprobe & MPI_Recv once the receiver is ready, or

  • MPI_Irecv with buffer (such that there is always and MPI_Irecv posted with sufficient buffer) and then MPI_Send when the sender is ready?

The communication scenario is that data has to be exchanged asynchronously and the arrival times do not matter and both processes have workload. Only the overall performance (especially no blocking) is considered.



Below is a minimal working example (I did not include workload and the timings are thus probably not meaningful).



#include <mpi.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>

int main(int argc, char const *argv)
MPI_Init(NULL, NULL);
int world_size, world_rank;

MPI_Comm_size(MPI_COMM_WORLD, &world_size);
MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);

if (world_rank == 0 && world_size != 2)
fprintf(stderr, "This example requires two MPI processes.n");
MPI_Abort(MPI_COMM_WORLD, EXIT_FAILURE);


/* Non Blocking Send */
int buf[100] = 0;

MPI_Barrier(MPI_COMM_WORLD);
double time = MPI_Wtime();
if (world_rank == 1)
MPI_Request request;
MPI_Isend(buf, 100, MPI_INT, 0, 0, MPI_COMM_WORLD, &request);
MPI_Wait(&request, MPI_STATUS_IGNORE);
else
MPI_Recv(buf, 100, MPI_INT, 1, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE);

time = MPI_Wtime() - time;
printf("rank = %d, time = %f secn", world_rank, time);
MPI_Barrier(MPI_COMM_WORLD);

usleep(100);
if (world_rank == 0)
printf("---n");


/* Non Blocking Receive */
MPI_Barrier(MPI_COMM_WORLD);
time = MPI_Wtime();
if (world_rank == 1)
MPI_Send(buf, 100, MPI_INT, 0, 0, MPI_COMM_WORLD);
else
MPI_Request request;
MPI_Irecv(buf, 100, MPI_INT, 1, 0, MPI_COMM_WORLD, &request);
MPI_Wait(&request, MPI_STATUS_IGNORE);

time = MPI_Wtime() - time;
printf("rank = %d, time = %f secn", world_rank, time);
MPI_Barrier(MPI_COMM_WORLD);

MPI_Finalize();
return 0;



On my machine this generates:



rank = 0, time = 0.000035 sec
rank = 1, time = 0.000036 sec
---
rank = 0, time = 0.000035 sec
rank = 1, time = 0.000026 sec


Thank you already for your answers and have a nice day :)










share|improve this question







New contributor




Lukas Koestler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.



















  • The latter avoids unexpected messages (that could cause an increased memory usage). Also, keep in mind MPI_Send() might block if no matching receive has been posted. These are two reasons to go with the second option.
    – Gilles Gouaillardet
    21 hours ago














up vote
1
down vote

favorite












For asynchronous communication in MPI which of the following is better (in terms of performance, reliability, readability, etc.):



  • MPI_Isend with buffer and then MPI_Iprobe & MPI_Recv once the receiver is ready, or

  • MPI_Irecv with buffer (such that there is always and MPI_Irecv posted with sufficient buffer) and then MPI_Send when the sender is ready?

The communication scenario is that data has to be exchanged asynchronously and the arrival times do not matter and both processes have workload. Only the overall performance (especially no blocking) is considered.



Below is a minimal working example (I did not include workload and the timings are thus probably not meaningful).



#include <mpi.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>

int main(int argc, char const *argv)
MPI_Init(NULL, NULL);
int world_size, world_rank;

MPI_Comm_size(MPI_COMM_WORLD, &world_size);
MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);

if (world_rank == 0 && world_size != 2)
fprintf(stderr, "This example requires two MPI processes.n");
MPI_Abort(MPI_COMM_WORLD, EXIT_FAILURE);


/* Non Blocking Send */
int buf[100] = 0;

MPI_Barrier(MPI_COMM_WORLD);
double time = MPI_Wtime();
if (world_rank == 1)
MPI_Request request;
MPI_Isend(buf, 100, MPI_INT, 0, 0, MPI_COMM_WORLD, &request);
MPI_Wait(&request, MPI_STATUS_IGNORE);
else
MPI_Recv(buf, 100, MPI_INT, 1, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE);

time = MPI_Wtime() - time;
printf("rank = %d, time = %f secn", world_rank, time);
MPI_Barrier(MPI_COMM_WORLD);

usleep(100);
if (world_rank == 0)
printf("---n");


/* Non Blocking Receive */
MPI_Barrier(MPI_COMM_WORLD);
time = MPI_Wtime();
if (world_rank == 1)
MPI_Send(buf, 100, MPI_INT, 0, 0, MPI_COMM_WORLD);
else
MPI_Request request;
MPI_Irecv(buf, 100, MPI_INT, 1, 0, MPI_COMM_WORLD, &request);
MPI_Wait(&request, MPI_STATUS_IGNORE);

time = MPI_Wtime() - time;
printf("rank = %d, time = %f secn", world_rank, time);
MPI_Barrier(MPI_COMM_WORLD);

MPI_Finalize();
return 0;



On my machine this generates:



rank = 0, time = 0.000035 sec
rank = 1, time = 0.000036 sec
---
rank = 0, time = 0.000035 sec
rank = 1, time = 0.000026 sec


Thank you already for your answers and have a nice day :)










share|improve this question







New contributor




Lukas Koestler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.



















  • The latter avoids unexpected messages (that could cause an increased memory usage). Also, keep in mind MPI_Send() might block if no matching receive has been posted. These are two reasons to go with the second option.
    – Gilles Gouaillardet
    21 hours ago












up vote
1
down vote

favorite









up vote
1
down vote

favorite











For asynchronous communication in MPI which of the following is better (in terms of performance, reliability, readability, etc.):



  • MPI_Isend with buffer and then MPI_Iprobe & MPI_Recv once the receiver is ready, or

  • MPI_Irecv with buffer (such that there is always and MPI_Irecv posted with sufficient buffer) and then MPI_Send when the sender is ready?

The communication scenario is that data has to be exchanged asynchronously and the arrival times do not matter and both processes have workload. Only the overall performance (especially no blocking) is considered.



Below is a minimal working example (I did not include workload and the timings are thus probably not meaningful).



#include <mpi.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>

int main(int argc, char const *argv)
MPI_Init(NULL, NULL);
int world_size, world_rank;

MPI_Comm_size(MPI_COMM_WORLD, &world_size);
MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);

if (world_rank == 0 && world_size != 2)
fprintf(stderr, "This example requires two MPI processes.n");
MPI_Abort(MPI_COMM_WORLD, EXIT_FAILURE);


/* Non Blocking Send */
int buf[100] = 0;

MPI_Barrier(MPI_COMM_WORLD);
double time = MPI_Wtime();
if (world_rank == 1)
MPI_Request request;
MPI_Isend(buf, 100, MPI_INT, 0, 0, MPI_COMM_WORLD, &request);
MPI_Wait(&request, MPI_STATUS_IGNORE);
else
MPI_Recv(buf, 100, MPI_INT, 1, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE);

time = MPI_Wtime() - time;
printf("rank = %d, time = %f secn", world_rank, time);
MPI_Barrier(MPI_COMM_WORLD);

usleep(100);
if (world_rank == 0)
printf("---n");


/* Non Blocking Receive */
MPI_Barrier(MPI_COMM_WORLD);
time = MPI_Wtime();
if (world_rank == 1)
MPI_Send(buf, 100, MPI_INT, 0, 0, MPI_COMM_WORLD);
else
MPI_Request request;
MPI_Irecv(buf, 100, MPI_INT, 1, 0, MPI_COMM_WORLD, &request);
MPI_Wait(&request, MPI_STATUS_IGNORE);

time = MPI_Wtime() - time;
printf("rank = %d, time = %f secn", world_rank, time);
MPI_Barrier(MPI_COMM_WORLD);

MPI_Finalize();
return 0;



On my machine this generates:



rank = 0, time = 0.000035 sec
rank = 1, time = 0.000036 sec
---
rank = 0, time = 0.000035 sec
rank = 1, time = 0.000026 sec


Thank you already for your answers and have a nice day :)










share|improve this question







New contributor




Lukas Koestler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











For asynchronous communication in MPI which of the following is better (in terms of performance, reliability, readability, etc.):



  • MPI_Isend with buffer and then MPI_Iprobe & MPI_Recv once the receiver is ready, or

  • MPI_Irecv with buffer (such that there is always and MPI_Irecv posted with sufficient buffer) and then MPI_Send when the sender is ready?

The communication scenario is that data has to be exchanged asynchronously and the arrival times do not matter and both processes have workload. Only the overall performance (especially no blocking) is considered.



Below is a minimal working example (I did not include workload and the timings are thus probably not meaningful).



#include <mpi.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>

int main(int argc, char const *argv)
MPI_Init(NULL, NULL);
int world_size, world_rank;

MPI_Comm_size(MPI_COMM_WORLD, &world_size);
MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);

if (world_rank == 0 && world_size != 2)
fprintf(stderr, "This example requires two MPI processes.n");
MPI_Abort(MPI_COMM_WORLD, EXIT_FAILURE);


/* Non Blocking Send */
int buf[100] = 0;

MPI_Barrier(MPI_COMM_WORLD);
double time = MPI_Wtime();
if (world_rank == 1)
MPI_Request request;
MPI_Isend(buf, 100, MPI_INT, 0, 0, MPI_COMM_WORLD, &request);
MPI_Wait(&request, MPI_STATUS_IGNORE);
else
MPI_Recv(buf, 100, MPI_INT, 1, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE);

time = MPI_Wtime() - time;
printf("rank = %d, time = %f secn", world_rank, time);
MPI_Barrier(MPI_COMM_WORLD);

usleep(100);
if (world_rank == 0)
printf("---n");


/* Non Blocking Receive */
MPI_Barrier(MPI_COMM_WORLD);
time = MPI_Wtime();
if (world_rank == 1)
MPI_Send(buf, 100, MPI_INT, 0, 0, MPI_COMM_WORLD);
else
MPI_Request request;
MPI_Irecv(buf, 100, MPI_INT, 1, 0, MPI_COMM_WORLD, &request);
MPI_Wait(&request, MPI_STATUS_IGNORE);

time = MPI_Wtime() - time;
printf("rank = %d, time = %f secn", world_rank, time);
MPI_Barrier(MPI_COMM_WORLD);

MPI_Finalize();
return 0;



On my machine this generates:



rank = 0, time = 0.000035 sec
rank = 1, time = 0.000036 sec
---
rank = 0, time = 0.000035 sec
rank = 1, time = 0.000026 sec


Thank you already for your answers and have a nice day :)







mpi






share|improve this question







New contributor




Lukas Koestler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question







New contributor




Lukas Koestler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question






New contributor




Lukas Koestler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked 22 hours ago









Lukas Koestler

61




61




New contributor




Lukas Koestler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





Lukas Koestler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






Lukas Koestler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











  • The latter avoids unexpected messages (that could cause an increased memory usage). Also, keep in mind MPI_Send() might block if no matching receive has been posted. These are two reasons to go with the second option.
    – Gilles Gouaillardet
    21 hours ago
















  • The latter avoids unexpected messages (that could cause an increased memory usage). Also, keep in mind MPI_Send() might block if no matching receive has been posted. These are two reasons to go with the second option.
    – Gilles Gouaillardet
    21 hours ago















The latter avoids unexpected messages (that could cause an increased memory usage). Also, keep in mind MPI_Send() might block if no matching receive has been posted. These are two reasons to go with the second option.
– Gilles Gouaillardet
21 hours ago




The latter avoids unexpected messages (that could cause an increased memory usage). Also, keep in mind MPI_Send() might block if no matching receive has been posted. These are two reasons to go with the second option.
– Gilles Gouaillardet
21 hours ago

















active

oldest

votes











Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);






Lukas Koestler is a new contributor. Be nice, and check out our Code of Conduct.









 

draft saved


draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53204330%2fmpi-isend-mpi-recv-vs-mpi-send-mpi-irecv%23new-answer', 'question_page');

);

Post as a guest



































active

oldest

votes













active

oldest

votes









active

oldest

votes






active

oldest

votes








Lukas Koestler is a new contributor. Be nice, and check out our Code of Conduct.









 

draft saved


draft discarded


















Lukas Koestler is a new contributor. Be nice, and check out our Code of Conduct.












Lukas Koestler is a new contributor. Be nice, and check out our Code of Conduct.











Lukas Koestler is a new contributor. Be nice, and check out our Code of Conduct.













 


draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53204330%2fmpi-isend-mpi-recv-vs-mpi-send-mpi-irecv%23new-answer', 'question_page');

);

Post as a guest














































































Popular posts from this blog

𛂒𛀶,𛀽𛀑𛂀𛃧𛂓𛀙𛃆𛃑𛃷𛂟𛁡𛀢𛀟𛁤𛂽𛁕𛁪𛂟𛂯,𛁞𛂧𛀴𛁄𛁠𛁼𛂿𛀤 𛂘,𛁺𛂾𛃭𛃭𛃵𛀺,𛂣𛃍𛂖𛃶 𛀸𛃀𛂖𛁶𛁏𛁚 𛂢𛂞 𛁰𛂆𛀔,𛁸𛀽𛁓𛃋𛂇𛃧𛀧𛃣𛂐𛃇,𛂂𛃻𛃲𛁬𛃞𛀧𛃃𛀅 𛂭𛁠𛁡𛃇𛀷𛃓𛁥,𛁙𛁘𛁞𛃸𛁸𛃣𛁜,𛂛,𛃿,𛁯𛂘𛂌𛃛𛁱𛃌𛂈𛂇 𛁊𛃲,𛀕𛃴𛀜 𛀶𛂆𛀶𛃟𛂉𛀣,𛂐𛁞𛁾 𛁷𛂑𛁳𛂯𛀬𛃅,𛃶𛁼

ữḛḳṊẴ ẋ,Ẩṙ,ỹḛẪẠứụỿṞṦ,Ṉẍừ,ứ Ị,Ḵ,ṏ ṇỪḎḰṰọửḊ ṾḨḮữẑỶṑỗḮṣṉẃ Ữẩụ,ṓ,ḹẕḪḫỞṿḭ ỒṱṨẁṋṜ ḅẈ ṉ ứṀḱṑỒḵ,ḏ,ḊḖỹẊ Ẻḷổ,ṥ ẔḲẪụḣể Ṱ ḭỏựẶ Ồ Ṩ,ẂḿṡḾồ ỗṗṡịṞẤḵṽẃ ṸḒẄẘ,ủẞẵṦṟầṓế

⃀⃉⃄⃅⃍,⃂₼₡₰⃉₡₿₢⃉₣⃄₯⃊₮₼₹₱₦₷⃄₪₼₶₳₫⃍₽ ₫₪₦⃆₠₥⃁₸₴₷⃊₹⃅⃈₰⃁₫ ⃎⃍₩₣₷ ₻₮⃊⃀⃄⃉₯,⃏⃊,₦⃅₪,₼⃀₾₧₷₾ ₻ ₸₡ ₾,₭⃈₴⃋,€⃁,₩ ₺⃌⃍⃁₱⃋⃋₨⃊⃁⃃₼,⃎,₱⃍₲₶₡ ⃍⃅₶₨₭,⃉₭₾₡₻⃀ ₼₹⃅₹,₻₭ ⃌