- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用omp来实现listranking问题(也称为快捷方式),以使数组W的和为前缀。
我不知道我是否正确使用了冲洗编译指示。
而且我在编译时发出警告:“障碍区域可能不会紧密嵌套在工作共享,关键,有序,主要或明确的任务区域内”
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <omp.h>
main(int argc, char *argv[])
{
int Q[9]={1,2,3,4,5,6,7,8,0};
int W[8]={1,2,3,4,5,6,7,8};
int i,j=6,id;
printf("Before:\n");
for(j=0;j<8;j++)
printf("%d",W[j]);
printf("\n");
#pragma omp parallel for shared(Q,W) private(id) num_threads(7)
for (i=6; i>=0; i--)
{
id= omp_get_thread_num();
while((Q[i] !=0)&& (Q[Q[i]] !=0))
{
#pragma omp flush(W)
W[i]=W[i]+W[Q[i]];
#pragma omp flush(W)
printf("Am %d \t W[%d]= %d",id,i,W[i]);
#pragma omp barrier
#pragma omp flush(Q)
Q[i]=Q[Q[i]];
#pragma omp flush(Q)
printf("Am %d \n Q[%d]= %d",id,i,Q[i]);
};
}
printf("Result:\n");
for(j=0; j<8; j++)
printf("%d \t",W[j]);
printf("\n");
最佳答案
您不能在omp并行区域内使用屏障,而只能在omp并行区域内使用屏障。
这样做的原因是因为如果您的循环是从1到N,则内部的屏障将有效地创建N个线程,如果N大,则会对性能产生负面影响。
我没有在这里查找算法,但是有两个合理的选择是重构使用2个并行的for循环,一个接一个地设置障碍,或者重构您的算法以使用#pragma并行区域。
我查看了列表排名算法,可以很好地找到前缀和的实现,或者扫描是否必须使用openmp。
-里克
关于c - 如何在没有相等迭代次数的while循环上使用omp barrier,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1959777/
我是 Barrier-kvm 的常客。我最近将我的服务器升级到 Ubuntu 20.04 并开始收到错误“错误:ssl 证书不存在:/home/rsvay/snap/barrier-kvm/2/.lo
根据维基百科:内存屏障,也称为 membar、内存栅栏或栅栏指令,是一种栅栏指令,它导致中央处理单元 (CPU) 或编译器对在屏障指令。 这通常意味着在屏障之前发出的操作保证在屏障之后发出的操作之前执
我正在尝试使用omp来实现listranking问题(也称为快捷方式),以使数组W的和为前缀。 我不知道我是否正确使用了冲洗编译指示。 而且我在编译时发出警告:“障碍区域可能不会紧密嵌套在工作共享,关
问题 是否允许在发散流控制之后但在发散流控制之外使用 barrier()? 详细信息 在兼容 OpenGL 4.00 的计算着色器中,我正在做一些涉及发散(即非动态统一)分支语句的工作。稍后在同一个着
我想制作一个看起来像这样的布局,但使用 Barrier: 所以我制作了以下 XML: 但是结果是这样的: Barrier 似乎没有向下移动。我做错了什么?
我了解了一些关于 GCD 障碍的知识并想检查这些信息(来自 Apple docs ): Any blocks submitted after the barrier block are not exe
通常,线程屏障(即 boost::barrier)用一个整数初始化,该整数表示必须调用 boost::barrier::wait 的线程数 - 所有线程都在该点等待,直到满足条件,然后所有线程继续。
我正在尝试解决我们的操作系统教授在上一次考试中向我们展示的问题,以便为下一次考试做准备。 问题是有两个线程同时执行并且可能在不同的时间内完成。一个特定的线程完成后,它需要阻塞直到另一个线程完成,然后它
我正在研究测试驱动开发,其中一个讨论点是与 TDD 相关的“进入壁垒”。有没有人在这方面有任何经验,在您参与的任何项目中,由于进入阈值太高而决定不使用 TDD? 据我所知,进入的唯一障碍是个人开发人员
如何使用类成员函数初始化 std::barrier ? class CMyClass { private: void func() { } public: void start
作为类(class)作业的一部分,我必须使用锁来实现自定义屏障类。为了测试我的 LockBarrier 类,我想出了以下测试代码。它工作正常,但我担心这是否是正确的方法。您能否建议我可以做的改进,特别
最近在看页面The JSR-133 Cookbook for Compiler Writers由 Doug Lea 关于 JSR 133: JavaTM Memory Model and Thread
我想在我的 cpp 多线程代码中使用 std::experimental::barrier。但即使我写这样的代码: #include #include #include int main ()
我目前正在使用 MPI C 库,但是使用 C++ 编码,我知道 MPI_Barrier(MPI_COMM_WORLD) 函数会阻止调用者,直到通信器中的所有进程都调用它 , 如 documentati
在omp临界区之后是否存在隐式omp屏障 例如,我可以将以下代码版本 1 修改为版本 2 吗? 版本-1 int min = 100; #pragma omp parallel { int lo
我不确定这是否在 xcode8 beta 5 中崩溃了。看看这段代码。你认为它应该先打印“A”还是先打印“B”? let q = DispatchQueue(label: "q", attribute
在 Java 中,当我们有两个线程共享以下变量时: int a; volatile int b; 如果线程 1 执行: a = 5; b = 6; 然后在这两条指令之间插入一个 StoreStore
从 Linux 内核代码中,我可以看到 preempt_enable() 和 preempt_disable() 除了 barrier() 之外什么都没有: #define preempt_disab
我有时会在有关内存排序的教程中看到“完全内存屏障”一词,我认为这意味着: 如果我们有以下指示: instruction 1 full_memory_barrier instruction 2 然后,不
我已经阅读了我能找到的所有关于 torch.distributed.barrier() 的文档,但仍然无法理解它在 this script 中的使用方式并且非常感谢一些帮助。 所以official d
我是一名优秀的程序员,十分优秀!