Source code for pycif.plugins.datastreams.fluxes.becker_ocean.get_domain
import numpy as np
from logging import debug
import os
import warnings
import xarray as xr
from xarray import SerializationWarning
import itertools
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):
"""Read information from the reference file
to define the data horizontal and, if relevant, vertical domain.
Args:
ref_dir (str): the path to the input files
ref_file (str): format of the input files
input_interval (list): simulation interval (start and end dates)
target_dir (str): where to copy
tracer: the tracer Plugin, corresponding to the paragraph
:bash:`datavect/components/fluxes/parameters/my_species` in the
configuration yaml; can be needed to fetch extra information
given by the user
Return:
domain (Domain): a domain class object, with the definition of the center grid
cells coordinates, as well as corners
"""
ref_file = list(itertools.chain.from_iterable(tracer.input_files.values()))[0]
if not os.path.isfile(ref_file):
raise Exception(
"Could not initialize the domain as no reference file is available. "
"Expecting the following file: {}".format(ref_file))
# Grid cell centers
with warnings.catch_warnings():
warnings.simplefilter('ignore', category=SerializationWarning)
coords = xr.open_dataset(ref_file)[["latitude", "longitude"]]
lat = coords["latitude"].values
lon = coords["longitude"].values
nlat = len(lat)
nlon = len(lon)
zlon, zlat = np.meshgrid(lon, lat)
# Grid cell corners
dlat = np.unique(np.diff(lat))[0]
dlon = np.unique(np.diff(lon))[0]
latc = np.append(lat - dlat / 2, lat[-1] + dlat / 2)
lonc = np.append(lon - dlon / 2, lon[-1] + dlon / 2)
zlonc, zlatc = np.meshgrid(lonc, latc)
# Vertical definition (surface level)
pressure_unit = "Pa"
nlev = 1
sigma_a_mid = np.array([0])
sigma_b_mid = np.array([1])
# Put it to a domain Plugin
domain = Domain(nlon=nlon, nlat=nlat,
zlon=zlon, zlat=zlat,
zlonc=zlonc, zlatc=zlatc,
nlev=nlev, pressure_unit=pressure_unit,
sigma_b_mid=sigma_b_mid, sigma_a_mid=sigma_a_mid)
return domain