Welcome back to a new post at thoughts-on-cpp.com. In this post, I would like to discuss the Gauss integration algorithm, more precisely the Gauss-Legendre integration algorithm. The Gauss-Legendre integration is the most known form of the Gauss integrations. Others are
- Gauss-Tschebyschow
- Gauss-Hermite
- Gauss-Laguerre
- Gauss-Lobatto
- Gauss-Kronrod
The idea of the Gauss integration algorithm is to approximate, similar to the Simpson Rule, the function f(x) by
data:image/s3,"s3://crabby-images/c8463/c84637c4567b29a77b31c97e1288343cfdb58f4c" alt="f(x)=w(x) \cdot \phi (x) f(x)=w(x) \cdot \phi (x)"
While w(x) is a weighting function,
is a polynomial function (Legendre-Polynomials) with defined nodes
which can be exactly integrated. A general form for a range of a-b looks like the following.
data:image/s3,"s3://crabby-images/35d1c/35d1c34950f3d51bb8c6ba3cb0cb627c288ac86f" alt="\int_{a}^{b} f(x) \mathrm{d} x \approx \frac{b-a}{2} \sum_{i=1}^{n} f\left(\frac{b-a}{2} x_{i}+\frac{a+b}{2}\right) w_{i} \int_{a}^{b} f(x) \mathrm{d} x \approx \frac{b-a}{2} \sum_{i=1}^{n} f\left(\frac{b-a}{2} x_{i}+\frac{a+b}{2}\right) w_{i}"
The Legendre-Polynomials are defined by the general formula and its derivative
data:image/s3,"s3://crabby-images/c67a4/c67a4be683ffb122ae24cfd5057275954c612443" alt="P_n(x)=\sum_{k=0}^{n/2}=(-1)^k\frac{(2n-2k)!}{(n-k)!(n-2k)!k!2^n}x^{n-2k} P_n(x)=\sum_{k=0}^{n/2}=(-1)^k\frac{(2n-2k)!}{(n-k)!(n-2k)!k!2^n}x^{n-2k}"
data:image/s3,"s3://crabby-images/287fe/287fea19416a5306d4945af856a5655e9798307b" alt="P_{n}^{\prime}(x)=\frac{n}{x^{2}-1}\left(x P_{n}(x)-P_{n-1}(x)\right) P_{n}^{\prime}(x)=\frac{n}{x^{2}-1}\left(x P_{n}(x)-P_{n-1}(x)\right)"
The following image is showing the 3rd until the 7th Legendre Polynomials, the 1st and 2nd polynomials are just 1 and x and therefore not necessary to show.
data:image/s3,"s3://crabby-images/8ebc0/8ebc0976b4d04119c1e36955f3c70529101882a6" alt="First 5 Legendre Polynomials"
Let’s have a closer look at the source code:
The integral is done by the gaussLegendreIntegral
(line 69) function which is initializing the LegendrePolynomial
class and afterward solving the integral (line 77 – 80). Something very interesting to note: We need to calculate the Legendre-Polynomials only once and can use them for any function of order n in the range a-b. The Gauss-Legendre integration is therefore extremely fast for all subsequent integrations.
The method calculatePolynomialValueAndDerivative
is calculating the value (line 50) at a certain node
and its derivative (line 51). Both results are used at method calculateWeightAndRoot
to calculate the the node
by the Newton-Raphson method (line 33 – 37).
data:image/s3,"s3://crabby-images/02129/02129d7f7483fc4defa61dab578b8e79abbee4eb" alt="x_{n+1}=x_{n}-\frac{f\left(x_{n}\right)}{f^{\prime}\left(x_{n}\right)} x_{n+1}=x_{n}-\frac{f\left(x_{n}\right)}{f^{\prime}\left(x_{n}\right)}"
The weight w(x) will be calculated (line 40) by
![w_{i}=\frac{2}{\left(1-x_{i}^{2}\right)\left[P_{n}^{\prime}\left(x_{i}\right)\right]^{2}} w_{i}=\frac{2}{\left(1-x_{i}^{2}\right)\left[P_{n}^{\prime}\left(x_{i}\right)\right]^{2}}](https://s0.wp.com/latex.php?latex=w_%7Bi%7D%3D%5Cfrac%7B2%7D%7B%5Cleft%281-x_%7Bi%7D%5E%7B2%7D%5Cright%29%5Cleft%5BP_%7Bn%7D%5E%7B%5Cprime%7D%5Cleft%28x_%7Bi%7D%5Cright%29%5Cright%5D%5E%7B2%7D%7D++&bg=%23ffffff&fg=%23383838&s=2)
As we can see in the screen capture below, the resulting approximation of
data:image/s3,"s3://crabby-images/1db96/1db96f70784e6a8b964d78400cbd78c96b699467" alt="I=\int_0^{\pi/2} \frac{5}{e^\pi-2}\exp(2x)\cos(x)dx=1.0 I=\int_0^{\pi/2} \frac{5}{e^\pi-2}\exp(2x)\cos(x)dx=1.0"
is very accurate. We end up with an error of only
. Gauss-Legendre integration works very good for integrating smooth functions and result in higher accuracy with the same number of nodes compared to Newton-Cotes Integration. A drawback of Gauss-Legendre integration might be the performance in case of dynamic integration where the number of nodes are changing.
data:image/s3,"s3://crabby-images/a53b1/a53b1eeb678c0868ae78d677238954d3e452afdb" alt="Screen capture of program execution"
Did you like the post?
What are your thoughts?
Feel free to comment and share this post.