您的位置:首页 > 运维架构

OpenMP并行计算PI的值

2012-06-15 19:42 393 查看
用VS新建一个工程后,首先要右键项目,属性--C/C++--语言,,在右边的对话框中OpenMP支持选择是;
程序代码为:
#include<stdio.h>
#include<time.h>
#include<omp.h>

static long num_steps = 100000;
double step,pi;
void main()
{
clock_t t1=clock();
int i;
double x,sum = 0.0;
step = 1.0/(double)num_steps;
#pragma omp parallel for reduction(+:sum)
for(i = 0;i<num_steps;i++)
{
x = (i+0.5)*step;
sum = sum + 4.0/(1.0+x*x);
printf("%d",omp_get_thread_num());
}
pi = step *sum;
clock_t t2 =clock();
printf("pi=%f,用时:%d\n",pi,t2-t1);
}
上述代码使用了规约rduction(op:list);这样每个线程会有一个私有的list,当所有线程的list计算完成之后,每个线程的私有list值将被op规约为一个list值。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: