首页 > 代码库 > Open MP计算π的值
Open MP计算π的值
<pre name="code" class="cpp">#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值。如果不进行归约的话可能会导致每次的运行结果都不一样
Open MP计算π的值
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。