- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
所以我试图找出在 C 代码中使用 MPI 的处理器之间发送和接收信息的通信开销。
我需要在发送和接收中传递一个缓冲区,但我只想计算两个处理器之间进行通信需要多长时间。
这是我的全部代码:
main(int argc, char** argv){
int n;
int rank;
int time;
int i;
MPI_Status status;
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
if(rank == 0){
n = atoi(argv[1]);
printf("Size of data set = %d\n", n);
}
MPI_Bcast(&n, 1, MPI_INT, 0, MPI_COMM_WORLD);
for(i = 0; i < n; i++){
if(rank == 0){
MPI_Send(&n, 1, MPI_INT, 1, 0, MPI_COMM_WORLD);
}
else{
MPI_Recv(&n, 1, MPI_INT, 0, 1, MPI_COMM_WORLD, &status);
}
}
MPI_Barrier(MPI_COMM_WORLD);
time = clock();
printf("Time: %d\n", time);
MPI_Finalize();
}
我做了一些测试,我发现当我去掉 for 循环时,它按照我想要的方式工作。那么导致无限循环或段错误的 for 循环有什么问题呢?
最佳答案
有两个问题:
1) 代码中没有检查以确保它收到“数据集的大小”。如果您在没有有效命令行选项的情况下启动代码,它将出现段错误,或者根据您的系统,以不可预测的方式继续。
2) 发送和接收中的标签不匹配。标签必须匹配才能成功通信。如果没有匹配的标签,Recv 将永远等待直到找到匹配的发送。并发送等待直到找到匹配的接收。
将 MPI_COMM_WORLD 旁边的 receive 中的 1 更改为 0,代码将正常运行。
关于c - MPI_Send 和 MPI_Recv 开销,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2394448/
在下面的代码中,如果我没有将它声明为参数(我通常不能这样做),则 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 ,结果会出现段错误。为什
我是一名优秀的程序员,十分优秀!