MPI: 虚拟拓扑和近邻通信

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)

    请添加图片描述
    请添加图片描述
    请添加图片描述
    请添加图片描述
    请添加图片描述


参考资料
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值