interp1 fails to interpolate correctly
Show older comments
I have a set of input data which the function interp1 is incorrectly interpolating.
For a statement Vq = interp1(X,V,Xq), I have
X =
-0.0124393747904463
0.0134396235257952
0.0344412390769423
0.0850313641677704
0.0850004675375172
0.126329531171773
V =
-4
-2
0
2
4
6
Clq =
0.0772456107479591
The result interp1 gives me is Vq = 3.3864734865877. This is clearly wrong, but may be related to the face that between V = 4 and V =6, X is not monotonically increasing/decreasing. Can someone help me understand why this is failing?
Accepted Answer
More Answers (1)
Vladimir Sovkov
on 18 Nov 2019
0 votes
Why do you consider it is wrong? In the plot (see the attachment) this result looks quite reasonable.
5 Comments
Nate
on 18 Nov 2019
Vladimir Sovkov
on 19 Nov 2019
Do you mean that your dependence really goes from the third to the fourth point and then from the fourth point to the fifth one? As the fifth X is smaller than the fourth one, it makes the dependence to be double-valued between the fourth and fifth points. Matlab's interp1 deals with functions alone, i.e. with the one-to-one mappings, no double-valued dependences are allowed. Consequently, it sorts your data in the accending order of X switching your fourth and fifth points in order to make it actual function. In the sorted version, your Clq is between the 3rd and 5th (new 4th) points. This interp1 is unapplicable to double-valued dependencies and, if this is really the case, you should find another way to interpolate it. Maybe, you can just drop out the 5th and 6th points....
Nate
on 19 Nov 2019
Walter Roberson
on 19 Nov 2019
polynomial fits cannot solve double-valued functions.
Sometimes you should use a function of two variables instead.
Sometimes you can rewrite as a parameteric function.
Sometimes you just need to segment to decide which function is in control. For example hysterisis has to be handled as a pair of functions, not by trying to fit one single function.
Vladimir Sovkov
on 19 Nov 2019
Maybe, switching roles of X and V can help, e.g.:
VV=fzero(@(z)(interp1(V,X,z)-Clq),1)
VV=1.69220264208349
Categories
Find more on Interpolation of 2-D Selections in 3-D Grids in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!