Error using  '  during Transpose 3D variable from .nc file (error: "Transpose on ND array is not defined. Use PERMUTE instead.")

3 visualizaciones (últimos 30 días)
Hi all,
I am trying to transpose data using ' (e.g. A=A') but its showing error "Transpose on ND array is not defined. Use PERMUTE instead.". Could anyone help me to fix the error? For the 3D data variable I have used the following code to interpolate and to solve the problem:
File='trmm.1998.2010.nc'
rf=double(ncread(File, 'rf'));
time=double(ncread(File, 'time'));
lon=double(ncread(File, 'lon'));
rain=rf'
rain(isinf(rain)|isnan(rain))=0;
RF=griddedInterpolant({lon,flip(lat),time},flip(rain,1));
newdata=RF({LN,LT,time});
The following error is showing during riddedInterpolant command:
Error using griddedInterpolant
The grid vectors must be strictly monotonically increasing.
## THIS IS THE DATA DETAILS ##
==============
Name Size Bytes Class Attributes
lat 252x1 2016 double
lon 317x1 2536 double
rain 317x252x4748 3034313856 double
time 4748x1 37984 double
=========
  5 comentarios
Walter Roberson
Walter Roberson el 28 de En. de 2020
I needed to see the output of those issorted() and comparison calls .
Soumik Ghosh
Soumik Ghosh el 29 de En. de 2020
Hi Walter,
You can get the details from the attachment. Please let me know if you need anything more.
Thanks.lat.jpg

Iniciar sesión para comentar.

Respuesta aceptada

Rik
Rik el 29 de En. de 2020
I suspect you don't want to interpolate, but you just want to flip the first two dimensions. In that case you can just listen to the error message:
new_rain=permute(rain,[2 1 3]);
  5 comentarios
Rik
Rik el 1 de Feb. de 2020
You keep changing what you want. Do you want to interpolate your data to a new grid, calculate the complex conjugate, calculate the inner product, or something else?
The root of your problem seems to be that what you want doesn't work in 3D, but does in 2D. Can you write a complete example of what it is you want for a 2D example so we can try to help you extend that to 3D. Otherwise we'll keep going around in circles.
Soumik Ghosh
Soumik Ghosh el 5 de Feb. de 2020
Sorry for late response!
The problem has been solved by using
new_rain=permute(rain,[2 1 3]);
and afterwords 'reshape' command.
Thnaks a lot!

Iniciar sesión para comentar.

Más respuestas (1)

Soumik Ghosh
Soumik Ghosh el 28 de En. de 2020
Hi Rik,
Yes!
There is few modification in the script:
-------------------------------------------------
File='trmm.2010.nc'
rf=double(ncread(File, 'rf'));
time=double(ncread(File, 'time'));
lon=double(ncread(File, 'lon'));
lat=double(ncread(File, 'lat'));
ds = 0.25 ;
LN = min(lon):ds:max(lon) ;
LT = min(lat):ds:max(lat) ;
[LN,LT] = meshgrid(LN,LT) ;
rain=rf;
rain(isinf(rain)|isnan(rain))=0;
RF=griddedInterpolant({lon,lat,time},rain);
newdata=RF({LT,LN,time});
-------------------------------------------
Now the error is
Error using griddedInterpolant/subsref
Grid vector is not properly defined.
Error in Data_Regrid (line 21)
newdata=RF({LT,LN,time});
Regards

Categorías

Más información sobre Matrix Indexing en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by