mpi4py 点到点通信之非阻塞通信

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

上一篇中我们介绍了 mpi4py 中同步阻塞通信模式,下面我们将进入到对非阻塞通信模式的介绍。

非阻塞通信将通信和计算进行重叠,在一些情况下可以大大改善性能。特别是在那些具有独立通信控制硬件的系统上,将更能发挥其优势。

非阻塞通信需要通过发送操作的 start 函数启动发送,但并不要求操作立即执行和结束,启动发送操作的 start 调用在 MPI 环境从发送数据区取走数据之前即可返回。然后再在适当时机通过发送操作的 complete 函数来结束通信。在 start 和 complete 之间可并发进行数据传输和计算。

类似地,非阻塞通信的接收操作会发起一个接收的 start 操作,并在其它时机再通过接收的 complete 操作确认接收动作实际完成。再接收的 start 和 complete 函数之间,接收数据和执行计算可并发进行。

与阻塞通信相对应,非阻塞通信也可使用4个模式,即标准、缓冲、同步和就绪,区别在于非阻塞通信的方法在前面加了一个 I/i 前缀,但是语义与阻塞通信的各个模式一一对应。

非阻塞发送可与阻塞接收相匹配,反之,阻塞发送也可与非阻塞接收相匹配。

在非阻塞通信中一般会通过非阻塞通信对象来管理通信动作完成与否的信息。非阻塞通信的发送和接收方法会分别初始化一个发送和接收操作,然后立即返回一个MPI.Request 实例,在程序某个合适的地方可以调用 MPI.Request.Test(),MPI.Request.Wait() 和MPI.Request.Cancel() 来测试、等待或者取消本次通信。如果需要进行多重的测试或等待,可以使用 MPI.Request.Testall(),MPI.Request.Testany(),MPI.Request.Testsome(),MPI.Request.Waitall(),MPI.Request.Waitany(),MPI.Request.Waitsome()方法。

这里我们对非阻塞通信做了一个非常概要的介绍,在下一篇中我们将依次介绍非重复的非阻塞通信的四种通信模式,并给出相应的例程。让我们首先从非重复的标准通信开始。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值