gpt4 book ai didi

c - openmpi:如何在根线程和随机(最快)的其他线程之间接收和发送数据?

转载 作者:太空宇宙 更新时间:2023-11-04 08:16:19 27 4
gpt4 key购买 nike

我的基本问题是有多个线程做一些事情,其中​​一些需要比其他线程更多的时间(20 倍甚至更多),他们需要的时间只取决于起始值,但不能从起始值预测单独他们需要多少时间。为了减少更快线程的空闲时间,我想通过指定一个线程(根线程)来平衡工作负载,该线程为其他线程分配工作负载(如果一个线程完成了他的工作,我希望它发送一个新的起始值,并且要求一个新的)。

理想情况下,应该有一个 MPI 函数,它可以将一个值(下一个起始值)发送给首先获取它的线程(因为我对哪个线程计算了哪些起始值不感兴趣)。但是我找不到这样的功能,有吗?

然后我想我可以结合基本的 MPI_Recv 和 MPI_Send 函数,我的想法是让根等待 MPI_Recv 和其他调用 MPI_Send 的线程(目的地:根)在它们完成后立即发送它们的 ID与他们的工作。在根收到另一个线程的 ID 后,它调用 MPI_Send(目标是调用线程)向它们发送新的起始值。同时另一个线程调用了 MPI_Recv 来接收新的起始值。然后根线程循环回到 MPI_Recv 并等待下一个完成的线程。但后来我注意到 MPI_Recv 也需要一个明确的源值!所以 root 不能只等待 MPI_Recv 而不知道下一个线程将完成!

我能做什么,有没有办法让根线程与到达程序中指定点的第一个线程通信(一些 MPI 函数)?

谢谢。

最佳答案

您可以通过使用 MPI_ANY_SOURCE 作为根上的源来从任意级别接收。可以通过 status.MPI_SOURCE 找到要回复的等级。

从技术上讲,您还可以使用 MPI_Probe 来检查某个 rank 是否正在尝试向 root 发送内容,或者为每个 worker 发布一个 MPI_Irecv 并等待 MPI_Waitany 直到有人需要更多工作。

关于c - openmpi:如何在根线程和随机(最快)的其他线程之间接收和发送数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35582002/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com