gpt4 book ai didi

c++ - 如何在 openMP 的单个区域内并行 for 循环?

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:18:17 25 4
gpt4 key购买 nike

我有一个递归程序,我想使用 openMP 来加速它。结构如下。

我不熟悉omp task,只是从here 中学到了一些东西| .看来我必须将 buildTree 包装在 omp single 区域中。

但是,我还想在 buildTree 中并行化 for 循环,我该如何实现?

int main()
{
#pragma omp parallel
{
#pragma omp single nowait
buildTree();
}
}
void buildTree
{
if(endRecursion)
return;
for(int i = 0; i < problemSize; i++)
{
// I want to parallelize these code using omp for
}

if(problemSizeIsSmall)
{
buildTree(subProblemSize); // left subtree
buildTree(subProblemSize); // right subtree
}
else
{
#pragma omp task
{
buildTree(subProblemSize); // left subtree
}
#pragma omp task
{
buildTree(subProblemSize); // right subtree
}
}
}

最佳答案

我想你可以使用 nested parallelism在你的问题中。您的代码在 main() 中看起来像这样:

#pragma omp parallel for num_threads(2)
buildTree();

buildTree() 中:

omp_set_num_threads(4); // 4 or whatever number of threads you want
#pragma omp parallel for
for(int i = 0; i < problemSize; i++)

查看我的 first link 的第 4.3 节 示例 4–2 调用并行区域内的 OpenMP 例程了解更多详情

关于c++ - 如何在 openMP 的单个区域内并行 for 循环?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30294883/

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