C++函数和MPI编程

从我在超级计算课上学到的东西,我知道 MPI 是一个通信(和数据传递)接口。

从我在超级计算课上学到的东西,我知道 MPI 是一个通信(和数据传递)接口。

我很困惑,当你在 C ++ 程序中运行一个函数,并希望每个处理器执行一个特定的任务。

例如,质数搜索(在超级计算机中非常流行)。假设我有一个值范围(531-564,某个任意范围),并说我有 50 个进程,我可以对每个数字进行一系列评估。如果 root(进程 0)要检查 531 并知道质数,则我可以使用 8 个进程(1-8)来评估质数状态。如果该数字可被任何数字 2-9 整除,并且余数不为 0,

对于将数据传递给每个进程的 MPI,是否有可能让这些进程执行这些操作?

对我来说最困难的部分是理解,如果我在原始的 C ++ 程序中执行一个动作,发生的进程可以分配在几个不同的进程上,那么在 MPI 中我如何构建这个?或者我的理解是完全错误的?

最大的想法是将数据传递给进程,而不是将函数发送到进程

2

每个 MPI 进程都在运行相同的程序,但这并不意味着它们在做同样的事情。不同的进程可以运行代码的不同分支,这取决于进程的 id (或“rank”),实际上是完全的。像任何分布式计算一样,参与者确实需要就如何通信达成一致。

MPI 中最基本的策略是分散收集,其中“主”进程(通常是等级为 0 的进程)将在对等方(包括主进程本身)之间平均分配一组工作,让他们都调用分散,对等方将完成工作,然后所有对等方将调用聚集以将结果发送回主。

在您的主要算法示例中,构建一个整数数组,将其“分散”到所有对等端,每个对等端将运行其数组,如果它是素数,则保存 1,如果不是,则“收集”结果以掌握。

作为伪代码:

main():
  int x[n], n = 100
  MPI_init()
  // prepare data on master
  if rank == 0:  
      for i in 1 ... n, x[i] = i
  // send data from x on root to local on each process in world
  MPI_ter(x, n, int, local, n/k, int, root, world)  
  for i in 1 ... n/k
      result[i] = 1   // ume prime 
      if 2 divides local[i], result[i] = 0
      if 3 divides local[i], result[i] = 0
      if 5 divides local[i], result[i] = 0
      if 7 divides local[i], result[i] = 0
  // gather reults from local on each process in world to x on root
  MPI_gather(result, n/k, int, x, n, int, root, world)
  // print results
  if rank == 0:
      for i in 1 ... n, print i if x[i] == 1
  MPI_finalize()

有很多细节要填写,如适当的声明,并处理这样的事实,即一些行列将有比其他人更少的元素,使用适当的 C 语法等,但得到他们的权利并不能帮助解释整体情况。

特别重要的是,如果进程 a 向进程 b 调用 MPI_send,那么进程 b 最好从进程 a 调用 MPI_recv。

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(36)
DynamicsCRM2013:工作流设计器布尔值和Optionset字段设置值消失
上一篇
在DRF中添加链接到序列化程序中的操作的url字段
下一篇

相关推荐

  • vscode code命令:# 如何使用 VSCode 命令

    VSCode Code命令是Visual Studio Code的一个内置命令,用于在本地和远程服务器上执行代码。它可以让你在不同的系统上运行代码,而不需要安装任何软件。…

    2023-01-22 09:55:35
    0 38 26
  • crv的cvt变速箱耐用吗耐用性强,提供良好的驾驶体验

    CR-V的CVT变速箱是一种非常耐用的变速箱,在正常使用情况下,它可以提供几百万英里的使用寿命。它的耐用性取决于如何使用它,建议您遵循以下指南来确保您的变速箱的最佳性能:在发动机启动时,请不要猛踩油门,以免瞬间发动机转速过快,从而破坏变速箱。…

    2023-02-16 02:02:27
    0 88 98
  • cv糖醋排骨是弯的吗弯曲的美味

    cv糖醋排骨不是弯的,它是一种制作方法,通常用来制作排骨。代码:…

    2023-01-30 08:19:31
    0 66 63
  • cv糖醋排骨甜蜜可口的家常美食

    cv糖醋排骨是一道具有浓郁中国风味的菜肴,它以排骨为主料,加入糖和醋,再加上葱、姜、蒜等调料,经过煮炖而成。代码如下:…

    2023-02-10 13:19:14
    0 39 32
  • cv树洞柒夜事件CV树洞中的秘密与惊奇

    cv树洞柒夜事件是一个有趣的计算机视觉活动,它提供了一种新的方式来利用计算机视觉技术来探索和发现景观。它始于2020年7月,由一群热爱计算机视觉的研究者和开发者发起,他们希望通过使用机器学习技术来探索景观中的精彩之处。cv树洞柒夜事件的目标是使用机器学习技术来探索景观中的精彩之处,并利用这些发现来改善景观设计。参与者需要使用机器学习技术来探索景观,并利用这些发现来改善景观设计。参与者可以使用Python,OpenCV,TensorFlow等技术来完成任务,并将其发布在GitHub上。…

    2023-01-08 12:49:50
    0 63 68
  • certification怎么读:如何获得认证,提升职业技能

    示例示例读音:/ˌsəːtɪfɪˈkeɪʃn/代码示例:…

    2023-02-21 06:27:25
    0 28 66
  • cvtdct哪个好如何提升使用cvtdct的效率

    cvtdct是一种用于图像压缩的算法,它可以有效地将图像中的信息减少到最小。它使用一种称为离散余弦变换(DCT)的算法,将图像中的信息转换为频率信息。由于DCT可以将图像中的信息转换为频率信息,因此可以有效地进行压缩。cvtdct好的原因是它可以有效地将图像中的信息减少到最小,从而减少图像文件的大小。此外,它还可以提供良好的图像质量,因为它可以把图像中的信息转换成频率信息,从而减少图像中的噪声。…

    2023-03-14 00:21:41
    0 63 75
  • cv小随:如何利用CV技术提升求职成功率

    示例示例cv小随是一种基于计算机视觉的智能技术,它可以帮助用户自动识别图像中的物体、场景和行为,从而实现自动化的图像处理。cv小随可以用于多种应用场景,如图像搜索、图像分类、图像识别、图像检测等。…

    2023-01-01 11:12:42
    0 36 18

发表评论

登录 后才能评论

评论列表(19条)