任何人都知道omp_set_max_active_levels()的范围,假设函数A有一个omp并行区,在这个区域内,A的每个线程都会调用库函数B,并且在库函数B中有两个级别的omp并行性。
那么,如果我们将函数A中的活动omp级别设置为3(A中为1,B中为2),能否确保库函数B的并行区正常工作?
发布于 2013-08-28 04:39:21
如果从活动的并行区域内调用omp_set_max_active_levels(),则该调用将被忽略(应该被忽略)。
发布于 2013-08-31 21:31:23
根据OpenMP 4.0标准(第3.2.15节):
从程序的连续部分调用时,为
omp_set_max_active_levels区域设置的绑定线程是遇到的线程。当从任何显式并行区域中调用时,omp_set_max_active_levels区域的绑定线程集(如果需要,还包括绑定区域)是由实现定义的。
然后:
此例程仅在从程序的连续部分调用时才具有所描述的效果。当从显式并行区域内调用时,此例程的效果由实现定义。
因此,如果您在程序的顺序部分中设置了嵌套并行区域的最大数量,那么您应该确保在任何兼容的OpenMP实现上都能按预期工作。
https://stackoverflow.com/questions/18435425
复制相似问题