首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用MPI_COMM_split后进程等级之间的关系

使用MPI_COMM_split后进程等级之间的关系
EN

Stack Overflow用户
提问于 2010-05-12 12:43:12
回答 2查看 2.6K关注 0票数 1

我使用MPI_Comm_split来拆分默认的MPI communicator.If,最初在默认通信器中有10个进程,比如MPI_COMM_WORLD,它们的级别由id_original标识。新的通信器由4个进程和id_original 6,7,8,9组成,这些进程将由新通信器中的id_new定义。这两个传播者之间的过程等级之间的关系是什么?id_original 6,7,8,9的进程会有新的等级0,1,2,3 在新的通信器中,还是排序可能不同?

EN

回答 2

Stack Overflow用户

发布于 2010-05-12 14:12:29

您应该使用拆分的"key“参数来控制新通信器中的顺序。例如,您可以使用MPI_Comm_world中的级别(或"id_original")作为键,如下所示:

代码语言:javascript
复制
MPI_Comm_split( MPI_COMM_WORLD, id_original >= 6 && id_original <= 9,
                id_original, &newComm ); 
票数 1
EN

Stack Overflow用户

发布于 2010-05-13 15:20:08

根据 (由我强调):

在每个子组中,进程按照参数键的值定义的顺序排列,根据其在旧组中的排名而被打破。

因此,如果进程6-9为key提供了相同的值,那么它们将分别在新的通信器中获得0-3的等级。但是,如果这对程序的正确性至关重要,那么您应该使用Edric的方法在代码中显式地显示这种安排。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2818833

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档