pwl_interp_2d, a FORTRAN90 code which evaluates a piecewise linear interpolant of data depending on a 2D argument, defined on on a product grid, so that p(x(i),y(j)) = z(i,j).
The code requires the R8LIB library. The test code requires the TEST_INTERP_2D library.
The computer code and data files described and made available on this web page are distributed under the MIT license
pwl_interp_2d is available in a C version and a C++ version and a FORTRAN90 version and a MATLAB version and a Python version.
LAGRANGE_INTERP_2D, a FORTRAN90 code which defines and evaluates the Lagrange polynomial p(x,y) which interpolates a set of data depending on a 2D argument that was evaluated on a product grid, so that p(x(i),y(j)) = z(i,j).
PWL_INTERP_1D, a FORTRAN90 code which interpolates a set of data using a piecewise linear function.
R8LIB, a FORTRAN90 code which contains many utility routines using double precision real (R8) arithmetic.
RBF_INTERP_2D, a FORTRAN90 code which defines and evaluates radial basis function (RBF) interpolants to 2D data.
SHEPARD_INTERP_2D, a FORTRAN90 code which defines and evaluates Shepard interpolants to 2D data, based on inverse distance weighting.
TEST_INTERP_2D, a FORTRAN90 code which defines test problems for interpolation of data z(x,y), depending on a 2D argument.
TOMS886, a FORTRAN90 code which defines the Padua points for interpolation in a 2D region, including the rectangle, triangle, and ellipse, by Marco Caliari, Stefano de Marchi, Marco Vianello. This is ACM TOMS algorithm 886.
VANDERMONDE_INTERP_2D, a FORTRAN90 code which finds a polynomial interpolant to data z(x,y) of a 2D argument by setting up and solving a linear system for the polynomial coefficients, involving the Vandermonde matrix.