python用泰勒级数计算圆周率_利用泰勒级数加速计算

使用Python+Numpy,它可能在这里和那里进行了优化,因此不可能真正地对log(1+x)与{}进行基准测试。

所以我搬到了C++。在

结果:Time per operation with log: 19.57 ns

Time per operation with order-2 Taylor expansion of log: 3.73 ns

所以大概是x5因子!在#include

#include

#include

#define N (1000*1000*100)

#define NANO (1000*1000*1000)

int main()

{

float *x = (float*) malloc(N * sizeof(float));

float y;

float elapsed1, elapsed2;

clock_t begin, end;

int i;

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

x[i] = (float) (rand() + 1) / (float)(RAND_MAX);

begin = clock();

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

y = logf(x[i]);

end = clock();

elapsed1 = float(end - begin) / CLOCKS_PER_SEC / N * NANO;

begin = clock();

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

y = x[i] + 0.5 * x[i] * x[i];

end = clock();

elapsed2 = float(end - begin) / CLOCKS_PER_SEC / N * NANO;

std::cout << "Time per operation with log: " << elapsed1 << " ns\n";

std::cout << "Time per operation with order-2 Taylor epansion: " << elapsed2 << " ns";

free(x);

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值