• 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)

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


    参考资料
  • 相关阅读:
    trace-bpfcc
    Microsoft Visual Studio—常用快捷键
    vscode one dark和c扩展变量颜色冲突 设置settings.json如下即可
    IP地址、子网掩码、默认网关介绍及例题计算
    如何创建一个qt项目
    CSS 清除浮动
    git manual
    js-学习链表
    总结类体中的内容及其执行的先后顺序(学习中途总结)
    【Linux】权限管理
  • 原文地址:https://blog.csdn.net/weixin_42849849/article/details/128169034