C语言 由 OpenMP 线程处理的迭代索引



>我正在运行一个带有openmp静态负载平衡的for循环。我想打印每个线程处理的第一个和最后一个迭代(又名 i 的第一个和最后一个值,对于每个线程(。循环如下所示:

#pragma omp parallel for schedule(static) private(i)
for(i=0;i<n;i++){
//loop code
}

我很清楚 OpenMP 文档指定了要在静态计划中平均划分的迭代范围,尽管我想打印迭代值。

只要记住初始化为标记值 (-1( 的私有变量中的索引:

#pragma omp parallel
{
    int index = -1;
    #pragma omp for schedule(static)
    for(int i=0; i<n; i++){
        //loop code
        if (index == -1) {
            printf("%d: start %dn", omp_get_thread_num(), i);
        }
        index = i;
    }
    printf("%d: last %dn", omp_get_thread_num(), index);
}

相关内容

  • 没有找到相关文章

最新更新