二、MPI消息传递.PDF

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

第六讲 消息传递编程接口MPI 二、MPI 消息传递 1 MPI 消息传递 MPI 点对点通信类型 阻塞型和非阻塞型 MPI 消息发送模式 标准模式、缓冲模式、同步模式、就绪模式 MPI 聚合通信 多个进程间的通信 2 阻塞型和非阻塞型通信 阻塞型(blocking) 和非阻塞型(non blocking) 通信 阻塞型通信函数需要等待指定的操作实际完成,或所涉及 的数据被MPI 系统安全备份后才返回 阻塞型通信是非局部操作,它的完成可能涉及其它进程 MPI_SEND 和MPI_RECV 都是阻塞型的 非阻塞型通信函数总是立即返回,实际操作由MPI 后台 进行,需要调用其它函数来查询通信是否完成 非阻塞型通信是局部操作 在实际操作完成之前对相关数据区域的操作是不安全的 在有些并行系统上,使用非阻塞型函数可以实现计算与 通信的重叠进行 常用的非阻塞型通信函数为MPI_ISEND 和MPI_IRECV 3 非阻塞型发送函数 MPI_ISEND(buf,count,datatype,dest,tag,comm,request) 其中request 是输出参数,为请求句柄,以备将来查询, 其它参数含义与MPI_SEND 相同 在C 中request 的数据类型是MPI_Request ; 在FORTRAN 中request 为整型 int MPI_Isend(void *buf, int count, MPI_Datatype datatype, int dest, C int tag, MPI_Comm comm, MPI_Request *request) MPI_ISEND(BUF, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERR) F77 type BUF(*) INTEGER COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERR 4 非阻塞型接收函数 MPI_IRECV(buf,count,datatype,source,tag,comm,request) int MPI_Irecv(void *buf, int count, MPI_Datatype datatype, int source, C int tag, MPI_Comm comm, MPI_Request *request) MPI_IRECV(BUF, COUNT, DATATYPE, SOURCE, TAG, COMM, REQUEST, IERR) F77 type BUF(*) INTEGER COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERR 参数中没有status,消息的查询使用request 阻塞型/ 非阻塞型通信函数使用时要保持一致性!

文档评论(0)

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

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

1亿VIP精品文档

相关文档