Filter löschen
Filter löschen

Interp2 - make resolution lower

11 Ansichten (letzte 30 Tage)
Grant
Grant am 7 Mär. 2013
I have a matrix 'I' representing a digital elevation model, with a pixel resolution of 90m. I need to lower the resolution to 250m and I've been advised to do this using interp2 but I'm unclear on how to do so from the help file?
I don't understand what I put as the X, Y, Z, Xi, Yi inputs.
Thank you
  8 Kommentare
Grant
Grant am 8 Mär. 2013
Hi, The output of size is:
ans =
4609 2737
Thanks
Grant
Grant am 8 Mär. 2013
I think previous error was just me mixing x and y, but it still tells me ??? Error using ==> interp2 at 147 XI and YI must be the same size or vectors of different orientations.

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

Matt J
Matt J am 8 Mär. 2013
XI and YI must be the same size or vectors of different orientations.
Xo must be a row vector and Yo must be a column vector. So just transpose Yo
ValOut= interp2(Xi, Yi, Values,Xo, Yo.'); %do the interpolation
  2 Kommentare
Grant
Grant am 8 Mär. 2013
Ahhh. I think it worked but seems futile as out of memory. (Using 250/90 processed but did it the wrong way round, increasing the resolution rather than lowering).
Doing it with 90/250 returns ??? Out of memory. Type HELP MEMORY for your options.
Error in ==> interp2>linear at 317 s = 1 + (arg4-arg1(1))/(arg1(end)-arg1(1))*(ncols-1);
Error in ==> interp2 at 220 zi = linear(ExtrapVal,x,y,z,xi,yi);
So I expect there is nothing I can do.
Thank you for your help.
Matt J
Matt J am 8 Mär. 2013
I assume you're using a 32-bit machine. Pre-converting your Values to type single would probably make it fit
ValOut= interp2(Xi, Yi, single(Values),Xo, Yo.');
Or, look for a 64-bit computer to work on.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (2)

Matt J
Matt J am 7 Mär. 2013
Bearbeitet: Matt J am 7 Mär. 2013
I would advise using griddedInterpolant instead
F=griddedInterpolant(I);
Now evaluate F at the sample locations that you want. So, for example, if you want the resulting image to be 100x250, you would do
x=linspace(1,size(I,1),100);
y=linspace(1,size(I,2),250);
I_new = F({x,y});

Grant
Grant am 8 Mär. 2013
Thanks, but it appears I don't have griddenInterpolant in my toolbox.
I'd also prefer to use interp2 to ensure I'm consistent with another person's method.
  2 Kommentare
Matt J
Matt J am 8 Mär. 2013
Bearbeitet: Matt J am 8 Mär. 2013
Thanks, but it appears I don't have griddenInterpolant in my toolbox.
What MATLAB version are you using? It would have to be several years old. You've spelled griddedInterpolant incorrectly, so that might be why you couldn't find it.
I'd also prefer to use interp2 to ensure I'm consistent with another person's method.
INTERP2 calls griddedInterpolant to perform its interpolations. It would be the same method, just with a somewhat easier (IMO) interface.
Grant
Grant am 8 Mär. 2013
I'm using R2010a. I typed it correctly into the command window and it can't find it - nor for the help file. The same on my university computer. :/

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Interpolation finden Sie in Help Center und File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by