20 releases (6 breaking)

0.7.7 May 23, 2025
0.7.3 Jan 22, 2025

#176 in Math

MIT license

14MB
333K SLoC

Quadrature rules

The online encylopedia of quadrature rules is a reference website that lists a number of quadrature rules.

Quadrature rules are sets of points and weights that are used to approximate integrals. If ${p_0,\dots,p_{n-1}}\subset\mathbb{R}^d$ and ${w_0,\dots,w_{n-1}}\subset\mathbb{R}$ are the points and weights (repectively) of the quadrature rule for a single integral, then:

$$\int f(x),\mathrm{d}x \approx \sum_{i=0}^{n-1}f(p_i)w_i$$

Website

Before building the online encylopedia of quadrature rules, you must first install qrtools from the python directory:

cd python
python3 -m pip install .

The online encylopedia of quadrature rules website can then be built by running:

cd website
python3 build.py

Libraries

All of the quadrature rules included in the online encylopedia of quadrature rules are included in the quadraturerules library, which is available in the following languages:

Language Badges
C Test and build C library
C++ Test and build C++ library
Fortran Test and build Fortran 90 library
FORTRAN 77 Test and build Fortran 77 library
Julia Test and build Julia library
Python Test and build Python library PyPI
Rust Test and build Rust library crates.io docs.rs

Before building any of the libraries, you must first install qrtools from the python directory:

cd python
python3 -m pip install .

You can then build the libraries using the build.py script in the library directory. For example, to build the python library, you can run:

cd library
python build.py python

and to build the rust library, you can run:

cd library
python build.py rust

C++ library

The source code of the quadraturerules C++ library can be downloaded from the latest release on GitHub. It can be installed by running:

wget https://github.com/quadraturerules/quadraturerules/releases/download/v{{VERSION}}/quadraturerules-cpp-v{{VERSION}}.tar.gz
mkdir src
tar -xvf quadraturerules-cpp-v{{VERSION}}.tar.gz -C src
mkdir build
cd build
cmake ../src
make
make install

Once the library is installed, you can run the tests by running:

python src/test/run_tests.py

Or you can run individual tests:

cd src/test/{TEST_NAME}
cmake .
make .
./{TEST_NAME}

Usage

The library's function single_integral_quadrature can be used to get the points and weights of quadrature rules for a single integral. For example the following snippet will create an order 3 Xiao--Gimbutas rule on a triangle:

#include <quadraturerules.h>

using quadraturerules;

auto [points, weights] = single_integral_quadrature(
    QuadratureRule::XiaoGimbutas,
    Domain::Triangle,
    3
);

Note that the points returned by the library are represented using barycentric coordinates.

Generating the library

The C++ quadraturerules library can be generated from the templates in the online encyclopedia of quadrature rules GitHub repo. First clone the repo and move into the library directory:

git clone https://github.com/quadraturerules/quadraturerules.git
cd quadraturerules/library

The C++ library can then be generated by running:

python build.py cpp

This will create a directory called cpp.build containing the C++ source code.

Dependencies