⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ompi.c

📁 一个利用OpenMP并行计算pi值的程序,双核CPU可以提高计算速度一倍,减少时间一半儿.
💻 C
字号:
#include <limits.h>
#include <stdio.h> 
#include <omp.h> 
#include <time.h> 

static long num_steps = 1000000000;
double step, pi;

int main(int argc, char **argv)
{
    int i;
    double x, sum = 0.0;
    clock_t t1, t2;
    
    #pragma omp parallel
    {
        printf("Hello, I am OpenMP!\n");
    }
    
    step = 1.0 / (double)num_steps;
    t1 = clock();
    #pragma omp parallel for reduction(+: x, sum)
    for (i = 0; i < num_steps; i++)
    {
        x = (i + 0.5) * step;
        sum = sum + 4.0 / (1.0 + x * x);
    }
    t2 = clock();
    pi = step * sum;
    printf("Pi = %f, %.3f seconds", pi, (double)(t2 - t1) / CLOCKS_PER_SEC);
    return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -