interp2d generalizes the GSL interpolation routines to 2D interpolation. It tries to stick to the workflow and interface of the GSL 1D interpolation as closely as possible (even in cases where the GSL way may not quite make sense). The library includes implementations of bilinear and bicubic interpolation schemes.
Just like the GSL interpolation functions, there are two interfaces to the code. You can use the low-level interface defined in interp2d.h, which does not store the data arrays that define the function being interpolated (so you have to store them yourself and pass them to every function call), or you can use the high-level interface in interp2d_spline.h, which does store the data arrays in the interp2d_spline object.
The typical workflow is
- create an interpolation object using
- initialize it using
- evaluate the interpolating function or its derivatives using
interp2d_spline_eval()or its counterparts, possibly many times
- free the memory using
If your code evaluates the interpolating function many times, it may benefit from using
gsl_interp_accel objects, which are described in the GSL documentation.
interp2d uses CMake as its build system. Typically, to install a CMake-based project from source, from the directory containing
cmake . ./make ./make install
All files are licensed under the GPL version 3 or any later version at your option.
interp2d is hosted on the Github project page https://github.com/diazona/interp2d, which is where you should report bugs or offer suggestions for improvement if you would like to do so.