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
1,793 downloads per month
Used in 11 crates
(6 directly)
290KB
2.5K
SLoC
gauss-quad
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