4.数据类型 mpi.docx

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
4.数据类型 mpi

数据类型数据类型的分类MPI的消息类型分为两种:预定义类型和派生数据类型(Derived Data Type)预定义数据类型:MPI支持异构计算(Heterogeneous Computing),它指在不同计算机系统上运行程序,每台计算可能有不同生产厂商,不同操作系统。—MPI通过提供预定义数据类型来解决异构计算中的互操作性问题,建立它与具体语言的对应关系。派生数据类型:MPI引入派生数据类型来定义由数据类型不同且地址空间不连续的数据项组成的消息。类型图用于描述在内存当中整个数据的构成的图像由于不同的类型有不同的对齐位置的要求,e就是能够使类型图的跨度满足该类型的类型表中的所有的类型都能达到下一个对齐要求所需要的最小非负整数值。假设type={(double,0),(char,8)}(一个double型的值在偏移0,后面在偏移8处跟一个字符值)。进一步假设double型的值必须严格分配到地址为8的倍数的存储空间。则该数据类型的extent是16(从9循环到下一个8的倍数)。一个由一个字符或面紧跟一个双精度值的数据类型,其extent也是16。创建不同数据类型函数调用复制数据类型(创建连续数据类型)————PPT30intMPI_Type_contiguous(intcount,MPI_Datatypeoldtype, MPI_Datatype *newtype)IN count 复制个数(非负整数)IN oldtype原有数据类型(句柄)OUT newtype新数据类型(句柄)示例:代码009_datatype向量数据类型intMPI_Type_vector(intcount,intlocklength,int stride, MPI_Datatypeoldtype,MPI_Datatype *newtype)IN count 块的数量(非负整数)IN blocklength每个块中所含元素个数(非负整数)IN stride 各块第一个元素之间相隔的元素个数(整数)IN oldtype旧数据类型(句柄)OUT newtypr新数据类型(句柄)向量数据类型示例代码009_datatype3、索引类型————PPT31IntMPI_Type_indexed(intcount,int*array_of_blocklengths, int *array_of_displacements, MPI_Datatypeoldtype, MPI_Datatype *newtype)IN count 块的数量(整型)IN array_of_blocklengths每个块中所含元素个数(非负整数数组)IN array_of_displacements各块偏移值(整数数组)IN oldtype旧数据类型(句柄)OUT newtypr新数据类型(句柄)示例:课本P206 idxdatatype.c代码009_datatype4、结构数据类型————PPT32IntMPI_Type_struct(intcount,int*array_of_blocklengths,MPI_Aint *array_of_displacements, MPI_Datatype *array_of_types , MPI_Datatype *newtype)IN count 块的数量(整数)IN array_of_blocklengths每个块中所含元素个数(整数数组)IN array_of_displacements各块偏移字节数(整数数组)IN array_of_types原有数据类型句柄数组)OUT newtypr新数据类型(句柄)代码示例:代码009_datatypestructs5、重新分配大小——————PPT33IntMPI_Type_create_resized(MPI_Datatypeoldtype,MPI_Aintlb, MPI_Aint extent, MPI_Datatype * newtype)IN oldtype旧数据类型IN lb新的下界IN extent 新的跨度OUT newtype新数据类型示例代码:源码\typesize.c其他函数PPT打包和解包 PPT34打包(Pack)和解包(Unpack)操作是为了发送不连续的数据,在发送前显式地把数据包装到一个连续的缓冲区,在接收之后从连续缓冲区中解包intMPI_Pack(void* inbuf, intincount, MPI_datatype, void *outbuf, intoutcount, int *position, MPI_Commcomm)IN inbuf输入缓冲区起始地址(可选数据类型)[inbuf可以是MPI_Send允许的任何通信缓冲区]IN incount输

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档