shepard_interp_1d


shepard_interp_1d, a Fortran90 code which defines and evaluates Shepard interpolants to 1D data, based on inverse distance weighting.

The code needs the R8LIB library. The test code also needs the TEST_INTERP library.

Licensing:

The information on this web page is distributed under the MIT license.

Languages:

shepard_interp_1d is available in a C version and a C++ version and a Fortran90 version and a MATLAB version and an Octave version and a Python version.

Related Data and Programs:

shepard_interp_1d_test

barycentric_interp_1d, a Fortran90 code which defines and evaluates the barycentric Lagrange polynomial p(x) which interpolates a set of data, so that p(x(i)) = y(i). The barycentric approach means that very high degree polynomials can safely be used.

chebyshev_interp_1d, a Fortran90 code which determines the combination of Chebyshev polynomials which interpolates a set of data, so that p(x(i)) = y(i).

divdif, a Fortran90 code which uses divided differences to compute the polynomial interpolant to a given set of data.

lagrange_interp_1d, a Fortran90 code which defines and evaluates the Lagrange polynomial p(x) which interpolates a set of data, so that p(x(i)) = y(i).

nearest_interp_1d, a Fortran90 code which interpolates a set of data using a piecewise constant interpolant defined by the nearest neighbor criterion.

newton_interp_1d, a Fortran90 code which finds a polynomial interpolant to data using Newton divided differences.

pwl_interp_1d, a Fortran90 code which interpolates a set of data using a piecewise linear interpolant.

r8lib, a Fortran90 code which contains many utility routines using double precision real (R8) arithmetic.

rbf_interp_1d, a Fortran90 code which defines and evaluates radial basis function (RBF) interpolants to 1D data.

shepard_interp_2d, a Fortran90 code which defines and evaluates Shepard interpolants to 2D data, based on inverse distance weighting.

shepard_interp_nd, a Fortran90 code which defines and evaluates Shepard interpolants to multidimensional data, based on inverse distance weighting.

test_interp, a Fortran90 code which defines a number of test problems for interpolation, provided as a set of (x,y) data.

test_interp_1d, a Fortran90 code which defines test problems for interpolation of data y(x), depending on a 2D argument.

vandermonde_interp_1d, a Fortran90 code which finds a polynomial interpolant to a function of 1D data by setting up and solving a linear system for the polynomial coefficients, involving the Vandermonde matrix.

Reference:

  1. Richard Franke,
    Scattered Data Interpolation: Tests of Some Methods,
    Mathematics of Computation,
    Volume 38, Number 157, January 1982, pages 181-200.
  2. Donald Shepard,
    A two-dimensional interpolation function for irregularly spaced data,
    ACM '68: Proceedings of the 1968 23rd ACM National Conference,
    ACM, pages 517-524, 1969.

Source Code:


Last revised on 26 August 2020.