gpt4 book ai didi

c++ - 通过 MPI 发送和接收二维数组

转载 作者:太空宇宙 更新时间:2023-11-04 04:19:49 27 4
gpt4 key购买 nike

我要解决的问题如下:

我的 C++ 串行代码计算了一个大型二维矩阵。为了优化这个过程,我希望拆分这个大的 2D 矩阵并使用 MPI 在 4 个节点(比如说)上运行。节点之间发生的唯一通信是在每个时间步结束时共享边值。每个节点与其邻居共享边数组数据 A[i][j]。

根据对 MPI 的阅读,我有以下方案要实现。

if (myrank == 0)
{
for (i= 0 to x)
for (y= 0 to y)
{
C++ CODE IMPLEMENTATION
....
MPI_SEND(A[x][0], A[x][1], A[x][2], Destination= 1.....)
MPI_RECEIVE(B[0][0], B[0][1]......Sender = 1.....)
MPI_BARRIER
}

if (myrank == 1)
{
for (i = x+1 to xx)
for (y = 0 to y)
{
C++ CODE IMPLEMENTATION
....
MPI_SEND(B[x][0], B[x][1], B[x][2], Destination= 0.....)
MPI_RECEIVE(A[0][0], A[0][1]......Sender = 1.....)
MPI BARRIER
}

我想知道我的方法是否正确,也希望对其他 MPI 函数的任何指导以及实现方面的研究表示感谢。

谢谢,阿什温。

最佳答案

只是为了进一步强调 Joel 的观点:

如果你分配你的数组使得它们是连续的(C 的“多维数组”不会自动给你:),这会容易得多:)

int **alloc_2d_int(int rows, int cols) {
int *data = (int *)malloc(rows*cols*sizeof(int));
int **array= (int **)malloc(rows*sizeof(int*));
for (int i=0; i<rows; i++)
array[i] = &(data[cols*i]);

return array;
}

/*...*/
int **A;
/*...*/
A = alloc_2d_init(N,M);

然后,您可以使用

发送和接收整个 NxM 数组
MPI_Send(&(A[0][0]), N*M, MPI_INT, destination, tag, MPI_COMM_WORLD);

完成后,使用

释放内存
free(A[0]);
free(A);

另外,MPI_Recv 是一个阻塞接收,MPI_Send 可以是一个阻塞发送。根据 Joel 的观点,这意味着您绝对不需要 Barriers。此外,这意味着如果您有上述发送/接收模式,您可能会陷入僵局——每个人都在发送,没有人在接收。更安全的是:

if (myrank == 0) {
MPI_Send(&(A[0][0]), N*M, MPI_INT, 1, tagA, MPI_COMM_WORLD);
MPI_Recv(&(B[0][0]), N*M, MPI_INT, 1, tagB, MPI_COMM_WORLD, &status);
} else if (myrank == 1) {
MPI_Recv(&(A[0][0]), N*M, MPI_INT, 0, tagA, MPI_COMM_WORLD, &status);
MPI_Send(&(B[0][0]), N*M, MPI_INT, 0, tagB, MPI_COMM_WORLD);
}

另一种更通用的方法是使用 MPI_Sendrecv:

int *sendptr, *recvptr;
int neigh = MPI_PROC_NULL;

if (myrank == 0) {
sendptr = &(A[0][0]);
recvptr = &(B[0][0]);
neigh = 1;
} else {
sendptr = &(B[0][0]);
recvptr = &(A[0][0]);
neigh = 0;
}
MPI_Sendrecv(sendptr, N*M, MPI_INT, neigh, tagA, recvptr, N*M, MPI_INT, neigh, tagB, MPI_COMM_WORLD, &status);

或非阻塞发送和/或接收。

关于c++ - 通过 MPI 发送和接收二维数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47829456/

27 4 0
文章推荐: python - 在Python子进程中运行call()时出错
文章推荐: python - 有没有办法优化矩阵与一组样本的比较?
文章推荐: javascript - 谷歌地图不显示在 HTML
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com