CDXWRFcore
Core variables
UNDER CONSTRUCTION
These are the basic variables required by CORDEX. Most of them are standard fields and therefore tend to require simple calculations from the currently available variables from the WRF model. These variables are obtained by setting the pre-compilation flag CORDEXDIAG, and will appear in two different files: 3D variables at pressure levels (the WRF model internally interpolate them since it uses the η coordinate in the vertical) will appear in the output file with the 23rd stream (mainly called wrfpress), and the 2D variables in the module's output file wrfcdx.
3D at pressure-levels
These are the additional variables which have been added into the WRF pressure-level integration module. Their values will be written in the 23rd output stream in addition to the ones currently available. All of them are instantaneous values.
hus: humidity
3D atmospheric specific humidity (hus) 1 and relative humidity (hur) are computed at the unstaggered model η levels. Specific humidity is simply obtained from water vapor mixing ratio using equation 2 (named QV AP OR in WRF). Relative humidity can be obtained following the Clausius-Clapeyron formula and its approximation from the well-known August-Roche-Magnus formula for saturated water vapor pressure.
where rv: mixing ratio (kgkg-1), with tempC: being temperature in degree Celsius (◦C), presshPa: pressure (hPa), es: saturated water vapor pressure (hPa), ws: saturated mixing ratio (kgkg-1).
press: air-pressure
WRF model integrates the perturbation of the pressure field from a reference one. Thus to obtain the full pressure at unstaggered model η levels, it is required to combine two different fields as shown in equation 6,
where PB, WRF base pressure (Pa), P, WRF perturbation pressure (Pa)
ta: air-temperature
This variable states for the 3D atmospheric temperature on unstaggered model η levels. WRF model equations are based on the perturbation of potential temperature, therefore a conversion to actual temperature is required, and it is performed as indicated by equation 7,
where T, WRF temperature (K, which is as potential temperature), PB, WRF base pressure (Pa), P, WRF perturbation pressure (Pa), p0: pressure reference 100000 (Pa)
ua/va: Earth roteted wind components
These variables state for the 3D atmospheric wind components following Earth coordinates on standard model η levels. WRF model equations use the Arakawa-C horizonatally staggered grid with wind components following the grid direction. In order to get actual winds following the Earth geographical coordinates, a transformation shown in equation 8 is required,
where Ustg: x-staggered WRF eastward wind (ms-1, [1,dimx+1]), Vstg: y-staggered WRF northward wind (ms -1, [1,dimy+1]), Uunstg: unstaggered WRF eastward wind (ms-1, [1,dimx]), Vunstg: unstaggered WRF northward wind (ms-1, [1,dimy]), cosa: local cosine of map rotation (1), sina: local sine of map rotation (1).
zg: geopotential height
As in the case of air-pressure, WRF model also integrates the perturbation of the geopotential field from a reference or base one. Thus to obtain the full geopotential height on staggered model η levels, it is required to combine the two WRF fields andit is also destaggered as it is shown in equation 9,
where PHB, WRF base geopotential height (m2s-2), PH, WRF perturbation geopotential height (m2s-2), zgstaggered: staggered geopotential height k=[1, dimz+1], zg: un-staggered geopotential height k=[1, dimz]
2-dimensional
Here is provided the list of the the added 2-dimensional CORDEX variables. Some of them are diagnosed as a combination of 3-dimensional variables, some are required as instantaneous values, and others as statistics. The fact that the module provides 2D variables online using 3D fields, shows one more key advantage of the module related to disk space. Thanks to these online calculations when using the module, a user does not need anymore to store large amount of 3D data from the model in order to post-process them. This reduces the requirements of disk space by a factor of around 2.
pr, prc, prl, prsh, prsn: precipitation fluxes
The total precipitation flux (pr) is computed as the sum of all types of precipitation fields in the model accumulated along the 9th stream output frequency (9freq) divided by this period of time (9freq), as it is shown in equation 10,
where RAINCV: instantaneous precipitation from cumulus scheme (kgm-2), RAINNCV: instantaneous precipitation from microphysics scheme (kgm-2), RAINSHV: instantaneous precipitation from shallow-cumulus scheme (kgm-2), Nsteps: number of time steps, and δt: time step length (s) to achieve the 9th stream frequency output time (9f req = N steps × δt). In this version, the computation of the accumulated values does not take into account configurations of the model with adaptive time-step. When adaptive time-step is used, we strongly discourage the use of these variables.
Each individual precipitation flux is also provided as:
Solid precipitation flux (prsn) only accounts for frozen precipitation. Depending on the selected micro-physics scheme chosen in the `namelist', this variable might account for the precipitation of snow, graupel and hail. It is computed as it is shown in equation 12,
where prins: instantaneous total precipitation (kg-2, previously obtained), SR: fraction of solid precipitation (%, variable provided by WRF).
Radiative flux
Surface upwelling shortwave radiation flux (rsus, W gm −2 ) and surface upwelling longwave radiation flux (rlus, W gm-2) are understood as the shortwave and longwave radiation from Earth's surface. They are directly provided by radiation schemes CAM 2 and RRTMG 3 (sw_ra_scheme = 3,4) as instantaneous variables swupb and slupb. When there is no use of such schemes, it is recommended to use the `generic' definition instead (rsusgen, rlusgen, see in next section). Statistical retrieval for the surface fluxes follows the same methodology as for the precipitation fluxes.
Outgoing radiative fluxes at top the atmosphere are also provided being `rsut' for mean Top of the Atmosphere (TOA) outgoing shortwave radiation (in Wgm-2) and `rlut' for longwave. However there is not a `generic' implementation of these variables.
sund: duration of sunshine
This variable accounts for the the sum of the time for which the direct solar irradiance (downwelling short-wave radiation, rsds) exceeds 120 Wm-2 (WMO, 2010a) implemented following equation 13 and provided in seconds. In order to provide an example of the correct implementation of this diagnostics preliminary results are shown in figure 2. The figure shows the `sund' values and compare them with the incoming solar radiation. It is shown how the `sund' values vary accordingly to the moment of the day with zero values during night (left panel) or persistent totally cloud covered regions (map at the right panel)
where SWDOWN: downward shortwave radiation (W m-2), δt: time-step length (s).
tauuv: surface downward wind stress
Instantaneous surface downward wind stress at 10m accounts for the force that winds exerts on the Earth's surface. It is implemented following the equation 14
where, CD: drag coefficient (1), uas: Earth-rotated eastward 10 m surface wind (ms-1), vas: Earth-rotated northward 10 m surface wind (ms-1). The drag coefficient is non-zero only for certain options of the surface layer physics (sf_sfclay_physics parameter in the namelist): 1 (MM5-similarity), or 5 (MYNN surface layer). A `generic' formulation has been introduced when these schemes are not used.
psl: sea level pressure
This variable accounts for the instantaneous pressure extrapolated to the sea level. It represents the value of the pressure without the presence of orography. In order to provide a framework ready to implement different methodologies, three different methods have already been implemented. The choice of the method can be controlled by a new namelist.input parameter labeled psl_diag in cordex section. The implemented methods are:
- The hydrostatic-Shuell method (Stackpole and Cooley, 1970) already implemented in the the module phys/module_diag_afwa.F, assuming a constant lapse-rate of -6.5 Kkm-1 , selected when in WRF 'cordex' namelist section setting the parameter [psl_diag = 1]
- The 'ptarget' method (Benjamin and Miller, 1990) that uses smoothed surface pressure and a target upper-level pressure, already implemented in the WRF post-processing tool called p_interp.F90[psl_diag = 2]
- The ECMWF method (Yesad, 2015) taken from the Laboratoire de Météorologie Dynamique GCM (LMDZ; Hourdin et al., 2006) from the module pppmer.F90, following the methodology by Mats Hamrud and Philippe Courtier from ECMWF [psl_diag = 3]
Cloud derived variables
Four cloud derived variables are required by CORDEX: the total cloudiness (clt) and the cloudiness for each grid point at three different vertical layers above ground (low: p ≥ 680h Pa, labeled cll; medium: 680 < p ≥ 400 hPa, clm; high: p < 400 hPa, clh). These cloud diagnostics are provided as mean values.
The module computes these variables taking the cloud fraction of a given grid cell and level as input. The cloud fraction in WRF is computed by the radiative scheme, and it is called at a frequency given by radt parameter in WRF namelist.
Due to the large computational cost of the radiative scheme, radt usually is larger than the time-step of the simulation. This determines when cloud fraction is also actualized to meet the evolved atmospheric conditions. Cloud fractions can be computed in the model using different methodologies. It would be possible to make available these methodologies as another choice in the namelist section and then compute the cloud fraction at each time-step. However, in order to be consistent with the radiative cloud effects that the simulation is experiencing, this method was discarded. Thus, the cloud values provided by the module follow the same frequency of refreshing rate as the one set for radiation in the namelist level (radt value). The most common implementation of `clt' found in other models (in particular most GCMs) assumes `random overlapping'. Random overlapping assumes that adjacent cloud layers are from the same system, hence are maximumly overlapped (Geleyn and Hollingsworth, 1979). In the module, the methodology from the GCM LMDZ was implemented. In this GCM, calculation of the total cloudiness and different layers' cloudiness is done inside the subroutine newmicro.f90. The method basically consists in a product of the consecutive non-zero values of cloud fraction as it is shown in equation 15,
where CLDFRAC: cloud fraction (1) at each vertical level, zclear: clear-sky value (1), zcloud: cloud-sky value (1), ZEPSEC: value for very tiny number. Same methodology as in equation 15 is applied for the diagnostic of `clh', `clm' and `cll' but splitting by corresponding pressure layers. The figure 4 illustrates the result of the implementation and compare the results with the actual values of the cloud fraction (a and b panels) as well as the different cloud distribution (panels c to f).
Wind derived variables
CORDEX requires two wind-derived diagnostics: the daily maximum near-surface wind speed of gust (wsgsmax) and the daily maximum wind speed of gust at 100m above ground (wsgsmax100). These variables can not be retrieved by post-processing the standard output since they require the combination of different variables (some of them not available from the model output) and have to be produced as a maximum value. The module provides different ways to compute them under certain limitations.
wsgsmax: maximum near-surface wind speed of gust
The wind gust accounts for the wind from upper levels that is projected to the surface due to instability within the planetary boundary layer. In the current version of the module two complementary methods of diagnosing the variable have been implemented (resultant winds are Earth-rotated). The choice between the two methods is done by the parameter labeled wsgs_diag (in cordex section), with the default value set to 1. The implemented methods are:
- The Brasseur method [wsgs_diag = 1]: An implementation of wind gust considering Turbulent Kinetic Energy (TKE) estimates and stability defined by virtual temperature (θ v ) as indicated in equation 16 following Brasseur (2001). Implementation is adapted from a version already introduced in the CLimate WRF ([clWRF]; Fita et al., 2010),
where TKE: Turbulent Kinetic Energy (m2s-2), θv: virtual potential temperature (K). zp height of the considered parcel (m, maximum height which satisfies equation 16), ∆θv (z): variation of θ>SUB>v over a given layer (Km-1).
- The AFWA method [wsgs_diag = 2]: An implementation adopted from the WRF modulemodule_diag_afwa.Fwhich calculates the wind gust that only occurs as a blending of upper-level winds zagl (around 1 km above ground; zagl(k1000) ≥ 1000 m, see equation 17) when precipitation intensity per hour is above a given maximum value, prate mm
where va: air wind (ms-1), zagl: height above ground (m), k_1000: vertical level at which zagl is equal or above 1000 m. prate mm), va blend : blended wind (ms-1) hr: hourly precipitation rate (mmh-1)
The two methods provide wind gust estimation (WGE) from two different perspectives: mechanic and convective. In order to take into account both perspectives, additional variables: totwsgsmax (total maximum wind-gust speed at surface), totugsmax (total maximum wind-gust eastward speed at surface), totvgsmax (total maximum wind-gust northward speed at surface), and totwsgspercen (percentage of time steps along 9freq in which grid point got wind gust (%). Figure 5 shows the outcomes when applying each method. It is shown how wind gust is mainly originated by instability, with a minor impact of heavy precipitation events at the given time. Furthermore, in the bottom panel it is shown how wind-gusts are highly frequent above the sea in comparison to the low frequency above continental flat areas (Andes mountain range exhibits high occurrence of wind gust).
wsgsmax100: daily maximum wind speed of gust at 100 m
The calculation of wind gust at 100 m should follow a similar implementation used for calculating the wsgsmax, but at 100 m. An extrapolation of such turbulent phenomena would require a complete new set of equations which have not been placed yet. However, it could be considered as first approach to take the same wind gust as the one at the surface (when it is deflected from above 100 m). The assumption would be that the wind gust at 100 m would correspond to the deflected wind on its `way' to the surface. Instead, as a way to complement, the estimation of maximum wind speed at 100 m is provided. Provided wind components are also Earth-rotated. Three different methods have been implemented. Two following per-assumed vertical wind profiles (after PhD thesis Jourdier, 2015) and a third one following Monin-Obukhov theory to estimate the wind components above ground. These three methods are chosen by the namelist parameter labeled wsz100_diag. Its default value is 1. The implemented methods are:
- [wsz100_diag = 1], following the power-law wind vertical distribution as depicted in equation 18 using the upper-<>level atmospheric wind speed below (k 100 ) and above (k 100) the height above ground of 100 m (zagl), va 100
- [wsz100_diag = 3], following Monin-Obukhov theory. User should keep in mind that this method is not useful for heights larger than few decimeters (z > 80 m). The wind at given height is extrapolated following turbulent mechanisms. As it is shown in equation 20, surface wind speed is used as surrogate to estimate 100 m wind direction (θ10 = tan−1(uas, vas), without considering Eckman pumping, or other effects on wind direction). In this implementation u ∗ in similarity theory is taken as WRF estimates UST, Monin-Obukhov length (LO) as the WRF values RMOL, roughness length (z0) as WRF thermal time-varying roughness length ZNT,
where ΨM: stability function after (Businger et al., 1971), UST: u∗ in similarity theory (ms-1), z0: roughness length (m), U10, V10: 10-m wind speed (ms-1 ), theta10: 10-m wind speed direction (rad), ua100: 100 m eastward wind speed (ms-1), va100: 100 m northward wind speed (ms-1). Note the absence of correction in wind direction to Ekman pumping or other turbulence effects.
The user can also select the height at which the estimation is computed throughout the namelist parameter z100m_wind [100 m as default value].
Vertically integrated variables
The instantaneous vertically integrated amount of water vapor (prw), liquid condensed water species (clwvi), ice species (clivi), graupel (clgvi), hail (clhvi) are the vertically integrated amounts of each species along the vertical column (density weighted) over each grid point. They are provided using the same implementation as those in p_interp.F - WRF tool for vertical interpolation. The general equation following WRF standard variables is:
where clvivar: the column vertically integrated variable's CF-compliant name (prw, clwvi, clivi, clgvi, or clhvi), MU: perturbation dry air mass in column (Pa), MUB: base-state dry air mass in column (Pa), g: gravity (ms-2), e_vert: total number of vertical levels, WRFVAR: the water species' mixing ratio at each sigma level (kgkg-1), DNW: difference between two consecutive full-eta levels (-). Table 3 indicates the WRFVAR names associated with the clvivar names.
evspsblpot: potential evapotranspiration
This variable represents the evaporative demand of the atmosphere. It is computed following the standard method already implemented in most GCMs. One of the first proposed methods was provided by Manabe (1969). Some corrections have been proposed to the initial methodology in order to overcome its deficiencies (e.g. see Barella-Ortiz et al. (2013) for an intercomparison among different methods). It is provided as a statistical flux. Calculation of the potential evapotranspiration can be activated with the namelist input parameter potevap_diag (number 2 is the default option):
- bulk method [potevap_diag = 1]: this method corresponds to the original one proposed in Manabe (1969). It basically consists in a difference between a supposed saturated air at the surface temperature and the humidity of the atmosphere as it is depicted in equation 22,
where ws(ts): saturated air at ts (kgkg-1), qc: surface drag coefficient (ms-1), TSK: surface temperature (K), ws(ts): saturated air by surface temperature (kgkg-1) based on August-Roche-Magnus approximation, press: air pressure (Pa), U10, V10: 10 m wind components (ms-1), QVAPOR: 3D water vapour mxing ratio (kgkg1), CD: drag coefficient (-, only available from MM5-similarity and MYNN surface layer schemes, otherwise is zero).
- Milly92 method [potevap_diag = 2]: this method makes a correction of the bulk diagnostic by introducing a
Milly's correction parameter ξ, which accounts for other atmospheric-related phenomena (Milly, 1992). It is explained in equation 23, and its implementation is similar to the one present in ORCHIDEE model (Organising Carbon and Hydrology In Dynamic Ecosystems, [ORCHIDEE], de Rosnay et al. (2002). The implementation is retrieved from the module src_sechiba/enerbil.f90,
where β: Moisture availability function, sfcevap = QFX surface evaporation (kg-2 s-1) from QFX: surface moisture flux (kg-2s-1), L: latent heat of vaporization, EMISS: emissivity (1), CtBoltzman: constant of Stefan-Boltzman, Cp: specific heat of air, ∂Tws(T): derivative of saturated air at temperature of the first atmospheric layer (kgkg-1) using numerical 1st order approximation See in figure 8 an example of the differences between both implementations. It shows how important is the correction introduced by Milly and its strong effect on the diurnal cycle. Basically, the correction permits potential evapotranspiration during night time and reduces its strength at noon (18 UTC corresponds to 12 local time). There is a generic diagnostic to overcome boundary layer scheme dependency in the calculation of the drag coefficient (see below in generic variables).
Generic variables
Some of the diagnostics required by CORDEX depend on the approximations, equations, methodologies and observations used to compute them. This makes model intercomparison very difficult, since values might differ from one implementation to another. In order to overcome this problem, a series of variables are also provided in a 'generic' form (when possible) meaning that they are obtained directly from standard variables. Thus, these generic forms of the diagnostics become `independent' of the model's implementation.
cdgen: generic surface drag coefficient
Computation of the instantaneous drag coefficient at the surface depends on the selected surface scheme. In order to avoid this scheme dependency, a generic calculation of the coefficient has been introduced as in equation 24 following Garratt (1992),
with UST: u∗ being friction velocity from the similarity theory (ms-1), and wss = √U102 + V102: 10-m wind speed (ms-1)
tauuvgen: generic surface downward wind stress
Generic surface downward wind stress at 10m is calculated following the equation 25 which uses the generic diagnostics of the drag coefficient.
where CD: generic drag coefficient (-, see equation 24), uas: Earth-rotated eastward 10 m wind component, vas: Earth-rotated northward 10 m wind component.
rsusgen: surface upwelling shortwave radiation
Surface upwelling shortwave radiation is the shortwave radiation directed from the surface. It is calculated in a generic way as the reflected shortwave radiation depending on the surface albedo as it is shown in equation 26,
Being, ALBEDO: albedo (1), SWDOWN: downward at surface shortwave radiation (Wm-2)
rlusgen: surface upwelling longwawe radiation
Surface upwelling longwave radiation is the longwave radiation coming from the surface. It is calculated in a generic way as the longwave radiation from a black body due to surface temperature following the Stefan–Boltzmann law as it is given in equation 27,
Being, CtBoltzman: the Stefan–Boltzmann constant (= 5.67051E-8 W m-2 K-4), EMISS: surface emissivity (1), TSK: skin temperature (K)
evspsblpotgen: generic potential evapotranspiration
This variable corresponds to the generic definition of potential evapotranspiration (`evspsblpot'). The same two methodologies as in the the regular diagnostic have been implemented. The only difference is that in this case, the generic estimation of the drag coefficient `cdgen' is used (see equation 24) instead of the one given by the model.
 
	



