-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathc48.py
72 lines (59 loc) · 2.07 KB
/
c48.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import matplotlib.pyplot as plt
import netCDF4 as nc
import numpy as np
import cartopy.crs as ccrs
import cartopy.feature as cfeature
import os
datadir = '/work/noaa/da/weiwli/c48/gfs_land_c48/mem001/'
griddir = '/work/noaa/da/weiwli/c48/gfs_land_c48/grid/'
# one tile for now
tile=1
fname = os.path.join(datadir, f"20191215.180000.sfc_data.tile{tile}.nc")
oroname = os.path.join(griddir, f"C48_oro_data.tile{tile}.nc")
# read data and grid
ncdf = nc.Dataset(fname)
ncgf = nc.Dataset(oroname)
lat = ncgf.variables['geolat'][:]
lon = ncgf.variables['geolon'][:]
lon[np.where(lon>180)] = lon[np.where(lon>180)]-360
t127 = ncdf.variables['q2m'][0,-1,:,:]
# set up map
#ax = plt.axes(projection=ccrs.PlateCarree())
# define grid
#gnomonic = ccrs.Gnomonic(central_latitude=lat[384,384], central_longitude=lon[384,384])
# plot data
#ax.pcolormesh(lon, lat, t127)
##ax.pcolormesh(lon, lat, t127, transform=gnomonic)
#ax.coastlines(zorder=10)
#ax.set_global()
#plt.show()
# loop and try all six and get the min/max values
arr3d=np.empty((6,48,48))
lat3d=np.empty((6,48,48))
lon3d=np.empty((6,48,48))
for tile in range(1,7):
fname = os.path.join(datadir, f"20191215.180000.sfc_data.tile{tile}.nc")
oroname = os.path.join(griddir, f"C48_oro_data.tile{tile}.nc")
# read data and grid
ncdf = nc.Dataset(fname)
ncgf = nc.Dataset(oroname)
lat = ncgf.variables['geolat'][:]
lon = ncgf.variables['geolon'][:]
lon[np.where(lon>180)] = lon[np.where(lon>180)]-360
q2m = ncdf.variables['q2m'][0,-1,:,:]
# put these 2D arrays in the 3D arrays
arr3d[tile-1,...] = q2m
lat3d[tile-1,...] = lat
lon3d[tile-1,...] = lon
# get min/max for plotting
minval = np.nanmin(arr3d)
maxval = np.nanmax(arr3d)
# set up map
ax = plt.axes(projection=ccrs.PlateCarree())
# loop and plot data
cmaps=['jet', 'brg', 'terrain', 'gnuplot', 'coolwarm', 'RdGy']
for itile in range(0,6):
ax.pcolormesh(lon3d[itile], lat3d[itile], arr3d[itile], vmin=minval, vmax=maxval)
#ax.pcolormesh(lon3d[itile], lat3d[itile], arr3d[itile], vmin=minval, vmax=maxval, cmap=cmaps[itile])
ax.coastlines()
plt.show()