- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在多线程 程序中遇到MPI_Isend/MPI_Recv 问题。
在程序中:
第一台机器有一个线程做一些计算并调用MPI_Isend
将缓冲区发送到第二台机器,另一个线程总是试图MPI_Recv
来自第二台机器的数据。第一个线程将 MPI_Wait
它的最后一个 MPI_Isend
完成,然后再次调用 MPI_Isend
。
第二台机器做同样的事情。
然后我得到的结果是:
第一台机器:
线程0:MPI_Isend
数据成功到第二台机器。但在 MPI_Wait
中被阻止,因为最后一个 MPI_Isend
没有完成。
线程1:尝试从第二台机器MPI_Recv
数据,但是没有数据,它被阻塞了。
第二台机器:
线程0:MPI_Isend
数据成功到第一台机器。但在 MPI_Wait
中被阻止,因为最后一个 MPI_Isend
没有完成。
线程1:尝试从第一台机器MPI_Recv
数据,但是没有数据,它被阻塞了。
有人有什么想法吗?非常感谢,因为我已经跟踪了两天的问题,没有任何进展。
最佳答案
为了能够并发执行 MPI 调用,您必须初始化 MPI 库以支持 MPI_THREAD_MULTIPLE
级别的线程。为此,您必须将对 MPI_Init
的调用替换为:
int provided;
MPI_Init_thread(&argc, &argv, MPI_THREAD_MULTIPLE, &provided);
if (provided != MPI_THREAD_MULTIPLE)
{
printf("Sorry, this MPI implementation does not support multiple threads\n");
MPI_Abort(MPI_COMM_WORLD, 1);
}
一些 MPI 库必须以某种(非默认)方式编译,以支持来自多个线程的调用。例如,必须在库构建时配置 Open MPI。其他供应商提供两种版本的库 - 一种支持线程,另一种不支持线程,您必须在链接代码时选择正确的版本。这是因为添加对线程的支持会增加许多 MPI 调用的延迟,如果他的程序不使用线程,没有人希望出现这种情况。
关于c++ - 多线程程序中的MPI_Isend/MPI_Recv,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13722160/
在下面的代码中,如果我没有将它声明为参数(我通常不能这样做),则 xysize 的值会发生变化。它只发生在 gfortran 4.7.2 和 OpenMPI 1.6 中的优化 -O2 和更多。这怎么可
在下面的代码中,如果我没有将它声明为参数(我通常不能这样做),则 xysize 的值会发生变化。它只发生在 gfortran 4.7.2 和 OpenMPI 1.6 中的优化 -O2 和更多。这怎么可
所以我试图自己编写一个使用 MPI(OpenMPI 实现)的矩阵乘法。问题是,尽管通过 MPI_Send/MPI_Recv 将矩阵的一部分从主设备发送到从设备工作正常,但主进程中应该从从设备接收答案的
我有一个问题。假设我有 np 个进程。对于每个进程,我根据输入文件计算需要发送到每个其他进程的消息数量(从 0 到...),并且我想向它们发送这个数字。问题是我只能从通过直接连接的节点创建的拓扑发送。
为了简单起见,向上发送就是发送到rank+1,向下发送就是发送到rank-1 该代码将数组从一个节点发送到另一个节点,并在它们之间来回发送。这是代码: MPI_Request req1, req2;
是否可以将源列表传递给 MPI_Recv(或等效)调用?目前,我的代码看起来像这样: do i=nod1,nod2 call mpi_recv(tmp,n,MPI_REAL,MPI_ANY_S
我在多线程 程序中遇到MPI_Isend/MPI_Recv 问题。 在程序中: 第一台机器有一个线程做一些计算并调用MPI_Isend将缓冲区发送到第二台机器,另一个线程总是试图MPI_Recv 来自
我有邻接矩阵和以下代码: if (is_broadcast_message) { MPI_Send(&broadcast_message,1,MPI_INT,j,3,MPI_COMM_WORL
假设我有一个包含 2 个进程的 MPI 程序,等级 0 和等级 1。 int i[20], j[20], temp, size; 在排名为 0 的进程中,我有 for(temp=0; temp<20;
#include #include #include "mpi.h" int main(int argc, char **argv) { int N; scanf("%d", &N
我在一个与 MPI 开发相关的项目中遇到问题。我正在使用 MPI 实现 RNA 解析算法,在该算法中,我使用主节点根据一些解析规则和解析表(包含不同的状态和相关操作)开始解析输入字符串。在解析表中,每
更新版本 我发现了导致问题的部分,之前已在下面解释过。我也想跟大家分享一下我的情况。我意识到我犯的只是一个荒谬的错误。但是,我想知道即使我犯了如下大错误,这个问题是如何发生的; 我有一个结构定义如下;
当我链接我的 MPI C 程序时,出现以下错误:对 MPI_recv 的 undefined reference 。 我应该怎么做才能解决这个错误? 最佳答案 是MPI_Recv,不是MPI_recv
我在 C 中运行以下程序时遇到上述错误。它使用 MPI 库。 #include "mpi.h" #include #include int main (int argc, char *argv[]
我知道我可以使用 status.MPI_TAG 获取 MPI_Recv 消息的标记,如下所示: MPI_Recv(&buffer, 1, MPI_INT, MPI_ANY_SOURCE, MPI_AN
我正在尝试实现一个 MPI 程序,以迭代方式将数组中的每个元素设置为其自身及其邻居(在前一个时间步长上)的平均值,同时保持第一个和最后一个元素不变。对于一个过程,这很好用;然而,对于多进程,我没有得到
我正在开发一个 C++ 应用程序,我在其中使用 MPI C 绑定(bind)通过网络发送和接收数据。我明白发送 const int VECTOR_SIZE = 1e6; std::vector vec
我有一个 malloc 的整数数组,我用 MPI_Recv 填充它 MPI_Recv(d.current, n, MPI_INT, 0, TAG_CURRENT_ARRAY, MPI_COMM_WOR
对于MPI中的异步通信,以下哪个更好(在性能、可靠性、可读性等方面): MPI_Isend with buffer 然后 MPI_Iprobe & MPI_Recv 一旦接收器准备好,或者 带缓冲区的
我正在尝试将 NxN 矩阵的分区发送到不同的进程。我使用 MPI_Scatterv 成功完成此操作,如下面的代码所示,但如果我尝试使用 MPI_Send 和 MPI_Recv ,结果会出现段错误。为什
我是一名优秀的程序员,十分优秀!