fastmath.interpolation
1d, 2d interpolation functions.
See more:
- Apache Commons Math
- Smile Interpolation(http://haifengl.github.io/smile/api/java/smile/interpolation/package-summary.html
- SSJ B-Spline
Note: Smile interpolators also extrapolate values outside range.
Input data
You provide data as sequence or double array.
1d interpolation
You provide two sequences:
xs
- x axis coorditanes, strictly monotonic (increasing)ys
- function values
See kriging-spline-interpolator
2d interpolation
This is grid based interpolation.
xs
- x axis coordinates, strictly monotonic (increasing)ys
- y axis coordinates, strictly monotonic (increasing)vs
- sequence of sequences of values (2d array) for all possible pairs. Array is column-wise:[ [first column] [second column] ...]
.
Examples
Examples below use following functions:
1d
2d
Categories
Other vars: akima-spline b-spline b-spline-interp bicubic bicubic-smile bilinear cubic-2d cubic-spline divided-difference interpolators-1d-list interpolators-2d-list kriging-spline linear linear-smile loess microsphere-2d-projection microsphere-projection monotone neville piecewise-bicubic polynomial rbf shepard spline step step-after step-before
Code snippets
1d interpolation
(defn interpolate
[f params & opts]
(let [fun (fn [x] (m/sin (* x (* 0.5 (m/cos (inc x))))))
xs [0.69 1.73 2.0 2.28 3.46 4.18 4.84 5.18 5.53 5.87 6.22]
ys (map fun xs)
interpolator ((apply partial f params) xs ys)]
(interpolator 5.0)))
2d interpolation
(defn interpolate2d
[f params & opts]
(let [fun (fn [x y]
(m/sin (* (/ (- x 100.0) 10.0) (m/cos (/ y 20.0)))))
xs [20 50 58 66 100 121 140 150 160 170 180]
ys [20 30 58 66 90 121 140 152 170 172 180]
vs (partition (count ys) (for [x xs y ys] (fun x y)))
interpolator ((apply partial f params) xs ys vs)]
(interpolator 105 155)))
akima-spline
(akima-spline xs ys)
Examples
Usage
(interpolate akima-spline ...)
;;=> 0.6825735245080953
Akima spline plot
data:image/s3,"s3://crabby-images/19f34/19f34fc2b20806ef44ff05c1df1f848181c992a6" alt=""
b-spline
(b-spline xs ys)
(b-spline degree-or-knots xs ys)
B-spline for given points, default degree equals samples count - 1.
Examples
Usage
(interpolate b-spline ...)
;;=> 0.5600852765013091
B-Spline plot
data:image/s3,"s3://crabby-images/f042b/f042b86744e59c7d8bd2ed6afe35f19c0c2f208a" alt=""
B-Spline plot (degree=1)
data:image/s3,"s3://crabby-images/7c2b4/7c2b49e05c7d3580c24e2d323e0a1ae7a3a03ee5" alt=""
B-Spline plot (with knots)
data:image/s3,"s3://crabby-images/b362e/b362e7025bc659bc4b1f6751de499d7f60dc4e5e" alt=""
b-spline-interp
(b-spline-interp xs ys)
(b-spline-interp degree xs ys)
(b-spline-interp degree h xs ys)
Examples
Usage
(interpolate b-spline-interp ...)
;;=> 0.6903406231405653
B-Spline interpolation plot
data:image/s3,"s3://crabby-images/f06c7/f06c784c9b7004ae085509d7db1fd5d036778be7" alt=""
B-Spline interpolation plot (degree=5)
data:image/s3,"s3://crabby-images/709f2/709f2d2d865effb1093470a63b9828037c73ddd9" alt=""
B-Spline interpolation plot (degree=3, h=6)
data:image/s3,"s3://crabby-images/b553f/b553fcd0d39864d743d7757a400e4f77909aafb6" alt=""
bicubic
(bicubic xs ys vs)
Bicubic 2d.
Grid based.
Source: Apache Commons Math.
Examples
Usage
(interpolate2d bicubic ...)
;;=> 0.07081337259133846
Bicubic plot
data:image/s3,"s3://crabby-images/f4550/f4550573fde267586d4391e7593c16a24f64c1ce" alt=""
bicubic-smile
(bicubic-smile xs ys vs)
Bicubic 2d.
Grid based.
Source: Smile.
Examples
Usage
(interpolate2d bicubic-smile ...)
;;=> 0.07081337259133846
Bicubic (Smile) plot
data:image/s3,"s3://crabby-images/73ce3/73ce3ec1adcaf78fa06a884c67fba683598ecffa" alt=""
bilinear
(bilinear xs ys vs)
Bilinear 2d.
Grid based.
Source: Smile.
Examples
Usage
(interpolate2d bilinear ...)
;;=> 0.062068616254939334
Bilinear plot
data:image/s3,"s3://crabby-images/07363/0736391a4b3efa9e5d46d7120bc2cdf8e1d7225f" alt=""
cubic-2d
(cubic-2d xs ys vs)
Cubic spline 2d.
Grid based.
Source: Smile.
Examples
Usage
(interpolate2d cubic-2d ...)
;;=> 0.053984474655155074
Cubic-2d plot
data:image/s3,"s3://crabby-images/424ab/424ab27fbb49590405616de2ee2b626104374245" alt=""
cubic-spline
(cubic-spline xs ys)
Cubic spline interpolation.
Source: Smile.
Examples
Usage
(interpolate cubic-spline ...)
;;=> 0.6809644344471792
Cubic spline plot
data:image/s3,"s3://crabby-images/be2cd/be2cd6eab69a898709cd856a5a977e76377b8561" alt=""
divided-difference
(divided-difference xs ys)
Create Divided Difference Algorithm for interpolation.
Source: Apache Commons Math.
Examples
Usage
(interpolate divided-difference ...)
;;=> 0.6789478287835669
Divided difference plot
data:image/s3,"s3://crabby-images/93db4/93db4b063d7dbaf6aa9ca26ca9495111ee40b465" alt=""
interpolators-1d-list
Map of 1d interpolation functions
Examples
List of names
(keys interpolators-1d-list)
;;=> (:linear-smile :divided-difference :rbf
;;=> :neville :step-after
;;=> :kriging-spline :cubic-spline
;;=> :spline :b-spline
;;=> :loess :step-before
;;=> :polynomial :shepard
;;=> :linear :microsphere
;;=> :monotone :step
;;=> :b-spline-interp :akima)
interpolators-2d-list
Map of 2d interpolation functions
Examples
List of names
(keys interpolators-2d-list)
;;=> (:bicubic :piecewise-bicubic
;;=> :microsphere-2d :bilinear
;;=> :bicubic-smile :cubic-2d)
kriging-spline
(kriging-spline xs ys)
Kriging interpolation.
Source: Smile.
Examples
Usage
(interpolate kriging-spline ...)
;;=> 0.6863915017789624
Kriging spline plot
data:image/s3,"s3://crabby-images/75c75/75c75244b53170c231b0a6cfc30c0fdbdbdb069d" alt=""
linear
(linear xs ys)
Create Divided Difference Algorithm for inqterpolation.
Source: Apache Commons Math.
Examples
Usage
(interpolate linear ...)
;;=> 0.6843915831251183
Linear (Apache) plot
data:image/s3,"s3://crabby-images/86da1/86da1c64c8dc663868bac40dbe8dfce6b406306e" alt=""
linear-smile
(linear-smile xs ys)
Linear interpolation from Smile library.
Source: Smile.
Examples
Usage
(interpolate linear-smile ...)
;;=> 0.6843915831251183
Linear (Smile) plot
data:image/s3,"s3://crabby-images/f077e/f077e5722518d4ec96dc7d7b061ac823995da95b" alt=""
loess
(loess xs ys)
(loess bandwidth robustness-iters xs ys)
(loess bandwidth robustness-iters accuracy xs ys)
Local Regression Algorithm
- bandwidth: 0.2-1.0 (optimal: 0.25-0.5, default: 0.4)
- robustness-iters: 0-4 (optimal: 0, default: 2)
- accuracy: double (default: 1e-12)
Source: Apache Commons Math.
Examples
Usage
(interpolate loess ...)
;;=> 0.6878279262016764
Loess plot
data:image/s3,"s3://crabby-images/6765b/6765b0f2d505d31a0f26178f6bcd2eeb87097896" alt=""
Usage (0.7, 2.0)
(interpolate loess 0.7 2 ...)
;;=> 0.5834139882299265
Loess (0.7, 2.0) plot
data:image/s3,"s3://crabby-images/9618f/9618f35567a33df6e00ef4bcfcd52296e5661a88" alt=""
Usage (0.2, 1.0)
(interpolate loess 0.2 1 ...)
;;=> 0.6809644344471794
Loess (0.2, 1.0) plot
data:image/s3,"s3://crabby-images/23bf9/23bf9acb03b2be579da4522c9052dc75562f252d" alt=""
microsphere-2d-projection
(microsphere-2d-projection elements max-dark-friction dark-threshold background exponent shared-sphere? no-interpolation-tolerance xs ys vs)
Microsphere projection interpolator - 2d version
Grid based.
Source: Apache Commons Math.
Examples
Usage
(interpolate2d microsphere-2d-projection
10 0.5
1.0E-4 0.5
1.5 false
0.1 ...)
;;=> 0.016695534028974824
Microsphere 2d plot
data:image/s3,"s3://crabby-images/a51db/a51db83eac49f0fef42e183be53feda3f72f53e1" alt=""
microsphere-projection
(microsphere-projection elements max-dark-friction dark-threshold background exponent shared-sphere? no-interpolation-tolerance xs ys)
Microsphere projection interpolator - 1d version
Source: Apache Commons Math.
Examples
Usage
(interpolate microsphere-projection 6 0.1 0.1 0.1 1.5 false 0.01 ...)
;;=> 0.640659702573876
Microsphere plot
data:image/s3,"s3://crabby-images/1596f/1596f4856a268e98bc5528e10d74c1ceaa5166cb" alt=""
monotone
(monotone xs ys)
Monotone interpolation
Examples
Usage
(interpolate monotone ...)
;;=> 0.7094972531399422
Monotone plot
data:image/s3,"s3://crabby-images/517b2/517b2fefeb6f7450aaf0677cbb4c5dc4f6b74355" alt=""
neville
(neville xs ys)
Neville algorithm
Source: Apache Commons Math.
Examples
Usage
(interpolate neville ...)
;;=> 0.6789478287835672
Neville plot
data:image/s3,"s3://crabby-images/1a63c/1a63cf12fada609314571dcd341c5e3a9206a1e5" alt=""
piecewise-bicubic
(piecewise-bicubic xs ys vs)
Piecewise bicubic 2d.
Grid based.
Source: Apache Commons Math.
Examples
Usage
(interpolate2d piecewise-bicubic ...)
;;=> 0.06876424996210916
Piecewise bicubic plot
data:image/s3,"s3://crabby-images/54a04/54a0476f8d4b707de1ac1fe327515835bb73affc" alt=""
polynomial
(polynomial xs ys)
Polynomial interpolation.
Examples
Usage
(interpolate polynomial ...)
;;=> 0.6789478287861641
Polynomial plot
data:image/s3,"s3://crabby-images/5db61/5db61848db4200a725a7fe44556475461dbdd243" alt=""
rbf
(rbf xs ys)
(rbf rbf-fn normalize? xs ys)
(rbf rbf-fn xs ys)
RBF (Radial Basis Function) interpolation.
Default kernel: :gaussian
Source: Smile
Examples
Usage
(interpolate rbf ...)
;;=> 0.6773457006293544
Rbf plot
data:image/s3,"s3://crabby-images/708ca/708ca0ed103452447ab62683905d2eee2e1d58b5" alt=""
Usage (mattern-c0 kernel)
(interpolate rbf (k/rbf :mattern-c0) ...)
;;=> 0.6747315645069648
Rbf (mattern-c0 kernel) plot
data:image/s3,"s3://crabby-images/87984/87984627468c5d405def432f76b75da9797d1f0a" alt=""
Usage (gaussian kernel, normalized)
(interpolate rbf (k/rbf :gaussian) true ...)
;;=> 0.6883452896663599
Rbf (gaussian kernel, normalized) plot
data:image/s3,"s3://crabby-images/a65c3/a65c3379826c34e1ada9e7010540fa583ff8e65b" alt=""
Usage (truncated-power kernel)
(interpolate rbf (k/rbf :truncated-power 3 0.3) ...)
;;=> 0.11727096867681523
Rbf (truncated-power kernel) plot
data:image/s3,"s3://crabby-images/c3c5a/c3c5a9fd194d1d76e2c6b986a2ce9c5909e38686" alt=""
Usage (wendland-53 kernel)
(interpolate rbf (k/rbf :wendland-53) ...)
;;=> 0.74837576670325
Rbf (wendland-53 kernel) plot
data:image/s3,"s3://crabby-images/11592/115923c8bc4da729928541a3855beefb133309ae" alt=""
shepard
(shepard xs ys)
(shepard p xs ys)
Shepard interpolation.
Source: Smile.
Examples
Usage
(interpolate shepard ...)
;;=> 0.6717576636886534
Shepard plot
data:image/s3,"s3://crabby-images/c276b/c276bc349c80dd7e85861ba2cb57f17751279eae" alt=""
Usage (0.9)
(interpolate shepard 0.9 ...)
;;=> 0.5225345022349268
Shepard (0.9) plot
data:image/s3,"s3://crabby-images/38d28/38d2891d9be26063e4519b3231789c3df52fa4b8" alt=""
spline
(spline xs ys)
Cubic spline interpolation
Source: Apache Commons Math.
Examples
Usage
(interpolate spline ...)
;;=> 0.6809644344471794
Spline plot
data:image/s3,"s3://crabby-images/10b3c/10b3c7ad59aaec8bd9c48e824f95e409d0f4d18b" alt=""
step
(step xs ys)
Step function.
Examples
Usage
(interpolate step ...)
;;=> 0.8165378262982225
Step plot
data:image/s3,"s3://crabby-images/b4e42/b4e429f64181ed9d356a42ad8702fc16b94438f8" alt=""
step-after
(step-after xs ys)
Step function.
Examples
Usage
(interpolate step-after ...)
;;=> 0.8165378262982225
Step (after) plot
data:image/s3,"s3://crabby-images/837fe/837fe57bbd97b86a208be8f3666f528ecb307903" alt=""
step-before
(step-before xs ys)
Step function.
Examples
Usage
(interpolate step-before ...)
;;=> 0.5357270595553765
Step (before) plot
data:image/s3,"s3://crabby-images/d957d/d957d0d681f739bf4b8cc39f3a470346577e5f75" alt=""