openmp 互斥锁 mysql_openmp之互斥锁

double get_pi_omp(const int& N)

{

assert(N > 0);

double pi = 0;

double sigma = 1.0/N;

int i;

double x;

double sum = 0;

//#pragma omp parallel private(x) firstprivate(sum) num_threads(4)

// {

// #pragma omp for

// for (i = 0; i < N; ++i)

// {

// x = sigma*(i + 0.5);

// sum += sigma*4/(x*x + 1);

// //printf("threadid = %d, sum = %f\n", omp_get_thread_num(), sum);

// }

// #pragma omp critical

// {

// pi += sum;

// }

// }

omp_lock_t mylock;

omp_init_lock(&mylock);

#pragma omp parallel private(x) firstprivate(sum) num_threads(4)

{

#pragma omp for

for (i = 0; i < N; ++i)

{

x = sigma*(i + 0.5);

sum += sigma*4/(x*x + 1);

//printf("threadID = %d, sum = %f\n", omp_get_thread_num(), sum);

}

omp_set_lock(&mylock);

pi += sum;

omp_unset_lock(&mylock);

}

omp_destroy_lock(&mylock);

//#pragma omp parallel private(x) firstprivate(sum) num_threads(4)

// {

// #pragma omp for

// for (i = 0; i < N; ++i)

// {

// x = sigma*(i + 0.5);

// sum += sigma*4/(x*x + 1);

// //printf("threadID = %d, sum = %f\n", omp_get_thread_num(), sum);

// }

// #pragma omp atomic

// pi += sum;

// }

return pi;

}    在main函数中检测,设置0-1之间的分段数n = 120000000, 检测代码以及结果如图:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值