- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在考虑为 MPI 实现一个模仿 OpenMP 方式的包装器并行化 for 循环。
begin_parallel_region( chunk_size=100 , num_proc=10 );
for( int i=0 ; i<1000 ; i++ )
{
//some computation
}
end_parallel_region();
上面的代码将 for 循环内的计算分配给 10 个从属 MPI 处理器。进入并行区域后,将提供 block 大小和从属处理器的数量。离开并行区域后,MPI 处理器同步并处于空闲状态。
已编辑以响应高性能标记。
我无意模拟 OpenMP 的共享内存模型。我提出这个是因为我需要它。我正在开发一个从数学函数构建图形所需的库。在这些数学函数中,经常存在如下的for循环。
for( int i=0 ; i<n ; i++ )
{
s = s + sin(x[i]);
}
所以我希望首先能够将 sin(x[i]) 分配给从属处理器,最后像在 OpenMP 中一样减少到单个变量。
我想知道是否有这样的包装器,这样我就不必重新发明轮子了。
谢谢。
最佳答案
没有这样的 wrapper 可以从研究实验室逃脱并广泛使用。您的建议与其说是重新发明轮子,不如说是发明飞行汽车。
我知道您是如何建议编写 MPI 代码来模拟 OpenMP 分担循环负担的方法,但不太清楚的是您是如何建议让 MPI 模拟 OpenMP 的共享内存模型的?
在一个简单的 OpenMP 程序中,如您所建议的,可能有 10 个线程,每个线程执行一个大循环的 10% 的迭代,可能更新一个大的(共享的)数据结构的值。要在 MPI 中的狡猾包装器中模拟它,您要么必须 (i) 说服单方通信表现得像共享内存(这可能是可行的,但肯定会很困难)或 (ii) 将数据分发到所有进程,让每个进程独立计算 10% 的结果,然后将结果广播到所有进程,以便在执行结束时每个进程都拥有其他进程拥有的所有数据。
在分布式内存硬件上模拟共享内存计算是并行计算中的一个热门话题,过去是,将来也是。谷歌分布式共享内存计算并加入其中。
编辑
好吧,如果您已将 x
分布到多个进程,那么各个进程可以计算 sin(x[i])
并且您可以使用以下方法将总和减少到一个进程MPI_Reduce
。
我一定遗漏了您的要求,因为我不明白您为什么要在 MPI 已经提供的基础上构建任何上层结构。尽管如此,我对您最初问题的回答仍然是不,没有您想要的包装,我的其余所有回答都只是评论。
关于c - 模仿 OpenMP 的 for-loop pragma 的 MPI 包装器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12144849/
这个问题在这里已经有了答案: How to test your code on a machine with big-endian architecture? (3 个答案) 关闭 4 年前。 我想
我正在使用 Mockito 对业务对象进行单元测试。业务对象使用通常从数据库获取数据的 DAO。为了测试业务对象,我意识到使用单独的内存 DAO(将数据保存在 HashMap 中)比编写所有 when
如何实现: if X in (1,2,3) then 而不是: if x=1 or x=2 or x=3 then 换句话说,如何才能最好地模仿 Excel 的 VBA 中的 IN 运算符? 最佳答案
我正在使用带有 Jabber-net 的 ejabberd 2。我想问你是否可以在使用管理员登录时冒充用户。意思是我希望能够使用管理员帐户登录并发送消息 From: 'User A', To: 'Us
当查询输入到 Excel 中的 Bloomberg BDH 函数中时,它会自动填充选定的单元格,并使用请求的数据填充下面的单元格。 我正在尝试创建一个执行类似操作的函数(尽管使用不同的数据源)。 BD
在 es6 中保留模拟静态属性的类的属性的最佳方法是什么? 使用原型(prototype)链中创建的属性安全吗? class Employee { constructor(name, creato
我有一个 HTML 文本输入 用户输入字符串。由于它是文本输入而不是文本区域,因此用户无法输入换行符。 用户可以在文本输入中输入 Markdown 元素,以便在稍后重新显示数据时格式化数据。然而,他们
我有一个快速的问题:我正在使用 Spyder,变量浏览器选项卡中有一个巧妙的功能,我可以单击标题并对列进行排序。但是,当我尝试使用时无法重现相同的排序顺序: df.sort_values() 在 py
这是一个有趣的挑战。我正在阅读 TypeScript github 中的这个老问题 support Extension Methods用法与C#类似。提出了两种主要方法,一种是添加语法糖来扩展经常令人
在 Java 中这是有效的: class Class1 { T t; ... } //Inside other class that has no relation to Class1 private
我有另一个对象,我希望它的颜色与 UITextField 的默认占位符文本颜色相同。 我知道我可以简单地创建一个具有相同颜色的新 UIColor,但如果 Apple 更改默认的 UITextField
我正在尝试为我的 ListView 项目构建一个类似于 Gmail 应用程序标签列表的布局,其中标签文本在左侧,计数在右侧。除了长文本,我的大部分工作都有效。我所得到的结果导致文本与计数重叠。 这就是
我用一副纸牌创建了一个圆圈,用户可以旋转它来选择一张纸牌。平移结束后,它会捕捉到指定的角度,并带有漂亮的减速动画。将来会有某种指示表明 45 度的卡是所选的卡。我想指出选择随着触觉反馈而改变,就像在
我有一个简单的链表类型和一个 Clone 的实现它: #[deriving(Show)] enum List { Cons(int, Box), Nil, } impl Clone f
所以我创建了自己的自定义 UIView,它看起来像一个警报,现在我想添加显示和隐藏动画。 我想为 AlertController 模仿 Apple 的默认动画。解雇是一个简单的淡入淡出动画,但是我不确
我正在尝试让我的 Javascript 生活变得更轻松一些(至少对于我的工作环境而言)。我试图将所有 Javascript 对象创建方法移至“类”中。我有以下代码(用于创建超链接): function
您将如何模仿 iPhone 的键盘输入。因此,当您单击一个时,会显示 1,然后显示 2,然后显示 12... 依此类推,并显示 ( ) -。我不想使用实际的电话应用程序,因为我正在创建一个虚假的拨号器
你好,我有一个问题,我需要一些指导/帮助来创建一个菜单,如果屏幕太小而无法显示原始菜单,该菜单将替换为一个按钮。我知道 Bootstrap 会为您做这件事,但由于实现限制,我无法使用该库。因此,我查看
我正在使用 UIBarButtonItems 来触发特殊操作,但我还想在屏幕底部添加另一个按钮,其尺寸与在 NavigationBar 中创建的按钮的尺寸相同,我该怎么做? 我可以在 Interfac
我可以原谅可能重复的问题,但我没有找到解决问题的方法。 Controller 加载时模拟按钮点击。它运行良好,直到我将 ng-click 更改为 on-tap( ionic 应用程序)。现在根本不起作
我是一名优秀的程序员,十分优秀!