C++年复合辛普森规则中的错误

Errors in Composite Simpson's Rule in C++

本文关键字:错误 规则 辛普森 复合 C++      更新时间:2023-10-16

我正在编写一个小程序,使用复合辛普森规则来近似C++中的积分。它似乎有效,但是当我计算不同间隔数的积分(因此for循环)时,会出现一些错误,因为它似乎完全是随机的。这是我的代码。

#include <iostream>
#include <cmath>
double f(double x)
{
    double y = x;
    return y;
}
int main()
{
    for(double n=1; n<20; n+=1)
    {
        double a = 1;
        double b = 4;
        double d = (b-a)/n;
        double i = a;
        double area = 0;
        while(i<b)
        {
            double j = i + d;
            area += (d/6) * ( f(i) + 4*f((i+j)/2) + f(j) );
            i = i + d;
        }
        std::cout << "Order " << n << " : " << area << std::endl;
    }
    return 0;
}

输出如下。

Order 1 : 7.5
Order 2 : 7.5
Order 3 : 7.5
Order 4 : 7.5
Order 5 : 7.5
Order 6 : 7.5
Order 7 : 9.30612
Order 8 : 7.5
Order 9 : 7.5
Order 10 : 8.745
Order 11 : 8.6281
Order 12 : 7.5
Order 13 : 7.5
Order 14 : 7.5
Order 15 : 7.5
Order 16 : 7.5
Order 17 : 8.22145
Order 18 : 8.18056
Order 19 : 7.5

我认为这可能与变量类型或存储问题有关,尽管我无法弄清楚问题是什么。任何帮助,不胜感激。

这可能是由浮点数比较引起的。 在这种情况下,对于计算机来说,4.0<4.0可能是正确的,使您的循环次数过多。

为了解决这个问题,你可以使用 epsilon 来比较数字:

#define EPS 1e-8
if(a<b-EPS){...} // this is analogous to < operator for ints
if(a<b+EPS){...} // this is analogous to <= operator for ints

另一种选择是动态生成i变量,同时使用整数来控制循环:

for(int k=0;k<n;k++){
    double i=a+(b-a)*k/n;
    // ...
}