mpi4py 中的数据类型解析

本文详细介绍了mpi4py库中关于数据类型的解析,包括方法接口如获取数据类型创建参数,属性如是否预定义数据类型,以及相关例程展示。内容涉及MPI-2新增的解析函数,用于获取数据布局和定义信息。
摘要由CSDN通过智能技术生成

本文从本人简书博客同步过来

上一篇中我们介绍了 mpi4py 中的通用化请求,下面我们将介绍 mpi4py 中的数据类型解析。

通过自定义数据类型,应用程序可任意指定数据在内存中的布局。在 MPI-1 中,一旦确定了数据类型定义,则定义的具体细节将无从获取。某些情况下,在数据类型定义完之后,仍有必要访问其定义流程、数据布局等信息,为此 MPI-2 提供了一些函数来解析定义数据类型过程的信息,如数据类型图,数据类型描述等。

方法接口

MPI.Datatype.Get_envelope(self)

获取创建数据类型的参数数量信息,返回值为一个 (num_integers, num_addresses, num_datatypes, combiner) 的四元 tuple,其中 num_integers 是数据类型创建函数使用整型参数的个数,num_addresses 是数据类型创建函数使用地址型参数的个数,num_datatypes 是数据类型创建函数使用原始数据类型的个数,combiner 是数据创建函数的类型,下表是常用的 combiner 取值和数据类型创建函数的对应关系:

combiner 取值 对应的数据类型创建函数
MPI.COMBINER_NAMED MPI 预定义数据类型,已命名
MPI.COMBINER_DUP MPI.Datatype.Dup
MPI.COMBINER_CONTIGUOUS MPI.Datatype.Create_contiguous
MPI.COMBINER_VECTOR MPI.Datatype.Create_vector
MPI.COMBINER_HVECTOR MPI.Datatype.Create_hvector
MPI.COMBINER_INDEXED MPI.Datatype.Create_indexed
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值