#quadrature #gaussian #integration #numeric

gauss-quad

Library for applying Gaussian quadrature to integrate a function

12 releases

0.2.2 Dec 28, 2024
0.2.1 Aug 24, 2024
0.2.0 Jul 29, 2024
0.1.8 Nov 21, 2023
0.1.3 Nov 30, 2019

#64 in Math

Download history 427/week @ 2024-09-21 350/week @ 2024-09-28 407/week @ 2024-10-05 462/week @ 2024-10-12 934/week @ 2024-10-19 278/week @ 2024-10-26 190/week @ 2024-11-02 253/week @ 2024-11-09 270/week @ 2024-11-16 393/week @ 2024-11-23 389/week @ 2024-11-30 400/week @ 2024-12-07 471/week @ 2024-12-14 65/week @ 2024-12-21 496/week @ 2024-12-28 717/week @ 2025-01-04

1,793 downloads per month
Used in 11 crates (6 directly)

MIT/Apache

290KB
2.5K SLoC

gauss-quad

Crates.io Version docs.rs Build Status codecov

The gauss-quad crate is a small library to calculate integrals of the type

$$\int_a^b f(x) w(x) \mathrm{d}x$$

using Gaussian quadrature.

Here $f(x)$ is a user supplied function and $w(x)$ is a weight function that depends on which rule is used. Gaussian quadrature is interesting because a rule of degree n can exactly integrate all polynomials of degree 2n-1 or less.

To use the crate, the desired quadrature rule has to be included in the program, e.g. for a Gauss-Legendre rule

 use gauss_quad::GaussLegendre;

The general call structure is to first initialize the n-point quadrature rule setting the degree n via

 let quad = QUADRATURE_RULE::new(n)?;

where QUADRATURE_RULE can currently be set to calculate either:

QUADRATURE_RULE Integral
Midpoint $$\int_a^b f(x) \mathrm{d}x$$
Simpson $$\int_a^b f(x) \mathrm{d}x$$
GaussLegendre $$\int_a^b f(x) \mathrm{d}x$$
GaussJacobi $$\int_a^b f(x)(1-x)^\alpha (1+x)^\beta \mathrm{d}x$$
GaussLaguerre $$\int_{0}^\infty f(x)x^\alpha e^{-x} \mathrm{d}x$$
GaussHermite $$\int_{-\infty}^\infty f(x) e^{-x^2} \mathrm{d}x$$
GaussChebyshev $$\int_a^b f(x)(1-x^2)^a \mathrm{d}x,\qquad a=\pm\frac{1}{2}$$

For the quadrature rules that take an additional parameter, such as Gauss-Laguerre and Gauss-Jacobi, the parameters have to be added to the initialization, e.g.

 let quad = GaussLaguerre::new(n, alpha)?;

Then to calculate the integral of a function call

let integral = quad.integrate(a, b, f(x));

where a and b (both f64) are the integral bounds and f(x) is the integrand which implements the trait Fn(f64) -> f64. For example to integrate a parabola from 0 to 1 one can use a lambda expression as integrand and call:

let integral = quad.integrate(0.0, 1.0, |x| x * x);

If the integral is improper, as in the case of Gauss-Laguerre and Gauss-Hermite integrals, no integral bounds should be passed and the call simplifies to

let integral = quad.integrate(f(x));

Rules can be nested into double and higher integrals:

let double_integral = quad.integrate(a, b, |x| quad.integrate(c(x), d(x), |y| f(x, y)));

If the computation time for the evaluation of the integrand is large (≫100 µs), the rayon feature can be used to parallelize the computation on multiple cores (for quicker to compute integrands any gain is overshadowed by the overhead from parallelization)

let slow_integral = quad.par_integrate(a, b, |x| f(x));

Dependencies

~5MB
~99K SLoC