CDXWRFevolution
Here is kept the evolution of the code
v2.0 2023 January 27th
This is going to be a major enhancement of the module.
These are the major features to be included / modified:
- tas_or,- qvs_or: 2m air temperature and water vapour mixing ratio from LMDZ GCM diagnostics
- qc_pl,- qr_pl,- qs_pl,- qi_pl,- qg_pl,- qh_pl: p-level interpolation of all the other water species (cloud, rain, snow, ice, graupel and hail)
- iut,- ivt: vertical integration of hoirzontal water vapour transport
- tws: wet bulb temperature using "Stull, R. (2011), J. Appl. Meteor. Climatol. 50(11):2267-2269". doi: 10.1175/JAMC-D-11-0143.1
- zmlagen: generic boundary layer height based on the bulk Richardson number after (Vogelezang and Holtslag, 1996; Seidel et al., 2004)- Introduction of a new parameter in the cordexdiag section of the namelist zmlagen_diag: diagnostic of generic boundary layer height zmla
 
- Introduction of a new parameter in the cordexdiag section of the namelist 
- thetae-stability (default)
- bulk Richardson number
- ta50m, hus50m, ua50m, va50m: extrapolation of temperature, humidity and wind at 50 m following Monin-Obukhov similarity theory
- qv_pl_mc, qc_pl_mc, qr_pl_mc, qs_pl_mc, qi_pl_mc, qg_pl_mc, qh_pl_mc: mass-conservative p-level interpolation of all the water species
- fixing cape, cin, ... from AFWA module (it has some errors, since version v3.7.1 of the code is being used). Now code from WRFV4.3.1 is used (fixed by Zhixiao)
- 0-isotherm: height above ground at which temperature becomes 0 ºC
- clwvi: condensated water path fixed, to be as the vertical integration of QVAPOR+QCLOUD+QICE+SNOW
Thanks to J. Fernández (IFCA, Spain) and comment in: CORDEX-CMIP6_atm_variable_list_WRF.csv#L51
[ NOT WORKING ]
- simultaneous time of residence: variable that aggregates the time ('time of residence') at the grid point simultaneously passed at 2 bins (range of values) for 2 different 2D variables. In this case: 2-m temperature (tas) and humidty (hurs).
The tas variable is discretized by a series of bins: tas(n), tas(n+1), tas(n+2), ..., tas(N) The hurs variable is discretized by a series of bins: hurs(m), hurs(m+1), hurs(m+2), ..., hurs(M) The time of residence accumulates the time passed (during the integration of the model at time-steps dt) simultaneously at each possible combination of bins for tas and hurs.
simultaneous_time_residence(i,j,n,m) = SUM_dt(tas(n) <= tas(i,j,dt) < tas(n+1) & hurs(m) <= hurs(i,j,dt) < hurs(m+1))
v1.3.1 2020 December 15th
There is an important issue on two variables which have to be on the restart file which were not in previous versions, these are: mrso, limin, limax and limean
At the same time, it has been reported that when using tmn_update of namelist is activated, make sure that in Registry.EM_COMMON is written into the restart file. Otherwise you might risk to have a strong dry bias in summer in long simulations.
state real TLAG i&j misc 1 - rd=(interp_mask_field:lu_index,iswater)u=(copy_fcnm) "TLAG" "DAILY MEAN SFC TEMPERATURE OF PRIOR DAYS" "K"
There is a version for WRFV4.1.2
v1.3: 2018 September 28th
This version covers updates in the v1.3 version related to potential evapotranspiration index and WRF4.0 version
Problems on diagnostics of potential evapotranspiration
The former version of the diagnostics of the potential evapotranspiration was not correct. Firstly it was not the version included in ORCHIDEE and it was wrongly implemented, since it was using T2 temperature, instead of TSK (skin temperature) to compute the diagnostics.
Some work has been done and finally this is the current implementation which is explained and shown in the pdf Media:evspsblpot.pdf
At the same time a generic formulation of it 'evspsblpotgen' has also been included, in order to provide an estimation without scheme dependency. What is currently being done, is that the required drag coefficient 'cd' is diagnosed as in 'cdgen'
* IMPORTANT NOTE *: Due to the inclusion of the new generic variable 'evspsblpotgen', previous restart files should not be backward compatible (although I tested it on a WRFV3.9.1.1 and it worked). This should be because 'evspsblpotgen' is needed in the restart. In order to overcome this problem, a python script is also provided (See attached Media:add_var_restart-py.odt, to be renamed as add_var_restart.py) which adds this variable (with zero values) to the required restart. By this way, there is no need to run the simulation from the beginning and previous restarts can be used. To add evspsblpotgen in a previous restart, python script (which uses NetCDF4 library) has to be used as:
python add_var_restart.py -v EVSPSBLPOTGEN -d Time,south_north,west_east -f wrfrst_d[nn]_[YYYY]-[MM]-[DD]_[HH]:[MM]:[SS]
If any one has any clue about it, is very welcome!
New version of the module for WRF4.0
Module is now available for version V4.0 of the WRF model
Article about the module submitted to Geosciences Model Development (GMD)
We are pleased to announce that an article with a full description of the module has been submitted to Geosciences Model Development (GMD) which currently (Sept. 27th) is on 'waiting for Topical Editor assignment' status.
Information of module version during WRF run
Since this version, at the first time-step of the simulation, information into the standard and error output is provided:
CORDEX-WRF module version: X.X ..
Value of the version is kept in variable cdxwrfversion in: phys/module_diagvar_cordex.F
v1.2 2018 August 9th
This version covers
- Problem in the v1.1 version related to statistics of convective indices
Problem with calculation of statistics of convective indices
I detected a problem in the v1.1 of the module.
In the current version, when one activates the CDXWRF=1 and the computing of the statistics of the convective indices (convxtrm_diag = 1), it does not behave properly. The module provides the variables, but they are full of zeros.
This wrong behavior is only related to the 'phys/module_diag_cordex.F'. Thus, we suggest to you to update the version of the module (see attached) and recompile the model (there is no need for a `clean -a' before compilation). The module is the same for all the versions of WRF.
v1.1: 2018 July 5th
This version covers:
- Important improvements in performance of the model when module is activated
- Fixing calculation of rlugen
- Fixing attributes in tauu, tauv, taugen and tauvgen variables (thanks to Muralidhar Adakudlu)
Performance improvements
Module was increasing time-step at least by a 40%. In order to reduce it, a new pre-compilation flag has been added. It adds a little bit more of work to the compilation, but it makes possible to only add an extra 5% to model integration when module is integrated (see attached figure).
This new pre-compilation flag is called CDXWRF. It has to be added (or not) after -DCORDEXDIAG. At the same time, before compilation, user needs to introduce changes into the Registry/registry.cordex file. This new flag, now controls the quantity of variables to be retrieved, splitting them to the standard CORDEX 'Core', 'Tier1' and 'additional'  variables. 
Accordingly to the value given to the pre-compilation variable CDXWRF one obtains:
- Without adding the variable: all CORDEX'Core' variables
- CDXWRF=1CORDEX 'Tier' variables:- clivg, clivh, zmla, [cape/cin/zlfc/plfc/lidx]{min/max/mean}
- CDXWRF=2The same as with- CDXWRF=1and additional variables:- ua, va, ws, ta, press, zg, hur, hus, tfog, fogvisbltymin, fogvisbltymax, fogvisbltymean, tdsmin, tdsmax, tdsmean and the Water-Budget relarted ones: wbacdiabh, wbacpw, wbacpw[c/r/s/i/g/h], wbacf, wbacf[c/r/s/i/g/h], wbacz, wbacz[c/r/s/i/g/h], wbacdiabh{l/m/h}, wbacpw{l/m/h}, wbacpw{l/m/h}[c/r/s/i/g/h], wbacf{l/m/h}, wbacf{l/m/h}[c/r/s/i/g/h], wbac{l/m/h}z, wbacz{l/m/h}[c/r/s/i/g/h]
Simultanesouly, one needs to modify the Registry/registry.cordex accordingly to the value of CDXWRF:
- Without adding CDXWRF, nothing needs to be changed
- Adding CDXWRF=1, one needs to remove the comment##CDXWRF1##at the beginning of the line of the definition of certain variables
- Adding CDXWRF=2, one needs to remove the comment##CDXWRF1##and##CDXWRF2##at the beginning of the line of the definition of certain variables
Fixing 'rlugen'
There was a mistake on the calculation of the variable 'rlugen'.
It was: rlusgen = ctBoltzman*ts**4
and it should be, and fixed to rlusgen = emiss*ctBoltzman*ts**4
whre 'emiss' corresonds to the emissivity of the surface
Fixing attributes in tauu, tauv, taugen and tauvgen variables
Muralidhar Adakudlu found that the attributes (description of the variables) was flipped from eastward to northward and viceversa. It has been corrected
v1.0: 2018 May 28th
First public release of the code
known issues
- too slow: module adds at least a 40% on time-integration. Different strategies are being considered:
- Adding p-interpolation only on output times
- Adding more strict pre-compilation flags to speed-up the module
 
- error on rlusgen There is a mistake on the computation of the upward surface long-wave emission it should be
rlusgen = emiss*ctBoltzman*ts**4
- Wrong attributes in TAUU and TAUV (thanks to Muralidhar Adakudlu), TAUU and TAUV are northward downward wind stress and eastward downward wind stress respectively in the output, in the file they got the wrong attributes (interchanged)
