Download Code
This is a set of Matlab functions to interpolate scattered data with Radial Basis Functions (RBF).
Getting Started
y = RBFinterp(xs, ys, x, RBFtype, R)
interpolates to find y, the values of the function y=f(x) at the points x.
Xs must be a matrix of size [N,Dx], with N the number of data points and Dx the dimension of the points in xs and x.
Ys must be a matrix of size [N,Dy], with N the number of known values at points in Xs, and Dy the dimension of the y values.
X must be a matrix of size [M,Dx], with M the number of query points.
RBFtype specifies the radial basis functions (RBF) to be used.
- The available global support RBFs are:
- ‘R1’ - linear spline
- ‘R3’ - cubic spline
- ‘TPS2’ - thin plate spline
- ‘Q’ - quadric
- ‘MQ’ - multiquadric
- ‘IMQ’ - inverse multiquadric
- ‘IQ’ - inverse quadric
- ‘GS’ - Gauss
RBF name |
Abbreviation |
data:image/s3,"s3://crabby-images/1b2a6/1b2a66d93086c0ea9c00bfde2c212c33457fcb85" alt="" |
Linear spline |
R1 |
data:image/s3,"s3://crabby-images/8791a/8791a36fcb8526708d48f0bb64280544318aed8e" alt="" |
Cubic splie |
R3 |
data:image/s3,"s3://crabby-images/75a42/75a420d1f3f94573ca05d835ea046f208fea93d8" alt="" |
Thin plate spline |
TPS2 |
data:image/s3,"s3://crabby-images/82c00/82c0092a3c1120a078cff7731fe26309de156795" alt="" |
Quadric |
Q |
data:image/s3,"s3://crabby-images/cdaa9/cdaa9e3a78f8eade59de90ef28d81c54c8ed8b3b" alt="" |
Multiquadric |
MQ |
data:image/s3,"s3://crabby-images/119ac/119ac31244790cc4613e46074ff2036c2c40692b" alt="" |
Inverse multiquadric |
IMQ |
data:image/s3,"s3://crabby-images/b1f9b/b1f9bb2dfacba52d664bf017da9eff2dd929ccd4" alt="" |
Inverse quadric |
IQ |
data:image/s3,"s3://crabby-images/74ce6/74ce6b4ef5bdbaa94e89312b2720fa8386767fb6" alt="" |
Gauss |
GS |
data:image/s3,"s3://crabby-images/d5f9d/d5f9d78913d9c218ec1af346ddf9bd754bf4e836" alt="" |
- The available compact support RBFs are (see Wendland H., Konstruktion und Untersuchung radialer Basisfunktionen mit kompaktem Träger. PhD thesis, Göttingen, Georg-August-Universität zu Göttingen, Diss, 1996):
- ‘CP_C0’
- ‘CP_C2’
- ‘CP_C4’
- ‘CP_C6’
- ‘CTPS_C0’
- ‘CTPS_C1’
- ‘CTPS_C2a’
- ‘CTPS_C2b’
Compact support functions have the form
R is either the support radius for the compact support RBFs or a parameter to make the distance values dimensionless for the global support RBFs.
[fPar, M] = RBFparam(xs, ys, RBFtype, R)
returns the weights in the RBF summation and the polynomial coefficients in a column vector fPar by solving a linear system
[y] = RBFeval(xs, x, fPar, RBFtype, R)
returns the values of the interpolation weighted function at points x by performing the matrix-vector product
Running the example
An example case can be run just by typing in the Matlab command line
test
References
- Beckert, Armin and Wendland, Holger. Multivariate interpolation for fluid-structure-interaction problems using radial basis functions. Aerospace Science and Technology, 5 (2), p. 125-134, 2001.
- Wendland, Holger. Konstruktion und Untersuchung radialer Basisfunktionen mit kompaktem Träger}. PhD thesis, Göttingen, Georg-August-Universität zu Göttingen, Diss, 1996.
- De Boer, A and Van der Schoot, MS and Bijl, Hester. Mesh deformation based on radial basis function interpolation. Computers & structures, 85 (11-14), p. 784-795, 2007.
- Biancolini, Marco Evangelos. Fast Radial Basis Functions for Engineering Applications. Springer, 2018.