Effacer les filtres
Effacer les filtres

Interp2 - make resolution lower

11 vues (au cours des 30 derniers jours)
Grant
Grant le 7 Mar 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 commentaires
Grant
Grant le 8 Mar 2013
Hi, The output of size is:
ans =
4609 2737
Thanks
Grant
Grant le 8 Mar 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.

Connectez-vous pour commenter.

Réponse acceptée

Matt J
Matt J le 8 Mar 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 commentaires
Grant
Grant le 8 Mar 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 le 8 Mar 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.

Connectez-vous pour commenter.

Plus de réponses (2)

Matt J
Matt J le 7 Mar 2013
Modifié(e) : Matt J le 7 Mar 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 le 8 Mar 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 commentaires
Matt J
Matt J le 8 Mar 2013
Modifié(e) : Matt J le 8 Mar 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 le 8 Mar 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. :/

Connectez-vous pour commenter.

Catégories

En savoir plus sur Interpolation dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by