繁体   English   中英

MPI多次发送和接收

[英]MPI Send and Receive Multiple Times

我正在尝试做一些MPI并行工作。 我可以在任何数量的处理器上运行它。 问题是每个处理器将执行一项作业,执行该作业,然后将其发回,然后程序完成。 我希望能够在完成后向处理器发送另一个作业。 林不知道如何实现这一点。 基本上,我正在尝试向每个核心发送10个职位。

if (myRank == 0) {
    int numCores = MPI::COMM_WORLD.Get_size();

    for (int rank = 1; rank < numCores; rank++) {
        MPI::COMM_WORLD.Send(&yarray[0], imax, MPI::DOUBLE, rank, 0);
        MPI::COMM_WORLD.Send(&tarray[0], imax, MPI::DOUBLE, rank, 0);

        MPI::COMM_WORLD.Recv(&ans, imax, MPI::DOUBLE, MPI::ANY_SOURCE, MPI_ANY_TAG, mystatus);
        answers[counter] = ans;
        counter++;
    }
}
else
{
    MPI::COMM_WORLD.Recv(&yarray1, imax, MPI::DOUBLE, MPI::ANY_SOURCE, MPI_ANY_TAG, mystatus);
    MPI::COMM_WORLD.Recv(&tarray1, imax, MPI::DOUBLE, MPI::ANY_SOURCE, MPI_ANY_TAG, mystatus);

    double floor = 0.5, ceiling = 3.5, range = (ceiling - floor);
    double rnd = floor + double((range * rand()) / (RAND_MAX + 1.0));

    yarray [0] = rnd;
    yarray1 [0] = rnd;

    double temp = 0;
    for (int k = 0; k < imax; k++) {
        tarray1[k+1] = tarray1[k] + h;
        yarray1[k+1] = yarray1[k] + h * (2 * yarray1[k] - 2 * tarray1[k] * tarray1[k] - 3);
    }
    temp = yarray1[int(imax)];

    //cout << "Rank = " << myRank << " Solution = " << temp << endl;

    MPI::COMM_WORLD.Send(&temp, 1, MPI::DOUBLE, 0, 0);

}

更新:在myrank内== 0

while(counter != jobs){
    MPI::COMM_WORLD.Recv(&ans, imax, MPI::DOUBLE, MPI::ANY_SOURCE, MPI_ANY_TAG, mystatus);
        answers[counter] = ans;
        counter++;
}

您需要从等级0到其他等级的某种反馈。 在其他职级将他们的工作返回到0级之后,他们应该收到一条新消息,告诉他们他们的下一个工作或没有更多的工作要完成。 队伍应该继续循环,直到没有更多的工作要做。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM