- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我的程序的最基本功能,因此不一定是可重现的。但是,我想知道是否有一种方法可以使用 MPI 发送数组数组?或者这是不可能的事情,我应该展平我的阵列?任何帮助将不胜感激,因为我一直在努力解决这个问题。
int *individual_topIds;
int **cell_topIds;
cell_topIds = (int**) malloc(sizeof(int*)*25*boxes);
if(rank == 0) {
for (int i = 0; i < boxes; i++) {
individual_topIds = (int*) malloc(sizeof(int)*25);
for(int j = 0; j < cellMatrix[i].numTop; j++){
individual_topIds[j] = cellMatrix[i].aTopIds[j];
}
cell_topIds[i] = individual_topIds;
}
MPI_Send(cell_topIds, boxes*25, MPI_INT, 1, 10, MPI_COMM_WORLD);
}
然后在我的排名==1部分。我尝试过仅使用盒子发送和接收,也尝试过不使用盒子*25。
for 1 -> boxes
MPI_Recv(cell_topIds, boxes*25, MPI_INT, 0, 10, MPI_COMM_WORLD, &status);
int *ptop;
ptop = (int*) malloc(sizeof(int)*25);
ptop = cell_topIds[i];
printf("1\n");
for(int j = 0; j < sizeof(&ptop)/sizeof(int); j++){
printf("%d, ", ptop[j]);
}
printf("2\n");
end for i -> boxes
free(ptop);
编辑:忘记提及打印的输出是段错误捕获错误:段错误(信号 11)
最佳答案
这不是一个措辞特别好的问题。
但是,如果您使用自定义类型,MPI 将允许您发送数组数组,如下所示:
#include "mpi.h"
#include <stdio.h>
struct Partstruct
{
char c;
double d[6];
char b[7];
};
int main(int argc, char *argv[])
{
struct Partstruct particle[1000];
int i, j, myrank;
MPI_Status status;
MPI_Datatype Particletype;
MPI_Datatype type[3] = { MPI_CHAR, MPI_DOUBLE, MPI_CHAR };
int blocklen[3] = { 1, 6, 7 };
MPI_Aint disp[3];
MPI_Init(&argc, &argv);
disp[0] = &particle[0].c - &particle[0];
disp[1] = &particle[0].d - &particle[0];
disp[2] = &particle[0].b - &particle[0];
MPI_Type_create_struct(3, blocklen, disp, type, &Particletype);
MPI_Type_commit(&Particletype);
MPI_Comm_rank(MPI_COMM_WORLD, &myrank);
if (myrank == 0)
{
MPI_Send(particle, 1000, Particletype, 1, 123, MPI_COMM_WORLD);
}
else if (myrank == 1)
{
MPI_Recv(particle, 1000, Particletype, 0, 123, MPI_COMM_WORLD, &status);
}
MPI_Finalize();
return 0;
}
或者,使用平面阵列设计(出于性能原因以及与 MPI 的轻松兼容性,这是一个好主意)。
关于可以使用 MPI_Send 和 MPI_Recv 发送数组内的数组吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59077556/
在下面的代码中,如果我没有将它声明为参数(我通常不能这样做),则 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 ,结果会出现段错误。为什
我是一名优秀的程序员,十分优秀!