Integrals of Polynomials over Triangles

**TRIANGLE_INTEGRALS**
is a Python library which
returns the exact value of the integral of a polynomial
over the interior of an arbitrary triangle in 2D.

The computer code and data files described and made available on this web page are distributed under the GNU LGPL license.

**TRIANGLE_INTEGRALS** is available in
a C version and
a C++ version and
a FORTRAN77 version and
a FORTRAN90 version and
a MATLAB version and
a Python version.

BALL_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit ball in 3D.

CIRCLE_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the surface of the unit circle in 2D.

CUBE_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit cube in 3D.

DISK_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit disk in 2D.

HYPERBALL_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit hyperball in M dimensions.

HYPERCUBE_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit hypercube in M dimensions.

HYPERSPHERE_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the surface of the unit hypersphere in M dimensions.

LINE_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the length of the unit line in 1D.

POLYGON_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of a polygon in 2D.

PYRAMID_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit pyramid in 3D.

SIMPLEX_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit simplex in M dimensions.

SPHERE_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the surface of the unit sphere in 3D.

SQUARE_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit square in 2D.

TETRAHEDRON_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit tetrahedron in 3D.

TRIANGLE_DUNAVANT_RULE, a MATLAB library which sets up a Dunavant quadrature rule over the interior of a triangle in 2D.

TRIANGLE_FEKETE_RULE, a MATLAB library which defines Fekete rules for quadrature or interpolation over the interior of a triangle in 2D.

TRIANGLE_FELIPPA_RULE, a MATLAB library which returns Felippa's quadratures rules for approximating integrals over the interior of a triangle in 2D.

TRIANGLE_LYNESS_RULE, a MATLAB library which returns Lyness-Jespersen quadrature rules over the interior of a triangle in 2D.

TRIANGLE_MONTE_CARLO, a MATLAB library which uses the Monte Carlo method to estimate the integral of a function over the interior of the unit triangle in 2D.

TRIANGLE_NCC_RULE, a MATLAB library which defines Newton-Cotes closed quadrature rules over the interior of a triangle in 2D.

TRIANGLE_NCO_RULE, a MATLAB library which defines Newton-Cotes open quadrature rules on a triangle.

TRIANGLE_SYMQ_RULE, a MATLAB library which returns efficient symmetric quadrature rules, with exactness up to total degree 50, over the interior of an arbitrary triangle in 2D, by Hong Xiao and Zydrunas Gimbutas.

TRIANGLE_WANDZURA_RULE, a MATLAB library which sets up a quadrature rule of exactness 5, 10, 15, 20, 25 or 30 over the interior of a triangle in 2D.

TRIANGLE01_INTEGRALS, a Python library which determines the exact integral of a monomial over the unit triangle in 2D.

WEDGE_INTEGRALS, a MATLAB library which returns the exact value of the integral of any monomial over the interior of the unit wedge in 3D.

- i4_to_pascal.py, converts an I4 to a pair of indices in Pascal's triangle;
- i4_to_pascal_degree.py, converts an I4 to the degree (sum) of the corresponding pair of indices in Pascal's triangle;
- pascal_to_i4.py, converts a pair of indices in Pascal's triangle to a linear index;
- poly_power.py, computes a power of a polynomial in X and Y.
- poly_power_linear.py, computes a power of a linear polynomial in X and Y.
- poly_print.py, prints a polynomial in X and Y.
- poly_product.py, computes the product of two polynomials in X and Y.
- r8mat_print.py, prints an R8MAT;
- r8mat_print_some.py, prints some of an R8MAT;
- rs_to_xy_map.py, determines the map coefficients from the reference to physical triangle.
- timestamp.py prints the current YMDHMS date as a time stamp.
- triangle_area.py computes the area of a arbitary triangle.
- triangle_monomial_integral.py computes the integral of a monomial over an arbitrary triangle.
- triangle_poly_integral.py computes the integral of a polynomial over an arbitrary triangle.
- triangle_xy_integral.py computes the integral of xy over an arbitrary triangle.
- triangle01_monomial_integral.py computes the integral of a monomial over the reference triangle.
- triangle01_poly_integral.py computes the integral of a polynomial over the reference triangle.
- trinomial.py, computes a trinomial coefficient;
- xy_to_rs_map.py, determines the map coefficients from the physical to reference triangle.

- triangle_integrals_test.py, calls all the tests.
- triangle_integrals_test.sh, runs all the tests.
- triangle_integrals_test_output.txt, the output file.

You can go up one level to the Python source codes.