- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
所以我正在学习并行编程,并且正在编写一个程序来计算数字列表的全局总和。该列表分为几个子列表(取决于我有多少个内核),并且这些列表分别并行求和。在每个核心都有自己的总和后,我使用 MPI_Reduce 将值发送回其他核心,直到它们最终返回到根。我们不是直接将它们的值发送回根 (O(n)),而是将它们并行发送回其他核心 (O(log(n)),如下图所示:http://imgur.com/rL2O3Tr
因此,在 54 之前一切正常。我想我可能误解了 MPI_Reduce。我的印象是 MPI_Reduce 只是在一个线程中获取一个值,在另一个线程(目标线程)中获取一个值,并对值执行操作,然后将其存储在第二个线程中的同一位置。这至少是我想要的。我想从发送线程中获取 my_sum,并将其添加到接收线程中的 my_sum。你能在不同线程的相同地址上使用 MPI_Reduce 吗?他们都有相同的名字。
此外,我想生成这样的二叉树表示:http://imgur.com/cz6iFxl
其中 S02 表示总和已发送到线程 2,而 R03 表示总和已被线程 3 接收。为此,我为总和中的每个步骤(log(n) 步)创建了一个结构数组。每一步都发生在第 59 - 95 行,while 循环的每次迭代都是一个步骤。第 64-74 行是线程将其总和发送到目标线程的位置,并将信息记录在结构数组中。
我想我可能以错误的方式使用了 MPI_Send。我是这样使用它的:
MPI_Send(srInfo, 1, MPI_INT, root, 0, MPI_COMM_WORLD);
其中 srInfo 是一个结构数组,所以只是指向第一个结构的指针(对吗?)。这会因为内存不共享而不起作用吗?
抱歉,我是并行编程的新手,只需要帮助理解这一点,谢谢。
最佳答案
您可能误解了 MPI_REDUCE
在更高层次上应该做什么。您真的需要手动分配减排量吗?通常,MPI 集体会更好地针对您可以自己完成的大型通信器进行优化。我建议只使用 MPI_REDUCE
函数对所有等级进行归约。
所以你的代码会做这样的事情:
MPI_REDUCE
。这看起来像:MPI_Reduce(&myval, &sum, 1, MPI_INT, MPI_SUM, root, MPI_COMM_WORLD);
这应该会自动以某种树状方式自动为您完成所有求和。
关于c - MPI 使用 MPI_Send 和 MPI_Reduce 发送消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21338268/
我对 MPI 很陌生,我正在尝试使用 MPI_Reduce 来查找整数数组的最大值。我有一个整数数组 arr尺寸arraysize ,这是我的代码: MPI_Init(&argc, &argv); M
我在 fortran 中遇到 MPI_REDUCE() 的精度问题。我测试了两种对存储在每个节点上的 double 数字求和的方法。我使用的 MPI_REDUCE() 行是 call MPI_REDU
只是一个问题。如果我使用函数 MPI_Reduce,只有根可以分配接收缓冲区,当这是一个动态数组时?。例如: int r = 10; int *yloc, *y; ... yloc = calloc(
我正在尝试使用 MPI_reduce() 计算跨进程分布的 1000 个数字的平均值。不幸的是,到目前为止,我的代码只给出零,而不是预期的答案(数字的算术平均值)。 我做错了什么? #include
MPI documentation断言接收缓冲区 (recvbuf) 的地址中的地址仅在根目录下才有意义。这意味着可能不会在其他进程中分配内存。 this question 证实了这一点. int M
我正在尝试在 C(或 C++)中使用 MPI_REDUCE 来查找数组中的最小值(和索引)。我有这个适用于常规数组,但现在我想切换到一个动态计算值的数组。即 arr[n] 的值是通过调用 fun(n)
我开始研究使用 C 和 OpenMPI 库进行并行编程。所以现在一切看起来都太复杂了。 我正在尝试做一个单程序多数据:掌握:- 初始化一个数组- segmentation 它- 将相同大小的位发送到不
我最近遇到了一个堰行为。如果我在我的机器上运行以下代码(使用最新版本的 cygwin,Open MPI 版本 1.8.6),我会得到一个线性增长的内存使用量,这很快就会淹没我的电脑。 program
我试图将我的处理器分成几组,然后添加每组的总和独立地......但直到现在我还无法正确找到结果。一个简单的例子如下: int main(int argc, char** argv) { int
我得到了一个小练习,我必须通过使用 MPI 来估计 n 个球体的总体积来实现蒙特卡罗算法,这些球体的中心坐标和半径在 3 维中。即使我们必须使用 MPI,我们也可以在本地机器上启动所有进程,因此没有网
我正在尝试找到随机生成的数字的最大值。对此有任何想法... 我正在使用 MPI_Scatter 将随机生成的数字分成相等的进程。我正在使用 MPI_Reduce 从每个进程中获取最大值。 #inclu
我正在尝试做一些简单的 MPI 项目(w MPICH),但在这样做时我遇到了一个我既不理解也无法解决的问题(可能是因为我误解了文档)。所以我基本上想做的是将一个结构传递给 MPI_Reduce,以便对
我的 MPI 代码有问题,当代码在多个节点 上运行时挂起。它在单个节点 上运行时成功 完成。我不确定如何调试它。有人可以帮我调试这个问题吗? 程序使用: mpicc -o string strin.c
我有一个顺序程序,它计算数值并将结果存储在一个数组中,其中每个元素代表一个数字“位置”。 例如,一个计算结果[2,4,5,1,1,8,9,3,1]表示一个十进制值2.45118931 格式是resul
当使用 MPI_reduce 时,根处理器是否也对自身应用指定的 MPI 操作? 例如,假设以下代码由包括 root 在内的所有处理器运行,root 是否将它的 local_sum 减少为 globa
我学会了使用一些 MPI 函数。当我尝试使用 MPI_Reduce 时,我在运行代码时收到检测到堆栈粉碎: #include #include #include void main(int ar
我有两个程序。产生执行一些计算的“ worker ”的“主人”,我希望主人从 worker 那里得到结果并存储总和。我正在尝试使用 MPI_Reduce 从 worker 那里收集结果,而 worke
我不明白为什么一旦我使用包含动态分配数组的自定义 MPI 数据类型,MPI_Reduce() 就会出现段错误。有人知道吗 ?以下代码在 MPI_Reduce() 内部使用 2 个处理器时会崩溃。但是,
我正在尝试使用 MPI 库用 C 语言编写程序。在我的程序中,我正在解决 TSP(但没有使用任何特殊算法......)。我的输入参数是int nCites , int xCoord[]和 int yC
我需要缩减节点从其他节点获取元素列表的拷贝(存储在 vector 中)。我定义了自己的还原函数,但它不起作用。程序终止/崩溃。 这是代码: #include #include "mpi.h" #in
我是一名优秀的程序员,十分优秀!