Thomas Simpson became famous for his integration formula which is basically a form of the integration algorithm invented by Johannes Kepler 100 years earlier.
The Simpson formula uses a second order polynomial to approximate a segment of the function to be integrated. Of this polynomial the definite integral can easily be built and computed. The second order polynomial is a very good approximation of a small segment and due to that the result of the Simpson integration is quite useful.
Usually the Simpson integration integrates a function given by some supporting points. It uses a sequence of 3 supporting points y1, y2, y3 to build the polynomial. That means these 3 supporting points build one segment that is integrated at once. Then the next 3 supporting points are taken and integrated in the same manner. This is done in a loop from the beginning till the end of the integration interval. At the end the sum of all these integrals is taken for the result.
data:image/s3,"s3://crabby-images/30123/30123916c2cca355028ce458e6c37cc3761effed" alt="Simpson"
This procedure implies a restriction: There must be an odd number of supporting points.
The segment that should be integrated is b – a = 2h and if a is set to 0 the approximated function f(x) shall be integrated as a function of y1, y2 and y3 like
data:image/s3,"s3://crabby-images/f0132/f01322675570bbdcdb842806b89195f1e88fd146" alt="Simpson"
And the factors k1, k2 and k3 shall be determined.
Therefore the formulation for the 3 points y1, y2 and y3 is set up:
With the second order polynomial f(x) is approximated like
data:image/s3,"s3://crabby-images/3bf56/3bf56b86b05cfe900efe071c4a227d4e9c91daff" alt="Simpson"
This formulation applied for y1, y2 and y3
data:image/s3,"s3://crabby-images/cf5d3/cf5d3640ea5f96e2e4bcc648b619e9f4fc33fa86" alt="Simpson"
data:image/s3,"s3://crabby-images/d57e6/d57e6cd610c5c4e25eeaad8203b92e8595d6faeb" alt="Simpson"
data:image/s3,"s3://crabby-images/cd665/cd665d4abd6e1baeec5a99aea742e4e1b5ce9d3c" alt="Simpson"
That leads to the equation
data:image/s3,"s3://crabby-images/da3bc/da3bc4840f4ca23b5b968b3d7aae6605fb2097da" alt="Simpson"
or a bit rearranged
data:image/s3,"s3://crabby-images/28afd/28afd1ff631b23e5238f6e279c3aaad040c6b5c7" alt="Simpson"
On the other hand
data:image/s3,"s3://crabby-images/6d2aa/6d2aa00b6fa6acd99107ff3e800140b87d7145de" alt="Simpson"
And a parameter comparison leads to the matrix equation:
data:image/s3,"s3://crabby-images/767bc/767bcd55d6311ddfdd54293f5dd5d59ac9558bd9" alt="Simpson"
which can easily be solved and yields
data:image/s3,"s3://crabby-images/48a92/48a9292384f0d030fe95d6a93c5778187bb448a2" alt="Simpson"
data:image/s3,"s3://crabby-images/8c016/8c016568e0121321b3cb50456f54f87ab0f45a56" alt="Simpson"
and with this
data:image/s3,"s3://crabby-images/28aaa/28aaab43b910290ac5e80ed973d074d76b804f9f" alt="Simpson"
That’s the integral for one segment. To integrate the entire interval, this formula must be applied in a loop running over the entire integration interval.
With the same sample function I already used or the other integration algorithms:
data:image/s3,"s3://crabby-images/aadaa/aadaaec58895aeda695a988cb27f572d69ab5ee2" alt="Simpson"
data:image/s3,"s3://crabby-images/cabe0/cabe03664fd5c4d6b5f69ec350e5c09a7bdd0f9f" alt="Simpson"
And 7 supporting points like
data:image/s3,"s3://crabby-images/b2028/b2028bd9476ff31323df214b37e3a19039ead0e9" alt="Simpson"
The loop to compute the Simpson integral looks like:
private double CalcSimpson(int n)
{
int i;
double m;
double h;
h = (b - a) / n;
m = 0;
for (i = 0; i < n-1; i+=2)
{
m = m + f_x(a + h * i)/3 + f_x(a + h * (i+1))*4/3+ f_x(a + h * (i+2))/3;
}
m = m * h;
return m;
}
With
private double f_x(double x)
{
return 5.0 / (Math.Exp(Math.PI) - 2.0) * Math.Exp(2 * x) * Math.Cos(x);
}
With this I get 0.9985. Quite a good accuracy with just 7 supporting points
data:image/s3,"s3://crabby-images/687bd/687bda72167c5a433be3cd710c2431e9af6f225c" alt=":-)"