Make a plt from a 4-D multi array variable from nc file

I have a nc file with:
Dimensions:
time = 8
depth = 48
latitude = 109
longitude = 25
and make this:
u='global-reanalysis-phy-001-030-daily_1591804259623.nc'
ncdisp(u)
east = ncread(u,'uo');
lat = ncread(u,'latitude');
lon = ncread(u,'longitude');
time=ncread(u, 'time');
depth=ncread(u, 'depth');
dtime = datetime(1950, 1, 1, time, 0, 0);
jd=juliandate(dtime);
plot(lat, east(:,:,15,1));
east is a 4-D 8371200 double
But I want a plot (surfc) in time, this 8 days, latitude, one depth (lets say 48, the last) and the east variable that is a velocity m/s.
Any idea? What I should do with east variable? squeeze, quiver, etc realy dont know or find solution
Thanks.

1 Kommentar

KSSV
KSSV am 17 Jun. 2020
OP commented:
the plot(lat, east(:,:,15,1)) is working but only for one day if I change 1 for : then the error
Data cannot have more than 2 dimensions.

Melden Sie sich an, um zu kommentieren.

 Akzeptierte Antwort

KSSV
KSSV am 17 Jun. 2020
Bearbeitet: KSSV am 17 Jun. 2020
ncfile = "global-reanalysis-phy-001-030-daily_1591804259623.nc";
time = ncread(ncfile,'time') ;
depth = ncread(ncfile,'depth') ;
lat = ncread(ncfile,'latitude') ;
lon = ncread(ncfile,'longitude') ;
u = ncread(ncfile,'uo') ;
% plots
for i = 1:length(time) % time loop
for j = 1:length(depth) % depth loop
z = u(:,:,j,i)' ; % extract the matrix here
pcolor(lon,lat,z) ;
colorbar
shading interp
xlabel('lon')
ylabel('lat')
title(sprintf('time = %d, depth = %d',i,j))
drawnow
end
end

17 Kommentare

Thanks for you answer, I try but this came:
>> surf(lon,lat,east(:,:,1))
Error using surf (line 74)
Data dimensions must agree.
>> pcolor(lon,lat,east(:,:,2))
Error using pcolor (line 59)
Matrix dimensions must agree.
I make the squeeze .
Any idea?
try transposing the matrix..
surf(lon,lat,east(:,:,1)')
If not working share the dimensions of each variable here..
Thanks!
Here is the file
What i want is a plot in 2D
x=time
y=latitude
z=east
at specific depth.
KSSV
KSSV am 17 Jun. 2020
Edited the answer.
ok! I try it runs with out error but the plot is empty.
the z matrix is NaN
KSSV
KSSV am 17 Jun. 2020
All the matrices are not NaN....when depth is increasing....data is having NaN's....see the plot, it is in a loop..it is plotting all the values..
I add this to your answer:
nx = length(lon);
ny = length(lat);
nd=length(depth);
nt=length(time);
that I saw you make in other question and works but is like running the time and depths like animation
but still the cordinates are lat and long
KSSV
KSSV am 17 Jun. 2020
Okay..I got it..you want to plot for specific depth, all the time data...
For this case, you need to fix the range of lat and lon...
ok! yes I understand so how can I make the plot time vs lat with u as 3 variable
ncfile = "global-reanalysis-phy-001-030-daily_1591804259623.nc";
time = ncread(ncfile,'time') ;
depth = ncread(ncfile,'depth') ;
lat = ncread(ncfile,'latitude') ;
lon = ncread(ncfile,'longitude') ;
u = ncread(ncfile,'uo') ;
% plots
for i = 1:length(lon)
ud = squeeze(u(:,i,1,:)) ;
pcolor(lon,time,ud')
shading interp ;
colorbar
title(sprintf("depth = 1, lat rows = %d",i)) ;
drawnow
pause
end
KSSV
KSSV am 17 Jun. 2020
This is called Hovmoller diagrams ..am I right?
ok! thanks I think I can change to axe x time and to y latitude
great!
Yes Hovmoller! I just start with this this week and try with few data now came the big things...
so what is doing: ud = squeeze(u(:,i,1,:))
thanks!
KSSV
KSSV am 17 Jun. 2020
You can try it your self......check the dimensions before and after squeeze.
squeeze : it will remove the unwanted extra dimensions
yes! thanks a lot!

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Graphics Object Properties finden Sie in Hilfe-Center und File Exchange

Gefragt:

am 17 Jun. 2020

Kommentiert:

am 17 Jun. 2020

Community Treasure Hunt

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

Start Hunting!

Translated by