如何使用MPI_Abort()来终止其他处理器

时间:2016-09-18 17:30:58

标签: c parallel-processing mpi

在MPI中,MPI_Abort()主要用于中止异常行为。在下面的程序中,在每次迭代时,ROOT进程检查条件,而剩余的处理器在MPI_Barrier等待接收下一次迭代的数据。因此,如果满足阈值,我希望root终止整个循环,并且其他处理器应该离开循环并终止。我的问题是:使用MPI_Abort()是否有意义,以便在屏障中等待的处理器将终止?

void kmeans() {

    do{
        // Step1: ROOT Broadcast the K centroids.
        MPI_Bcast(&cluster_centroids, N, MPI_FLOAT, ROOT, MPI_COMM_WORLD);
        MPI_Barrier(MPI_COMM_WORLD);

        // Step2: Calculate the distances.
        points_assignment(data, cluster_center);

        // Step3: Update cluster centroid (Locally at each processor)
        update_centroids_locally();

        if(Rank == ROOT){
            // Step4: ROOT checks the threshold
            Flag = check_threshold(cluster_center);

            if(Flag == 1){
                // MPI_Abort(MPI_COMM_WORLD,0);
                break;
            }else{
                continue;
            }
        }

    } while(1);

}

1 个答案:

答案 0 :(得分:1)

为了避免使用MPI_Abort,我可以考虑两种终止选项:

1)简单的一个:每次广播一个终止标志,每个进程将根据该标志继续或停止。

2)您可以使用两个MPI_IBcastMPI_Waitany。使用一个MPI_IBcast,您将广播您的cluster_centroids,而另一个广播您将广播终止标志。每次您检查广播已完成并基于此,每个过程将决定继续或停止。