gpt4 book ai didi

计数参数不一致,MPI_Bsend/MPI_Recieve

转载 作者:行者123 更新时间:2023-11-30 14:26:00 25 4
gpt4 key购买 nike

在示例中找到here ,为什么第二条消息的计数不一致

if (rank == src) {
/* These message sizes are chosen to expose any alignment problems */
MPI_Bsend( msg1, 7, MPI_CHAR, dest, tag, comm );
MPI_Bsend( msg2, 2, MPI_DOUBLE, dest, tag, comm );
MPI_Bsend( msg3, 17, MPI_CHAR, dest, tag, comm );
}

if (rank == dest) {
MPI_Recv( rmsg1, 7, MPI_CHAR, src, tag, comm, MPI_STATUS_IGNORE );
MPI_Recv( rmsg2, 10, MPI_DOUBLE, src, tag, comm, MPI_STATUS_IGNORE );
MPI_Recv( rmsg3, 17, MPI_CHAR, src, tag, comm, MPI_STATUS_IGNORE );
if (strcmp( rmsg1, msg1 ) != 0) {
errs++;
fprintf( stderr, "message 1 (%s) should be %s\n", rmsg1, msg1 );fflush(stderr);
}

为什么发送和接收的计数不一致?

最佳答案

Recv 的 count 参数只是要接收的数据量的上限。如果我们在编译时不知道有效负载的大小,这会很方便。第二个 Recv 完成后,rmsg2 将包含两个 double 值,然后是一些未初始化的数据。

关于计数参数不一致,MPI_Bsend/MPI_Recieve,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9710508/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com