c/c++语言开发共享OpenMP:并行运行两个函数,每个函数占线程池的一半

我有一个CPU消耗函数do_long ,我需要在两个不同的数据集上运行。

 do_long(data1); do_long(data2); do_long() { #pragma omp for for(...) { // do proccessing } } 

我有N个线程可用(取决于机器)。 如何告诉OpenMP我想要do_long函数并行运行,N / 2线程应该在第一个do_long执行循环而另一个N / 2应该处理第二个do_long

    一种方法是使用嵌套并行方法:

     void do_long(int threads) { #pragma omp parallel for num_threads(threads) for(...) { // do proccessing } } int main(){ omp_set_nested(1); int threads = 8; int sub_threads = (threads + 1) / 2; #pragma omp parallel num_threads(2) { int i = omp_get_thread_num(); if (i == 0){ do_long(data1, sub_threads); } if (i == 1 || omp_get_num_threads() != 2){ do_long(data2, sub_threads); } } return 0; } 

      以上就是c/c++开发分享OpenMP:并行运行两个函数,每个函数占线程池的一半相关内容,想了解更多C/C++开发(异常处理)及C/C++游戏开发关注计算机技术网(www.ctvol.com)!)。

      本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

      ctvol管理联系方式QQ:251552304

      本文章地址:https://www.ctvol.com/c-cdevelopment/518776.html

      (0)
      上一篇 2020年12月4日
      下一篇 2020年12月4日

      精彩推荐