Source code for pycif.plugins.datastreams.fields.noaa_glob_avg.get_domain
import datetime
import glob
import os
import numpy as np
import xarray as xr
from .....utils.classes.setup import Setup
from .....utils.classes.domains import Domain
[docs]
def get_domain(ref_dir, ref_file, input_interval, target_dir, tracer=None):
# Looking for a reference file to read lon/lat in
list_file = glob.glob("{}/*nc".format(ref_dir))
# Either a file is specified in the Yaml
domain_file = None
if ref_file in list_file:
domain_file = "{}/{}".format(ref_dir, ref_file)
# Or loop over available file regarding file pattern
else:
for flx_file in list_file:
try:
date = datetime.datetime.strptime(
os.path.basename(flx_file), ref_file
)
domain_file = flx_file
break
except ValueError:
continue
if domain_file is None:
raise Exception(
"EDGARv5 domain could not be initialized as no file was found"
)
# Read lon/lat in
nc = xr.open_dataset(domain_file, decode_times=False)
lonc = np.concatenate([nc["longitude"].values, [180]])
latc = np.concatenate([nc["latitude"].values, [90]])
zlonc, zlatc = np.meshgrid(lonc, latc)
lon = 0.5 * (lonc[1:] + lonc[:-1])
lat = 0.5 * (latc[1:] + latc[:-1])
zlon, zlat = np.meshgrid(lon, lat)
nlon = lon.size
nlat = lat.size
# Initializes vertical resolution
pres = nc["pressure"]
nlev = len(pres)
sigma_a_mid = pres.values
sigma_b_mid = 0. * pres.values
# Initializes domain
domain = Domain(
nlon=nlon, nlat=nlat, zlon=zlon, zlat=zlat,
zlonc=zlonc, zlatc=zlatc,
pressure_unit="Pa", lon_cyclic=True, nlev=nlev,
sigma_a_mid=sigma_a_mid, sigma_b_mid=sigma_b_mid,
)
return domain