griddedInterpolant error "Interpolation requires at least two sample points for each grid dimension."
Show older comments
I'm systematically getting this error trying to use griddedInterpolant. Here's a simple example:
bp1 = [0:1:10];
bp2 = [5:0.5:10];
bp3 = [2:0.1:3];
tv = bp1.*bp3+bp2.^2
f=griddedInterpolant(bp1,bp2,bp3,tv)
But I get the error:
Error using griddedInterpolant
Interpolation requires at least two sample points for each grid dimension.
What have I missed?
Answers (2)
The points (bp1, bp2, bp3) in 3d space do not form a grid. They are equally-spaced points along a line segment from (0,5,2) to (10,10,3).
You can use ndgrid to construct a set of points that form a grid from your bp1, bp2, bp3 vectors.
bp1 = 0:1:10;
bp2 = 5:0.5:10;
bp3 = 2:0.1:3;
% tv = bp1.*bp3+bp2.^2;
[BP1,BP2,BP3] = ndgrid(bp1,bp2,bp3);
TV = BP1.*BP3+BP2.^2;
f=griddedInterpolant(BP1,BP2,BP3,TV)
5 Comments
Dave Hall
on 3 Dec 2023
Another approach which does not create large arrays BP1, BP2, BP3, is to simply RESHAPE the vectors to have the correct orientations (note that RESHAPE is a very efficient command):
BP1 = reshape(0:1:10, [],1,1);
BP2 = reshape(5:0.5:10, 1,[],1);
BP3 = reshape(2:0.1:3, 1,1,[]);
TV = BP1.*BP3+BP2.^2;
f = griddedInterpolant({BP1(:),BP2(:),BP3(:)},TV)
Dave Hall
on 3 Dec 2023
Stephen23
on 3 Dec 2023
Either call RESHAPE on each column of data.
Or simply call SCATTEREDINTERPOLANT and let it do the work for you.
Dave Hall
on 3 Dec 2023
Star Strider
on 3 Dec 2023
0 votes
The interpn function could be an option. You will need to experiment with the ndgrid function to determine how best to reshape the first 5 columns of your data to conform to it (if they indeed need reshaping — they may not) and then do the interpolation. I am not certain how easy it would be to make sense of the results, much less plot them, since everything in this universe is limited to 3 spatial dimensions and time, last I heard.
If you only want to interpolate specific points or ranges of points within the limits of the original vectors (so not extrapolating), interpn could do what you want.
Categories
Find more on Logical 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!