gpt4 book ai didi

c - MPI 向工作人员发送信息时出现问题

转载 作者:行者123 更新时间:2023-11-30 14:29:19 24 4
gpt4 key购买 nike

在 MPI 程序中,我想将信息传输给工作人员,但遇到问题:

    Number of worker tasks = 4
sending 1-th element q=0.011000 to task 1
received 1-th element q=0.000000 in task 108827872
sending 2-th element q=0.012000 to task 2
sending 3-th element q=0.013000 to task 3
received 2-th element q=0.000000 in task 1353735488
sending 4-th element q=0.014000 to task 4
received 3-th element q=0.000000 in task -1900924208
received 4-th element q=0.000000 in task -1215863168

很可能我没有进行正确的消息传递,你知道错误可能出在哪里吗?

#include "mpi.h"               /* required MPI library */
#include <stdio.h>
#include <math.h>

#define NRRR 16 /* number of rows in matrix A */
#define NLLL 16 /* number of columns in matrix A */
#define MASTER 0 /* taskid of first task */
#define FROM_MASTER 1 /* setting a message type */
#define FROM_WORKER 2 /* setting a message type */

int main(argc,argv)
int argc;
char *argv[];
{
int numtasks, /* number of tasks in partition */
taskid, /* a task identifier */
numworkers, /* number of worker tasks */
source, /* task id of message source */
dest, /* task id of message destination */
mtype,
i,j,
rc; /* message type */
double qr[NRRR],
ql[NLLL],
element_r[NRRR][3],
element_l[NLLL][3];


MPI_Status status;
rc = MPI_Init(&argc,&argv);
rc|= MPI_Comm_size(MPI_COMM_WORLD,&numtasks);
rc|= MPI_Comm_rank(MPI_COMM_WORLD,&taskid);

if (rc != 0)
printf ("error initializing MPI and obtaining task ID info\n");

numworkers = numtasks-1;

// MASTER
if (taskid == MASTER)
{
printf("\n\n\n\nNumber of worker tasks = %d\n",numworkers);

// init element_r and element_l
for(j=0;j<NRRR;j++){
element_r[j][0]=j;
element_r[j][1]=j+1;
element_r[j][2]=j+2;
qr[j] = j*1e-4+1e-3;
}

for(i=0;i<NLLL;i++){
element_l[i][0]=12000+i;
element_l[i][1]=12000+i+1;
element_l[i][2]=12000+i+2;
ql[i] = i*1e-3 +1e-2 ;
}

mtype = FROM_MASTER;
for (dest=1; dest<=numworkers; dest++)
{
printf(" sending %d-th element q=%f to task %d\n",dest,ql[dest],dest);
MPI_Send(&ql[dest], 1, MPI_DOUBLE, dest, mtype, MPI_COMM_WORLD);
}

}

// WORKER
if (taskid > MASTER)
{
mtype = FROM_MASTER;
MPI_Recv(&ql, 1, MPI_DOUBLE, MASTER, mtype, MPI_COMM_WORLD, &status);
printf(" received %d-th element q=%f in task %d\n",taskid,ql,taskid);

}

MPI_Finalize();
}

最佳答案

查看您的发送和接收,我没有发现任何问题。 Master 正在向每个工作器 N 发送 ql[N],该消息被接收并存储在 ql[0] 中。

看来您只是没有正确打印出来。

当我用以下内容替换工作循环时,我得到了合理的输出:

// WORKER
if (taskid != MASTER)
{
mtype = FROM_MASTER;
MPI_Recv(&ql, 1, MPI_DOUBLE, MASTER, mtype, MPI_COMM_WORLD, &status);
printf(" received %d-th element q=%f in task %d\n", taskid, ql[0], taskid);

}

运行示例:

$ mpiexec.exe -np 5 ./a.exe

Number of worker tasks = 4
sending 1-th element q=0.011000 to task 1
sending 2-th element q=0.012000 to task 2
received 1-th element q=0.011000 in task 1
sending 3-th element q=0.013000 to task 3
received 2-th element q=0.012000 in task 2
sending 4-th element q=0.014000 to task 4
received 3-th element q=0.013000 in task 3
received 4-th element q=0.014000 in task 4

顺便说一句,您当前正在做的事情是 MPI_Scatter被设计用于。 Examples here .

关于c - MPI 向工作人员发送信息时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4897391/

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