MPI: 虚拟拓扑和近邻通信
admin
2024-03-16 02:36:43

Process Topologies & Neighborhood Communication

MPI通信域(Communicator)由进程组(Group of Processes)组成,进程组内进程从0开始按自然顺序依次被赋予唯一编号(rank),rank相当于本进程在组中的唯一身份(ID). MPI保证通信域内的任意进程对(i,j)之间,可以互相发送数据,整个进程内的所有进程组成一个连接图: 图中的顶点代表进程,顶点之间有边连接,所有的边是双通道的(即可发送数据,也可接收数据), 节点也可以给自身发送数据。

对于有些并行应用,自然的进程编号不是便利的,用户可以在已有的通信域上定义适合本身应用的进程之间链接关系(拓扑):每个进程定义自己的上下游数据交换进程,计算中可以和这些上下游进程进行数据交换。

虚拟拓扑是定义在通讯域上的进程命名规则。MPI实现中用一个图(graph)表示进程之间的连接关系: 图的节点(node)代表进程,有方向的边(edge)代表节点之间的连接关系,节点和节点之间可有多条有向边,每条边附有权重。


概念

名词解释备注
虚拟拓扑(virtual topology)
物理进程映射(physical mapping)

拓扑类型

拓扑类型解释备注
Cartesian多维规则Grid网格: hypercube或tori
Graph有向图Graph。边是有方向的,不一定是对称的:(i,j)边存在不保证(j,i)边存在;边有权重;两个顶点之间可有多条边连接
Distributed Graph和Graph相同,边带权重的有向图

函数

  • 生成函数

    函数解释备注
    MPI_CART_CREATE
    MPI_GRPAH_CREATE每个进程提供一致的全局图信息:顶点、边,进程和进程之间可以有多条边存在
    MPI_DIST_GRAPH_CREATE_ADJACENT定义本进程的上游(incoming,source)和下游(outgoing,dest)进程,可包含自身,每条边(edge)可定义权重
    MPI_DIST_GRAPH_CREATE每个进程定义图的一部分信息,每条边定义权重,带权重的多边超图
  • 查询函数

    函数解释备注
  • 近邻collective通信(Neighborhood Communication on Process Topologies)

    函数解释备注
    MPI_NEIGHBOR_ALLGATHER
    MPI_NEIGHBOR_ALLGATHERV
    MPI_NEIGHBOR_ALLTOALL
    MPI_NEIGHBOR_ALLTOALLV
    MPI_NEIGHBOR_ALLTOALLW允许发送接收不同数据类型(different datatypes)

    每个函数对应一个非阻塞版本(Nonblocking Neighborhood Communication),和长连接函数(Persistent Neighborhood Communication)


参考资料

  • mpi40-report: 8 ProcessTopologies
  • MPI 3.0 Neighbourhood Collectives
  • MPI-3 学习笔记(三):混合编程与邻居集合通信

相关内容

热门资讯

摸鱼、钓虾、吃瓜、赏荷…初夏时... 这个周末,一场场充满野趣的“田园嘉年华”在沪郊金山多个农场上演,吸引众多市民带着孩子下乡来,赛跑、吃...
原创 戚... 5月28日,北京环球影城迎来了一对温暖的家庭画面:戚薇和李承铉携三岁半的儿子Seven现身游玩。现场...
滹沱河畔 遇见“诗和远方” 图为市民在滹沱河畔休闲娱乐。 初夏五月,惠风和畅。徜徉在石家庄滹沱河生态区(城区段),澄澈河水蜿蜒...
在迪士尼排队两小时,我才看清V... 文丨沈理 在网上看到一则新闻: 上海迪士尼,创极速光轮排队区。一个父亲牵着七八岁的儿子,已经在烈日...
重庆文旅喊你去吃火锅、观山水、... 本网讯(草原云·正北方网记者 马丽侠)火锅、机车、文创、演艺……5月28日下午,重庆市文化和旅游发展...