使用 OPENMP 并行化 C++ 代码

using OPENMP to parallelize a c++ code

本文关键字:代码 C++ 并行化 OPENMP 使用      更新时间:2023-10-16

我使用 openmp 并行化了我的 c++ 代码,如下所示:

....//some code
   double S_theta = 0.0, S_x = 0.0, S_y = 0.0;
#pragma omp parallel for private(dx,dy,theta_new) reduction(+ : S_x,S_y,S_theta)
    for(int j = 0; j < N; j++)
      {
        if (j==i) continue;
           double delta_x = x[i]-x[j],  
        for(int ky = -1; ky<= 1; ky++)
            {
            for(int kx = -1; kx<= 1; kx++)
               {
               if (r_ij_square > l0_two)
                  { 
                  double r_ij = sqrt(r_ij_square);
                  r_x_ij/= r_ij; 
                  r_y_ij/= r_ij;
                  double rdote = r_x_ij * e_x[j] + r_y_ij * e_y[j];
                  S_theta += e_dot_e * ( e_cross_e -  rdote * (e_x[i] * r_y_ij - e_y[i] * r_x_ij) ) / (r_ij_square * r_ij);
                  double S = rdote  /r_ij_square;
                  S_x += r_x_ij * S;
                  S_y += r_y_ij * S;
                  }
               }
        }
    double zeta = -eta / 2.0 ; 
    theta_new[i] += zeta + dt * dlthet;
    }
  ....//some code

但是每次运行它时结果都会改变!当我删除此行时

 #pragma omp parallel for reduction(+ : S_x,S_y,S_theta)

,在不同的运行中结果是相同的!我的代码有什么问题?

您的变量S在循环外部声明,并将在运行循环的所有线程之间共享。 鉴于它的使用方式,它可以在使用它的循环中声明为double S = rdote / r_ij_square;