gpt4 book ai didi

c++ - MPI_Cart_Shift.Corner 邻域

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:37:11 24 4
gpt4 key购买 nike

enter image description here

我需要创建一个具有立方体拓扑结构的通信器,然后使用 MPI_Cart_Shift 在处于边缘的进程之间实现消息传递来选择立方体的面。例如,我处理的等级为 0(R0),我的邻域是 R2、R4、R6(立方体的下表面)。我可以找到R2和R4,但我不明白如何找到R6。我的代码:

#include<mpi.h>
#include<stdio.h>

int main(int argc, char *argv[])
{
int rank, k;
int size;
int ndims = 3;
int source, dest;
int up,down,right,left,up3, down3;

int edges[6][4] = {{0,1,5,4},
{4,5,7,6},
{2,3,1,0},
{6,7,3,2},
{1,3,7,5},
{0,2,6,7}};

int t, incep=0;
char processor_name[MPI_MAX_PROCESSOR_NAME];

MPI_Comm comm, comm3d;
int dims[3]={0,0,0}, coords[3]={0,0,0},
periods[3]={1,1,1}, reorder = 0;


MPI_Status status;


int user_edge;

MPI_Init(&argc, &argv);

MPI_Comm_size(MPI_COMM_WORLD, &size);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);

MPI_Dims_create(size, ndims, dims);


MPI_Cart_create(MPI_COMM_WORLD, ndims, dims, periods, reorder, &comm);


MPI_Cart_coords(comm, rank, 3, coords);

fflush(stdout);
printf("Rank %d coordinates are %d %d %d\n", rank, coords[0], coords[1], coords[2]);
MPI_Barrier(comm);

int leftrank, rightrank;
int downrank, uprank;

MPI_Comm_rank(comm, &rank);
MPI_Cart_coords(comm, rank, 2, coords);
MPI_Cart_shift(comm, 0, -1, &downrank, &uprank);
MPI_Sendrecv(buffer, 10, MPI_INT, downrank, 123, buffer2, 10, MPI_INT, uprank, 123, comm, &status);
MPI_Cart_shift(comm, 1, -1, &rightrank, &leftrank);
MPI_Sendrecv(buffer, 10, MPI_INT, leftrank, 123, buffer2, 10, MPI_INT, rightrank, 123, comm, &status);


printf("P:%d My neighbors are rightRank: %d downRank:%d leftRank:%d upRank:%d diagonal:%d diagonalX:%d\n", rank,rightrank,downrank,leftrank,uprank,diagonal,diagonalX);



MPI_Finalize();

return 0;

}

我会尝试添加像这样的东西 MPI_Cart_shift(comm, 2, 1, &diagonal, &diagonalX);但是对于 R0,它向我显示 R1,我明白了……我怎样才能得到角落街区?

最佳答案

您可以使用MPI_Cart_rank 来查找您需要的信息。

int MPI_Cart_rank(MPI_Comm comm, const int coords[], int *rank)

这里的 comm 是一个笛卡尔拓扑结构的通信器。 coords 是一个整数数组(该数组的大小是笛卡尔拓扑的维数),包含过程的坐标(在您的例子中,R6 为 1,1,0)。然后输出 rank 将返回您可以在后续通信中使用的该进程的全局排名。

顺便说一句,MPI_Cart_coords 执行相反的方向,即从等级到坐标。

关于c++ - MPI_Cart_Shift.Corner 邻域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34190216/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com