PI 手工製作 pragma omp 減少的近似

int i;
int n = 1000000;
double area = 0;
double h = 1.0 / n;

#pragma omp parallel shared(n, h)
{
  double thread_area = 0;                      // Private / local variable

  #pragma omp for
  for (i = 1; i <= n; i++)
  {
    double x = h * (i - 0.5);
    thread_area += (4.0 / (1.0 + x*x));
  }

  #pragma omp atomic                       // Applies the reduction manually
  area += thread_area;                     // All threads aggregate into area
}
double pi = h * area;

執行緒在#pragma omp parallel 中生成。每個執行緒都有一個獨立/私有的 thread_area,用於儲存其部分新增內容。以下迴圈使用#pragma omp for 線上程之間分配。在這個迴圈中,每個執行緒計算自己的 thread_area,在此迴圈之後,程式碼按原子順序聚合該區域