- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
下面是一个简单的代码,它使用 Isend 将处理器 i 的数据发送到 i+1 并探测所有发送是否完成。
代码:
std::vector<double> sendbuffer;
int myrank, nprocs;
std::vector <MPI::Request> req_v;
MPI::Init ();
nprocs = MPI::COMM_WORLD.Get_size ();
myrank = MPI::COMM_WORLD.Get_rank ();
sendbuffer.resize(20000);
int startin = 0;
if(myrank != nprocs-1)
for (int i = myrank+1; i <= (myrank+1);i++)
{
int sendrank = i;
int msgtag = myrank * sendrank;
int msgsz = sendbuffer.size();
double *sdata = &(sendbuffer[startin]);
MPI::Request req;
req = MPI::COMM_WORLD.Isend (sdata, msgsz, MPI::DOUBLE, sendrank, msgtag);
req_v.push_back (req);
}
printf("Size-%d %d\n", myrank,(int) req_v.size());
if(req_v.size() > 0)
MPI::Request::Waitall (req_v.size(), &(req_v[0]));
printf("Over-%d\n", myrank);
MPI::COMM_WORLD.Barrier();
MPI::Finalize ();
代码在缓冲区大小为 1500 时完成,但在缓冲区大小为 20000 时停止。这种行为似乎有点奇怪。我认为 Isend 不需要匹配接收。请提出此行为的可能原因。
最佳答案
您从未真正收到消息。如果没有对 Recv(或 Irecv)的相应调用,发送调用可能永远不会完成。
您可以在 this 获取更多详细信息问题,但一般来说,只要消息可以在 MPI 中缓冲(在发送方或接收方),发送就可以在没有发布相应接收的情况下完成。最终,您的系统将耗尽缓冲区并且发送调用将停止完成,直到您调用相应的接收调用并释放一些系统缓冲区。
关于c++ - Isend 的奇怪行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24415041/
下面是一个简单的代码,它使用 Isend 将处理器 i 的数据发送到 i+1 并探测所有发送是否完成。 代码: std::vector sendbuffer; int myrank, nprocs;
本文整理了Java中cyclops.data.Zipper.isEnd()方法的一些代码示例,展示了Zipper.isEnd()的具体用法。这些代码示例主要来源于Github/Stackoverflo
需要澄清我对 Send Types 中给出的 isend 和 issend 的理解 我的理解是,一旦发送缓冲区空闲,即当所有数据都被释放时,isend 将返回。另一方面,Issend 仅在它从获取/未
本文整理了Java中bitronix.tm.internal.XAResourceHolderState.isEnded()方法的一些代码示例,展示了XAResourceHolderState.isE
我在使用 Isend 和 Ireceive 时遇到问题。我试图向所有其他处理器发送消息,然后从其他处理器接收相同类型的消息,这些处理器执行相同的 Isend 方法。 void msgs(int my_
在 related question 中我了解到执行 request = Isend(...);接收(...); request.Wait(); 不保证工作,因为 Isend 可能不会做任何事情,直到
我的 MPI_Isend 和 MPI_Irecv 代码块有问题。我需要将一个数字 Cin 发送到生产线上的下一个流程,然后当前流程才能处理它的业务。 接收进程需要接收才能继续计算,但是当我没有 MPI
一个看似愚蠢的问题,但我似乎无法以任何方式找到明确的答案。 基本问题是我是否需要为 MPI::Isend 提供相应的 MPI::Irecv? 也就是说,即使消息发送是非阻塞的,只要我在重用发送缓冲区之
当我使用 Send/Recv 时,我的代码可以工作,但是当我用 Isend/Irecv 替换 Send/Recv 时,它会产生段错误。但在去其他地方之前,我想验证一下以下代码片段是否看起来很重要。 其
当使用序列化数据对同一标签执行多个 isend/irecv 传输时,我发现 boost::mpi 出现了 MPI_ERR_TRUNCATE 错误。这些不是并发传输,即不涉及线程。同时只有不止一项未完成
我正在尝试并行生成导数矩阵。我有两个线程的整个热方程求解器,但现在我试图找出如何将底行发送到下一个级别的 rec2,并将顶行发送到上一个级别的 rec1。我试着弄乱请求矩阵中的数字,但没有任何效果。出
在我的矩阵加法代码中,我使用 ISend 和 Tag 1 将下限传输到其他进程,但是当我编译代码时,所有其他从属进程都声称具有相同的下限。我不明白为什么? 输出: I am process 1 and
我正在创建一个程序来使用 MPI 计算两个导体之间的电势。我正在使用非阻塞发送和接收,因此可以在处理器之间发送信息时进行计算。 但是,isend 和 irecv 之间的 if 语句以及包含计算的 wa
我是一名优秀的程序员,十分优秀!