WRFDA Users Guide
WRFDA Users Guide
Introduction
Data assimilation is the technique by which observations are combined with an NWP
product (the first guess or background forecast) and their respective error statistics to
provide an improved estimate (the analysis) of the atmospheric (or oceanic, Jovian, etc.)
state. Variational (Var) data assimilation achieves this through the iterative minimization
of a prescribed cost (or penalty) function. Differences between the analysis and observa-
tions/first guess are penalized (damped) according to their perceived error. The difference
between three-dimensional (3D-Var) and four-dimensional (4D-Var) data assimilation is
the use of a numerical forecast model in the latter.
Various components of the WRFDA system are shown in blue in the sketch below, to-
gether with their relationship with the rest of the WRF system.
xb first guess, either from a previous WRF forecast or from WPS/real.exe output.
xlbc lateral boundary from WPS/real.exe output.
In this chapter, you will learn how to install and run the various components of the
WRFDA system. For training purposes, you are supplied with a test case, including the
following input data:
• observation files,
• a netCDF background file (WPS/real.exe output, the first guess of the analysis)
• background error statistics (estimate of errors in the background file).
• This tutorial dataset can be downloaded from the WRFDA Users Page
(http://www2.mmm.ucar.edu/wrf/users/wrfda/download/testdata.html), and will
be described later in more detail. In your own work, however, you will have to
create all these input files yourself. See the section “Running Observation Prepro-
cessor” for creating your observation files. See the section “Background Error and
running GEN_BE” for generating your background error statistics file, if you
want to use cv_options=5, 6, or 7.
Before using your own data, we suggest that you start by running through the WRFDA-
related programs using the supplied test case. This serves two purposes: First, you can
learn how to run the programs with data we have tested ourselves, and second you can
test whether your computer is capable of running the entire data assimilation system. Af-
ter you have done the tutorial, you can try running other, more computationally intensive
case studies, and experimenting with some of the many namelist variables.
Hopefully, our test cases will prepare you for the variety of ways in which you may wish
to run your own WRFDA experiments. Please inform us about your experiences.
As a professional courtesy, we request that you include the following references in any
publication that uses any component of the community WRFDA system:
Barker, D.M., W. Huang, Y.R. Guo, and Q.N. Xiao., 2004: A Three-Dimensional
(3DVAR) Data Assimilation System For Use With MM5: Implementation and Initial Re-
sults. Mon. Wea. Rev., 132, 897-914.
Kuo, 2009: Four-Dimensional Variational Data Assimilation for WRF: Formulation and
Preliminary Results. Mon. Wea. Rev., 137, 299–314.
Barker, D., X.-Y. Huang, Z. Liu, T. Auligné, X. Zhang, S. Rugg, R. Ajjaji, A. Bourgeois,
J. Bray, Y. Chen, M. Demirtas, Y.-R. Guo, T. Henderson, W. Huang, H.-C. Lin, J.
Michalakes, S. Rizvi, and X. Zhang, 2012: The Weather Research and Forecasting Mod-
el's Community Variational/Ensemble Data Assimilation System: WRFDA. Bull. Amer.
Meteor. Soc., 93, 831–843.
Running WRFDA requires a Fortran 90 compiler. The WRFDA system can be compiled
on the following platforms: Linux (ifort, gfortran, pgf90), Macintosh (gfortran, ifort),
IBM (xlf), and SGI Altix (ifort). Please let us know if this does not meet your require-
ments, and we will attempt to add other machines to our list of supported architectures, as
resources allow. Although we are interested in hearing about your experiences in modify-
ing compiler options, we do not recommend making changes to the configure file used to
compile WRFDA.
Note: Although the WRFDA package also contains the WRF source code, they can
not be built together. WRF should be downloaded and compiled separately.
After the tar file is unzipped (gunzip WRFDAV3.9.TAR.gz) and untarred (tar -xf
WRFDAV3.9.TAR), the directory WRFDA should be created. This directory contains the
WRFDA source, external libraries, and fixed files. The following is a list of the system
components and content for each subdirectory:
Some external libraries (e.g., LAPACK, BLAS, and NCEP BUFR) are included in the
WRFDA tar file. To compile the WRFDA code, the only mandatory library is the netCDF
library. You should set an environment variable NETCDF to point to the directory where
your netCDF library is installed
The source code for BUFRLIB 10.2.3 (with minor modifications) is included in the
WRFDA tar file, and is compiled automatically. This library will be used for assimilating
files in PREPBUFR and NCEP BUFR format.
Starting with WRFDA version 3.8, AMSR2 data can be assimilated in HDF5 format,
which requires the use of HDF5 libraries. If you wish to make use of this capability, you
should ensure that HDF5 libraries are installed on your system (or download and install
them yourself; the source code is available from https://www.hdfgroup.org/HDF5/). To
use HDF5 in WRFDA, you should set the environment variable “HDF5” to the parent
path of your HDF5 build:
The HDF5 path should contain the directories “include” and “lib”.
For some platforms, you may have to also add the HDF5 “lib” directory to your environ-
ment variable LD_LIBRARY_PATH:
If satellite radiance data are to be used, a Radiative Transfer Model (RTM) is required.
The current RTM versions that WRFDA supports are CRTM V2.2.3 and RTTOV V11.1–
11.3 .
The CRTM V2.2.3 source code is included in the WRFDA tar file, and is compiled au-
tomatically. No action is needed from the user.
If the user wishes to use RTTOV, download and install the RTTOV v11 library before
compiling WRFDA. This library can be downloaded from
http://nwpsaf.eu/deliverables/rtm/index.html. The RTTOV libraries must be compiled
with the “emis_atlas” option in order to work with WRFDA; see the RTTOV “re-
adme.txt” for instructions on how to do this. After compiling RTTOV (see the
RTTOV documentation for detailed instructions), set the “RTTOV” environment variable
to the path where the lib directory resides. For example, if the library files can be found
in /usr/local/rttov11/gfortran/lib/librttov11.*.a, you should set RTTOV as:
Note: Make sure the required libraries were all compiled using the same compiler
that will be used to build WRFDA, since the libraries produced by one compiler may
not be compatible with code compiled with another.
Assuming all required libraries are available and the WRFDA source code is ready, you
can start to build WRFDA using the following steps:
> cd WRFDA
> ./configure wrfda
A list of configuration options should appear. Each option combines an operating system,
a compiler type, and a parallelism option. Since the configuration script doesn’t check
which compilers are actually installed on your system, be sure to select only among the
options that you have available to you. The available parallelism options are single-
processor (serial), shared-memory parallel (smpar), distributed-memory parallel (dmpar),
and distributed-memory with shared-memory parallel (sm+dm). However, shared-
memory (smpar and sm+dm) options are not supported as of WRFDA Version 3.9,
so we do not recommend selecting any of these options.
For example, on a Linux machine such as NCAR’s Yellowstone, the above steps will
look similar to the following:
checking for perl5... no
checking for perl... found /usr/bin/perl (perl)
Will use NETCDF in dir: /glade/apps/opt/netcdf/4.3.0/gnu/4.8.2/
Will use HDF5 in dir: /glade/u/apps/opt/hdf5/1.8.12/gnu/4.8.2/
PHDF5 not set in environment. Will configure WRF for use without.
Will use 'time' to report timing information
$JASPERLIB or $JASPERINC not found in environment, configuring to build without grib2
I/O...
------------------------------------------------------------------------
Please select from among the following Linux x86_64 options:
44. (serial) 45. (smpar) 46. (dmpar) 47. (dm+sm) CRAY CCE (ftn/cc): Cray XE and XC
48. (serial) 49. (smpar) 50. (dmpar) 51. (dm+sm) INTEL (ftn/icc): Cray XC
52. (serial) 53. (smpar) 54. (dmpar) 55. (dm+sm) PGI (pgf90/pgcc)
56. (serial) 57. (smpar) 58. (dmpar) 59. (dm+sm) PGI (pgf90/gcc): -f90=pgf90
60. (serial) 61. (smpar) 62. (dmpar) 63. (dm+sm) PGI (pgf90/pgcc): -f90=pgf90
64. (serial) 65. (smpar) 66. (dmpar) 67. (dm+sm) INTEL (ifort/icc): HSW/BDW
68. (serial) 69. (smpar) 70. (dmpar) 71. (dm+sm) INTEL (ifort/icc): KNL MIC
Configuration successful!
------------------------------------------------------------------------
... ...
After entering the option that corresponds to your machine/compiler combination, the
configure script should print the message “Configuration successful!” followed by a large
amount of configuration information. Depending on your system, you may see a warning
message mentioning that some Fortran 2003 features have been removed: this message is
normal and can be ignored. However, if you see a message “One of compilers testing
failed! Please check your compiler”, configuration has probably failed, and you should
make sure you have selected the correct option.
After running the configuration script and choosing a compilation option, a config-
ure.wrf file will be created. Because of the variety of ways that a computer can be con-
figured, if the WRFDA build ultimately fails, there is a chance that minor modifications
to the configure.wrf file may be needed.
The main executable for running WRFDA is da_wrfvar.exe. Make sure it has been
created after the compilation: it is fairly common that all the executables will be success-
fully compiled except this main executable. If this occurs, please check the compilation
log file carefully for any errors.
The basic gen_be utility for the regional model consists of gen_be_stage0_wrf.exe,
gen_be_stage1.exe, gen_be_stage2.exe, gen_be_stage2a.exe,
gen_be_stage3.exe, gen_be_stage4_regional.exe, and gen_be_diags.exe.
da_update_bc.exe is used for updating the WRF lower and lateral boundary conditions
before and after a new WRFDA analysis is generated. This is detailed in the section on
Updating WRF Boundary Conditions.
da_advance_time.exe is a very handy and useful tool for date/time manipulation. Type
$WRFDA_DIR/var/build/da_advance_time.exe to see its usage instructions.
./clean
./clean -a
Note: if you intend to run both 3DVAR and 4DVAR experiments, it is not
necessary to compile the code twice. The da_wrfvar.exe executable compiled
for 4DVAR can be used for both 3DVAR and 4DVAR assimilation.
To install WRFPLUS:
• Unzip and untar the WRFPLUS file, then run the configure script
• Compile WRFPLUS
If compilation was successful, you should see the WRFPLUS executable (named
wrf.exe):
• If you intend to use RTTOV to assimilate radiance data, you will need to set the
appropriate environment variable at compile time. See the previous 3DVAR sec-
tion for instructions.
>./configure 4dvar
You should see the same 44 executables as are listed in the above 3DVAR sec-
tion, including da_wrfvar.exe
• Write out the observation file to be used by WRFDA in ASCII or BUFR format
If you haven’t already, you should download the tutorial case, which contains example
files for all the exercises in this User’s Guide. The case can be found at the WRFDA
website (http://www2.mmm.ucar.edu/wrf/users/wrfda/download/testdata.html).
As an example, to prepare the observation file at the analysis time, all the observations in
the range ±1h will be processed, which means that (in the example case) the observations
between 23h and 1h are treated as the observations at 0h. This is illustrated in the follow-
ing figure:
The files obserr.txt and msfc.tbl are included in the source code under
var/obsproc. To create the required namelist file, we have provided an example file
(namelist_obsproc.3dvar.wrfvar-tut) in the var/obsproc directory. Thus, proceed
as follows.
> cd $WRFDA_DIR/var/obsproc
> cp namelist.obsproc.3dvar.wrfvar-tut namelist.obsproc
You will likely only need to change variables listed under records 1, 2, 6, 7, and 8. See
$WRFDA_DIR/var/obsproc/README.namelist, or the section OBSPROC namelist vari-
ables for details. You should pay special attention to the record 7 and record 8 variables:
these will determine the domain for which observations will be written to the output ob-
servation file. Alternatively, if you do not wish to filter the observations spatially, you
can set domain_check_h = .false. under &record4.
If you are running the tutorial case, you should copy or link the sample observation file
(ob/2008020512/obs.2008020512) to the obsproc directory. Alternatively, you can edit
the namelist variable obs_gts_filename to point to the observation file’s full path.
Once obsproc.exe has completed successfully, you will see an observation data file,
with the name formatted obs_gts_YYYY-MM-DD_HH:NN:SS.3DVAR, in the obsproc direc-
tory. For the tutorial case, this will be obs_gts_2008-02-05_12:00:00.3DVAR. This is
the input observation file to WRFDA. It is an ASCII file that contains a header section
(listed below) followed by observations. The meanings and format of observations in the
file are described in the last six lines of the header section.
TOTAL = 9066, MISS. =-888888.,
SYNOP = 757, METAR = 2416, SHIP = 145, BUOY = 250, BOGUS = 0, TEMP =
86,
AMDAR = 19, AIREP = 205, TAMDAR= 0, PILOT = 85, SATEM = 106, SATOB =
2556,
GPSPW = 187, GPSZD = 0, GPSRF = 3, GPSEP = 0, SSMT1 = 0, SSMT2 =
0,
TOVS = 0, QSCAT = 2190, PROFL = 61, AIRSR = 0, OTHER = 0,
PHIC = 40.00, XLONC = -95.00, TRUE1 = 30.00, TRUE2 = 60.00, XIM11 = 1.00, XJM11 =
1.00,
base_temp= 290.00, base_lapse= 50.00, PTOP = 1000., base_pres=100000.,
base_tropo_pres= 20000., base_strat_temp= 215.,
IXC = 60, JXC = 90, IPROJ = 1, IDD = 1, MAXNES= 1,
NESTIX= 60,
NESTJX= 90,
NUMC = 1,
DIS = 60.00,
NESTI = 1,
NESTJ = 1,
INFO = PLATFORM, DATE, NAME, LEVELS, LATITUDE, LONGITUDE, ELEVATION, ID.
SRFC = SLP, PW (DATA,QC,ERROR).
EACH = PRES, SPEED, DIR, HEIGHT, TEMP, DEW PT, HUMID (DATA,QC,ERROR)*LEVELS.
INFO_FMT = (A12,1X,A19,1X,A40,1X,I6,3(F12.3,11X),6X,A40)
SRFC_FMT = (F12.3,I4,F7.2,F12.3,I4,F7.3)
EACH_FMT = (3(F12.3,I4,F7.2),11X,3(F12.3,I4,F7.2),11X,3(F12.3,I4,F7.2))
#------------------------------------------------------------------------------#
…… observations ………
Before running WRFDA, you may find it useful to learn more about various types of data
that will be processed (e.g., their geographical distribution). This file is in ASCII format
and so you can easily view it. For a graphical view of the file's content, there are NCL
scripts available which can display the distribution and type of observations. In the
WRFDA Tools package (can be downloaded at
http://www2.mmm.ucar.edu/wrf/users/wrfda/download/tools.html), the relevant script is located at
To prepare the observation file, for example, at the analysis time 0h for 4D-Var, all ob-
servations from 0h to 6h will be processed and grouped in 7 sub-windows (slot1 through
slot7) as illustrated in the following figure:
NOTE: The “Analysis time” in the above figure is not the actual analysis time (0h). It
indicates the time_analysis setting in the namelist file, which in this example is three
hours later than the actual analysis time. The actual analysis time is still 0h.
> cd $WRFDA_DIR/var/obsproc
> cp namelist.obsproc.4dvar.wrfvar-tut namelist.obsproc
In the namelist file, you need to change the following variables to accommodate your ex-
periments. In this tutorial case, the actual analysis time is 2008-02-05_12:00:00, but
in the namelist, time_analysis should be set to 3 hours later. The different values of
time_analysis, num_slots_past, and time_slots_ahead contribute to the actual
times analyzed. For example, if you set time_analysis = 2008-02-05_16:00:00, and set
the num_slots_past = 4 and time_slots_ahead=2, the final results will be the same as
before.
Edit all the domain settings according to your own experiment; a full list of namelist op-
tions and descriptions can be found in the section Description of Namelist Variables.
You should pay special attention to the record 7 and record 8 variables: these will deter-
mine the domain for which observations will be written to the output observation file.
Alternatively, if you do not wish to filter the observations spatially, you can set do-
main_check_h = .false. under &record4.
If you are running the tutorial case, you should copy or link the sample observation file
(ob/2008020512/obs.2008020512) to the obsproc directory. Alternatively, you can edit
the namelist variable obs_gts_filename to point to the observation file’s full path.
Once obsproc.exe has completed successfully, you will see 7 observation data files,
which for the tutorial case are named
obs_gts_2008-02-05_12:00:00.4DVAR
obs_gts_2008-02-05_13:00:00.4DVAR
obs_gts_2008-02-05_14:00:00.4DVAR
obs_gts_2008-02-05_15:00:00.4DVAR
obs_gts_2008-02-05_16:00:00.4DVAR
obs_gts_2008-02-05_17:00:00.4DVAR
obs_gts_2008-02-05_18:00:00.4DVAR
Running WRFDA
a) WRF first guess file, output from either WPS/real.exe (wrfinput) or a WRF
forecast (wrfout)
In the test case, you will store data in a directory defined by the environment variable
$DAT_DIR. This directory can be in any location, and it should have read access. Type
Here, your_choice_of_dat_dir is the directory where the WRFDA input data is stored.
If you have not already done so, download the sample data for the tutorial case, valid at
12 UTC 5th February 2008, from
http://www2.mmm.ucar.edu/wrf/users/wrfda/download/testdata.html
Now you should find the following four files under “$DAT_DIR”
At this point you should have three of the input files (first guess, observations from OB-
SPROC, and background error statistics files in the directory $DAT_DIR) required to run
WRFDA, and have successfully downloaded and compiled the WRFDA code. If this is
correct, you are ready to run WRFDA.
The data for the tutorial case is valid at 12 UTC 5 February 2008. The first guess comes
from the NCEP FNL (Final) Operational Global Analysis data, passed through the WRF-
WPS and real.exe programs.
To run WRF 3D-Var, first create and enter into a working directory (for example,
$WRFDA_DIR/workdir), and set the environment variable WORK_DIR to this directory (e.g.,
setenv WORK_DIR $WRFDA_DIR/workdir). Then follow the steps below:
> cd $WORK_DIR
> cp $DAT_DIR/namelist.input.3dvar namelist.input
> ln -sf $WRFDA_DIR/run/LANDUSE.TBL .
> ln -sf $DAT_DIR/rc/2008020512/wrfinput_d01 ./fg
> ln -sf $DAT_DIR/ob/2008020512/obs_gts_2008-02-05_12:00:00.3DVAR
./ob.ascii (note the different name!)
> ln -sf $DAT_DIR/be/be.dat .
> ln -sf $WRFDA_DIR/var/da/da_wrfvar.exe .
Now edit the file namelist.input, which is a very basic namelist for the tutorial test
case, and is shown below.
&wrfvar1
var4d=false,
print_detail_grad=false,
/
&wrfvar2
/
&wrfvar3
ob_format=2,
/
&wrfvar4
/
&wrfvar5
/
&wrfvar6
max_ext_its=1,
ntmax=50,
orthonorm_gradient=true,
/
&wrfvar7
cv_options=5,
/
&wrfvar8
/
&wrfvar9
/
&wrfvar10
test_transforms=false,
test_gradient=false,
/
&wrfvar11
/
&wrfvar12
/
&wrfvar13
/
&wrfvar14
/
&wrfvar15
/
&wrfvar16
/
&wrfvar17
/
&wrfvar18
analysis_date="2008-02-05_12:00:00.0000",
/
&wrfvar19
/
&wrfvar20
/
&wrfvar21
time_window_min="2008-02-05_11:00:00.0000",
/
&wrfvar22
time_window_max="2008-02-05_13:00:00.0000",
/
&time_control
start_year=2008,
start_month=02,
start_day=05,
start_hour=12,
end_year=2008,
end_month=02,
end_day=05,
end_hour=12,
/
&fdda
/
&domains
e_we=90,
e_sn=60,
e_vert=41,
dx=60000,
dy=60000,
/
&dfi_control
/
&tc
/
&physics
mp_physics=3,
ra_lw_physics=1,
ra_sw_physics=1,
radt=60,
sf_sfclay_physics=1,
sf_surface_physics=1,
bl_pbl_physics=1,
cu_physics=1,
cudt=5,
num_soil_layers=5,
mp_zero_out=2,
co2tf=0,
/
&scm
/
&dynamics
/
&bdy_control
/
&grib2
/
&fire
/
&namelist_quilt
/
&perturbation
/
No edits should be needed if you are running the tutorial case without radiance data. If
you plan to use the PREPBUFR-format data, change the ob_format=1 in &wrfvar3 in
namelist.input and link the data as ob.bufr,
Once you have changed any other necessary namelist variables, run WRFDA 3D-Var:
> da_wrfvar.exe >& wrfda.log
start_lat = 0.207406E+02
start_lon = -0.119501E+03
pole_lat = 0.900000E+02
dsm = 0.600000E+02
Observation summary
ob time 1
sound 86 global, 86 local
synop 750 global, 750 local
pilot 85 global, 85 local
satem 105 global, 105 local
geoamv 2499 global, 2499 local
airep 221 global, 221 local
gpspw 187 global, 187 local
gpsrf 3 global, 3 local
metar 2408 global, 2408 local
ships 140 global, 140 local
qscat 2126 global, 2126 local
profiler 61 global, 61 local
buoy 247 global, 247 local
sonde_sfc 86 global, 86 local
cloud_cv_options = 0
WRFDA dry control variables are: psi, chi_u, t_u and ps_u
WRFDA Humidity control variable is rh
Diagnostics
Final cost function J = 29185.68
The file namelist.output.da (which contains the complete namelist settings) will be
generated after a successful run of da_wrfvar.exe. The settings appearing in namel-
ist.output.da, but not specified in your namelist.input, are the default values from
$WRFDA_DIR/Registry/registry.var.
After successful completion, wrfvar_output (the WRFDA analysis file, i.e. the new ini-
tial condition for WRF) should appear in the working directory along with a number of
diagnostic files. Text files containing various diagnostics will be explained in the
WRFDA Diagnostics section.
To understand the role of various important WRFDA options, try re-running WRFDA by
changing different namelist options. Some examples are listed below:
&wrfvar6
eps = 0.0001,
/
&wrfvar6
max_ext_its = 2,
/
With this setting, the “outer loop” for the minimization procedure will be activated. You
may wish to compare various diagnostics with an earlier run.
Note that when running multiple outer loops with the CV3 background error option, you
must specify the scaling factors which are called as1, as2, as3, as4, and as5. More details
can be found in the section “Modifying CV3 length scales and variance”.
The types of observations that WRFDA gets to use actually depend on what is included
in the observation file and the WRFDA namelist settings. For example, if you have
SYNOP data in the observation file, you can suppress its usage in WRFDA by setting
use_synopobs=false in record &wrfvar4 of namelist.input. It is OK if there are no
SYNOP data in the observation file and use_synopobs=true.
Turning on and off certain types of observations is widely used for assessing the impact
of observations on data assimilations.
For example, try making the WRFDA convergence criterion more stringent. This is
achieved by reducing the value of “EPS” to e.g. 0.0001 by adding "EPS=0.0001" in the
namelist.input record &wrfvar6. See the section Additional Background Error options
for more namelist options.
To run WRF 4D-Var, first create and enter a working directory, such as
$WRFDA_DIR/workdir. Set the WORK_DIR environment variable (e.g. setenv WORK_DIR
$WRFDA_DIR/workdir)
For the tutorial case, the analysis date is 2008020512 and the test data directories are:
> setenv DAT_DIR {directory where data is stored}
> ls –lr $DAT_DIR
ob/2008020512
ob/2008020513
ob/2008020514
ob/2008020515
ob/2008020516
ob/2008020517
ob/2008020518
rc/2008020512
be
Note: WRFDA 4D-Var is able to assimilate conventional observational data, satellite ra-
diance BUFR data, and precipitation data. The input data format can be PREPBUFR
format data or ASCII observation data, processed by OBSPROC.
WRFDA 4D-Var has the capability to consider lateral boundary conditions as control
variables as well during minimization. The namelist variable var4d_lbc=true turns
on this capability. To enable this option, WRF 4D-Var needs not only the first guess at
the beginning of the time window, but also the first guess at the end of the time window.
> ln -fs $DAT_DIR/rc/2008020518/wrfinput_d01 fg02
Please note: WRFDA beginners should not use this option until you have a good under-
standing of the 4D-Var lateral boundary conditions control. To disable this feature, make
sure var4d_lbc in namelist.input is set to false.
Because 12UTC PREPBUFR data only includes the data from 9UTC to 15UTC, for 4D-
Var you should include 18UTC PREPBUFR data as well:
> ln -fs $DAT_DIR/ob/2008020512/gdas1.t12z.prepbufr.nr ob01.bufr
> ln -fs $DAT_DIR/ob/2008020518/gdas1.t18z.prepbufr.nr ob02.bufr
Edit namelist.input to match your experiment settings. The most important namelist
variables related to 4D-Var are listed below. Please refer to README.namelist under the
$WRFDA_DIR/var directory. A common mistake users make is in the time information
settings. The rules are: analysis_date, time_window_min and start_xxx in
&time_control should always be equal to each other; time_window_max and end_xxx
should always be equal to each other; and run_hours is the difference between
start_xxx and end_xxx, which is the length of the 4D-Var time window.
&wrfvar1
var4d=true,
var4d_lbc=false,
var4d_bin=3600,
……
/
……
&wrfvar18
analysis_date="2008-02-05_12:00:00.0000",
/
……
&wrfvar21
time_window_min="2008-02-05_12:00:00.0000",
/
……
&wrfvar22
time_window_max="2008-02-05_18:00:00.0000",
/
……
&time_control
run_hours=6,
start_year=2008,
start_month=02,
start_day=05,
start_hour=12,
end_year=2008,
end_month=02,
end_day=05,
end_hour=18,
interval_seconds=21600,
debug_level=0,
/
……
4DVAR is much more computationally expensive than 3DVAR, so running may take a
while; you can set ntmax to a lower value so that WRFDA uses fewer minimization
steps. You can also MPI with multiple processors to speed up the execution:
> mpirun –np 4 ./da_wrfvar.exe >& wrfda.log &
The “mpirun” command may be different depending on your machine. The output logs
will be found in files named rsl.out.#### and rsl.error.#### for MPI runs.
Please note: If you utilize the lateral boundary conditions option (var4d_lbc=true), in
addition to the analysis at the beginning of the time window (wrfvar_output), the analy-
sis at the end of the time window will also be generated as ana02, which will be used in
subsequent updating of boundary conditions before the forecast.
This section gives a brief description for various aspects related to radiance assimilation
in WRFDA. Each aspect is described mainly from the viewpoint of usage, rather than
more technical and scientific details, which will appear in a separate technical report and
scientific paper. Namelist parameters controlling different aspects of radiance assimila-
tion will be detailed in the following sections. It should be noted that this section does not
cover general aspects of the assimilation process with WRFDA; these can be found in
other sections of chapter 6 of this user’s guide, or other WRFDA documentation.
In addition to the basic input files (LANDUSE.TBL, fg, ob.ascii, be.dat) mentioned
in the “Running WRFDA” section, the following additional files are required for radianc-
es: radiance data (typically in NCEP BUFR format), radiance_info files,
VARBC.in (if you plan on using variational bias correction VARBC, as described in the
section on bias correction), and RTM (CRTM or RTTOV) coefficient files.
See the following sections for more de- Note: You can also specify the path of the “
tails on each aspect of radiance assimila- crtm_coeffs” directory via the namelist; see
tion. the following section for more details
Currently, the ingest interface for NCEP BUFR radiance data is implemented in
WRFDA. The radiance data are available through NCEP’s public ftp server
(ftp://ftp.ncep.noaa.gov/pub/data/nccf/com/gfs/prod/gdas.${yyyymmddhh}) in near real-
time (with a 6-hour delay) and can meet requirements for both research purposes and
some real-time applications.
As of Version 3.9, WRFDA can read data from NOAA ATOVS instruments (HIRS,
AMSU-A, AMSU-B and MHS), EOS Aqua instruments (AIRS, AMSU-A), DMSP in-
struments (SSMIS), METOP instruments (HIRS, AMSU-A, MHS, IASI), Meteosat in-
struments (SEVIRI), and JAXA GCOM-W1 instruments (AMSR2). Note that NCEP ra-
diance BUFR files are separated by instrument names (i.e., one file for each type of in-
strument), and each file contains global radiance (generally converted to brightness tem-
perature) within a 6-hour assimilation window, from multi-platforms. For running
WRFDA, users need to rename NCEP corresponding BUFR files (table 1) to
hirs3.bufr (including HIRS data from NOAA-15/16/17), hirs4.bufr (including
HIRS data from NOAA-18/19, METOP-2), amsua.bufr (including AMSU-A data
from NOAA-15/16/18/19, METOP-1 and -2), amsub.bufr (including AMSU-B data
from NOAA-15/16/17), mhs.bufr (including MHS data from NOAA-18/19 and
METOP-1 and -2), airs.bufr (including AIRS and AMSU-A data from EOS-AQUA)
ssmis.bufr (SSMIS data from DMSP-16, AFWA provided) iasi.bufr (IASI data
from METOP-1 and -2) and seviri.bufr (SEVIRI data from Meteosat 8-10) for
WRFDA filename convention. Note that the airs.bufr file contains not only AIRS
data but also AMSU-A, which is collocated with AIRS pixels (1 AMSU-A pixel collo-
cated with 9 AIRS pixels). Users must place these files in the working directory where
the WRFDA executable is run. It should also be mentioned that WRFDA reads these
BUFR radiance files directly without the use of any separate pre-processing program. All
processing of radiance data, such as quality control, thinning, bias correction, etc., is car-
ried out within WRFDA. This is different from conventional observation assimilation,
which requires a pre-processing package (OBSPROC) to generate WRFDA readable
ASCII files. For reading the radiance BUFR files, WRFDA must be compiled with the
NCEP BUFR library (see http://www.nco.ncep.noaa.gov/sib/decoders/BUFRLIB/).
Namelist parameters are used to control the reading of corresponding BUFR files into
WRFDA. For instance, USE_AMSUAOBS, USE_AMSUBOBS, USE_HIRS3OBS,
USE_HIRS4OBS, USE_MHSOBS, USE_AIRSOBS, USE_EOS_AMSUAOBS,
USE_SSMISOBS, USE_ATMSOBS, USE_IASIOBS, and USE_SEVIRIOBS control
whether or not the respective file is read. These are logical parameters that are assigned to
.FALSE. by default; therefore they must be set to .TRUE. to read the respective observa-
tion file. Also note that these parameters only control whether the data is read, not wheth-
er the data included in the files is to be assimilated. This is controlled by other namelist
parameters explained in the next section.
Sources for downloading these and other data can be found on the WRFDA website:
http://www2.mmm.ucar.edu/wrf/users/wrfda/download/free_data.html.
HDF5 file naming conventions are different than those for BUFR files. For AMSR2 data,
WRFDA will look for two data files: L1SGRTBR.h5 (brightness temperature) and
L2SGCLWLD.h5 (cloud liquid water). Only the brightness temperature file is mandatory
(you will also need to copy or link the “leapsec.dat” file from WRFDA/var/run). If you
have multiple data files for your assimilation window, you should name them
L1SGRTBR-01.h5, L1SGRTBR-02.h5, etc. and L2SGCLWLD-01.h5, L2SGCLWLD-
02.h5, etc.
The core component for direct radiance assimilation is to incorporate a radiative transfer
model (RTM) into the WRFDA system as one part of observation operators. Two widely
used RTMs in the NWP community, RTTOV (developed by ECMWF and UKMET in
Europe), and CRTM (developed by the Joint Center for Satellite Data Assimilation
(JCSDA) in US), are already implemented in the WRFDA system with a flexible and
consistent user interface. WRFDA is designed to be able to compile with or without
RTTOV by the definition of the “RTTOV” environment variable at compile time (see the
“Compile WRFDA and Libraries” section). At runtime the user must select which RTM
they intend to use via the namelist parameter RTM_OPTION (1 for RTTOV, the default,
and 2 for CRTM).
Both RTMs can calculate radiances for almost all available instruments aboard the vari-
ous satellite platforms in orbit. An important feature of the WRFDA design is that all data
structures related to radiance assimilation are dynamically allocated during running time,
according to a simple namelist setup. The instruments to be assimilated are controlled at
Here’s an example of this section of the namelist for a user assimilating IASI observa-
tions from METOP-A, utilizing RTTOV as their RTM:
&wrfvar14
rtminit_nsensor = 1
rtminit_platform = 10,
rtminit_satid = 2,
rtminit_sensor = 16,
rtm_option = 1,
/
Here’s another example of this section of the namelist, this time for a user assimilating
AMSU-A from NOAA 18–19 and EOS-Aqua, MHS from NOAA 18–19, and AIRS from
EOS-Aqua, utilizing CRTM as their RTM:
&wrfvar14
rtminit_nsensor = 6
rtminit_platform = 1, 1, 9, 1, 1, 9
rtminit_satid = 18, 19, 2, 18, 19, 2
rtminit_sensor = 3, 3, 3, 15, 15, 11
rtm_option = 2,
/
The instrument triplets (platform, satellite, and sensor ID) in the namelist can be ranked
in any order. More detail about the convention of instrument triples can be found in tables
2 and 3 in the RTTOV v11 User’s Guide
(http://nwpsaf.eu/deliverables/rtm/docs_rttov11/users_guide_11_v1.4.pdf)
When running WRFDA with radiance assimilation switched on, a set of RTM coefficient
files need to be loaded. For the RTTOV option, RTTOV coefficient files are to be copied
or linked to a sub-directory rttov_coeffs/ under the working directory. For the CRTM
option, CRTM coefficient files are to be copied or linked to a sub-directory
crtm_coeffs/ under the working directory, or the location of this directory can be spec-
ified in the namelist:
&wrfvar14
crtm_coef_path = WRFDA/var/run/crtm_coeffs (Can be a relative or absolute path)
/
Only coefficients for instruments listed in the namelist are needed. Potentially WRFDA
can assimilate all sensors as long as the corresponding coefficient files are provided. In
addition, necessary developments on the corresponding data interface, quality control,
and bias correction are important to make radiance data assimilate properly; however, a
modular design of radiance relevant routines already facilitates the addition of more in-
struments in WRFDA.
The RTTOV package is not distributed with WRFDA, due to licensing restrictions. Users
need to follow the instructions at http://nwpsaf.eu/site/software/rttov/ to download the RTTOV
source code and supplement coefficient files and the emissivity atlas dataset. Only
RTTOV v11 (11.1—11.3) can be used in WRFDA version 3.9, so if you have an older
version of RTTOV you must upgrade. RTTOV v12 is not yet supported.
To use one or both of the above radiative transfer models, you will have to set the appro-
priate environment variable(s) at compile time. See the section “Compile WRFDA and
Libraries” for details.
d. Channel Selection
Channel selection in WRFDA is controlled by radiance ‘info’ files, located in the sub-
directory radiance_info, under the working directory. These files are separated by sat-
ellites and sensors; e.g., noaa-15-amsua.info, noaa-16-amsub.info, dmsp-16-
ssmis.info and so on. An example of 5 channels from noaa-15-amsub.info is shown
below. The fourth column is used by WRFDA to control when to use a corresponding
channel. Channels with the value “-1” in the fourth column indicate that the channel is
“not assimilated,” while the value “1” means “assimilated.” The sixth column is used by
WRFDA to set the observation error for each channel. Other columns are not used by
WRFDA. It should be mentioned that these error values might not necessarily be optimal
for your applications. It is the user’s responsibility to obtain the optimal error statistics
for his/her own applications.
Sensor channel IR/MW use idum varch polarization(0:vertical;1:horizontal)
e. Bias Correction
All VarBC input is passed through a single ASCII file called VARBC.in. Once WRFDA
has run with the VarBC option switched on, it will produce a VARBC.out file in a similar
ASCII format. This output file will then be used as the input file for the next assimilation
cycle.
VarBC Coldstart
Coldstarting means starting the VarBC from scratch; i.e. when you do not know the val-
ues of the bias parameters.
The coldstart is a routine in WRFDA. The bias predictor statistics (mean and standard
deviation) are computed automatically and will be used to normalize the bias parameters.
All coldstart bias parameters are set to zero, except the first bias parameter (= simple off-
set), which is set to the mode (=peak) of the distribution of the (uncorrected) innovations
for the given channel.
It is defined in the namelist via the option VARBC_NBGERR; the default value is 5000.
This number is related to a number of observations; the bigger the number, the more iner-
tia constraint. If these numbers are set to zero, the predictors can evolve without any con-
straint.
Scaling factor
The VarBC uses a specific preconditioning, which can be scaled through the namelist op-
tion VARBC_FACTOR (default = 1.0).
MAX_VERT_VAR1=0.0
MAX_VERT_VAR2=0.0
MAX_VERT_VAR3=0.0
MAX_VERT_VAR4=0.0
MAX_VERT_VAR5=0.0
Freeze VarBC
In certain circumstances, you might want to keep the VarBC bias parameters constant in
time (="frozen"). In this case, the bias correction is read and applied to the innovations,
but it is not updated during the minimization. This can easily be achieved by setting the
namelist options:
USE_VARBC=false
FREEZE_VARBC=true
Passive observations
Some observations are useful for preprocessing (e.g. Quality Control, Cloud detection)
but you might not want to assimilate them. If you still need to estimate their bias correc-
tion, these observations need to go through the VarBC code in the minimization. For this
purpose, the VarBC uses a separate threshold on the QC values, called "qc_varbc_bad".
This threshold is currently set to the same value as "qc_bad", but can easily be changed to
any ad hoc value.
RAD_MONITORING (30)
Integer array of dimension RTMINIT_NSENSOR, 0 for assimilating mode, 1 for
monitoring mode (only calculates innovation).
THINNING
Logical, TRUE will perform thinning on radiance data.
THINNING_MESH (30)
Real array with dimension RTMINIT_NSENSOR, values indicate thinning mesh
(in km) for different sensors.
QC_RAD
Logical, controls if quality control is performed, always set to TRUE.
WRITE_IV_RAD_ASCII
Logical, controls whether to output observation-minus-background (O-B) files,
which are in ASCII format, and separated by sensors and processors.
WRITE_OA_RAD_ASCII
Logical, controls whether to output observation-minus-analysis (O-A) files (in-
cluding also O-B information), which are in ASCII format, and separated by sen-
sors and processors.
USE_ERROR_FACTOR_RAD
Logical, controls use of a radiance error tuning factor file
(radiance_error.factor) which is created with empirical values, or generated
using a variational tuning method (Desroziers and Ivanov, 2001).
ONLY_SEA_RAD
Logical, controls whether only assimilating radiance over water.
TIME_WINDOW_MIN
String, e.g., "2007-08-15_03:00:00.0000", start time of assimilation time window
TIME_WINDOW_MAX
String, e.g., "2007-08-15_09:00:00.0000", end time of assimilation time window
USE_ANTCORR (30)
Logical array with dimension RTMINIT_NSENSOR, controls if performing An-
tenna Correction in CRTM.
USE_CLDDET_MMR
Logical, controls whether using the MMR scheme to conduct cloud detection for
infrared radiance.
USE_CLDDET_ECMWF
Logical, controls whether using the ECMWF scheme to conduct cloud detection
for infrared radiance.
AIRS_WARMEST_FOV
Logical, controls whether using the observation brightness temperature for AIRS
Window channel #914 as criterion for GSI thinning.
USE_CRTM_KMATRIX
Logical, controls whether using the CRTM K matrix rather than calling CRTM
TL and AD routines for gradient calculation.
CRTM_CLOUD
Logical, include cloud effects in CRTM calculations.
Further information on this capability can be found in the following publication:
Chun Yang, Zhiquan Liu, Jamie Bresch, Syed R. H. Rizvi, Xiang-Yu Huang and Jinzhong Min,
2016: AMSR2 all-sky radiance assimilation and its impact on the analysis and forecast of Hurri-
cane Sandy with a limited-area data assimilation system. Tellus A, 68, 30917,
doi:10.3402/tellusa.v68.30917.
USE_RTTOV_KMATRIX
Logical, controls whether using the RTTOV K matrix rather than calling RTTOV
TL and AD routines for gradient calculation.
RTTOV_EMIS_ATLAS_IR
Integer, controls the use of the IR emissivity atlas.
Emissivity atlas data (should be downloaded separately from the RTTOV web
site) need to be copied or linked under a sub-directory of the working directory
(emis_data) if RTTOV_EMIS_ATLAS_IR is set to 1.
RTTOV_EMIS_ATLAS_MW
Integer, controls the use of the MW emissivity atlas.
Emissivity atlas data (should be downloaded separately from the RTTOV web
site) need to be copied or linked under a sub-directory of the working directory
(emis_data) if RTTOV_EMIS_ATLAS_MW is set to 1 or 2.
0 means assimilating mode. Innovations (O minus B) are calculated and data are
used in minimization.
1 means monitoring mode: innovations are calculated for diagnostics and moni-
toring. Data are not used in minimization.
write_iv_rad_ascii
Logical. TRUE to write out (observation-background, etc.) diagnostics in-
formation in plain-text files with the prefix ‘inv,’ followed by the instru-
ment name and the processor id. For example, 01_inv_noaa-17-
amsub.0000 (01 is outerloop index, 0000 is processor index)
write_oa_rad_ascii
Logical. TRUE to write out (observation-background, observation-
analysis, etc.) diagnostics information in plain-text files with the prefix
‘oma,’ followed by the instrument name and the processor id. For exam-
ple, 01_oma_noaa-18-mhs.0001
Each processor writes out the information for one instrument in one file in the
WRFDA working directory.
ier data viewing, handling and plotting with netCDF utilities and NCL scripts. See
WRFDA/var/da/da_monitor/README for information on how to use this program.
Steps (3) and (4) can be done by running a single ksh script (also in the WRFDA
Tools package: $TOOLS_DIR/var/scripts/da_rad_diags.ksh) with proper set-
tings. In addition to the settings of directories and what instruments to plot, there
are some useful plotting options, explained below.
mhs only
setenv CLWP_VALUE=0.2 only plot points with
clwp >= clwp_value (when clwp_value > 0)
clwp > clwp_value (when clwp_value = 0)
setenv SI_VALUE=3.0
WRFDA has the ability to assimilate Doppler radar data, either for 3DVAR or 4DVAR
assimilation. Both Doppler velocity and reflectivity can be assimilated, and there are sev-
eral different reflectivity operator options available.
Radar observations are read by WRFDA in a text-based format. This format is described
in the radar tutorial presentation available on the WRFDA website
(http://www2.mmm.ucar.edu/wrf/users/wrfda/Tutorials/2015_Aug/docs/WRFDA_Radar.pdf). Because
radar data comes in a variety of different formats, it is the user’s responsibility to convert
their data into this format. For 3DVAR, these observations should be placed in a file
named ob.radar. For 4DVAR, they should be placed in files named ob01.radar,
ob02.radar, etc., with one observation file per time slot, as described in the earlier
4DVAR section.
Once your observations are prepared, you can run WRFDA the same as you would nor-
mally (see the previous sections on how to run either 3DVAR or 4DVAR). For guidance,
there is an example 3DVAR case available for download at
http://www2.mmm.ucar.edu/wrf/users/wrfda/download/V38/wrfda_radar_testdata.tar.gz.
Edit namelist.input and pay special attention to the radar options listed below. Further
details on some of these options can be found in the following sections
&wrfvar4
use_radarobs true: radar observation files will be read by WRFDA
use_radar_rv true: Assimilate radar velocity observations
use_radar_rf true: Assimilate radar reflectivity using total mixing ratio
use_radar_rhv true: Assimilate retrieved hydrometeors (qr, qs, qg) from radar reflectivity
use_radar_rqv true: Assimilate estimated humidity (qv) from radar reflectivity
/
…
&wrfvar7
cloud_cv_options 0 (default): no hydrometeor control variables
1: use total water (water vapor+cloud liquid water+rain water) control variable
3: use individual hydrometeor control variables (use_radar_rhv = true
only)
use_cv_w false (default): use ω (vertical velocity with respect to pressure) control variable
true: use W (vertical velocity with respect to height) control variable.
For cloud_cv_options = 3 only
/
…
&radar_da
radar_non_precip_opt 0 (default): no null-echo assimilation
1: KNU null-echo scheme
radar_non_precip_rf Reflectivity flag value (dBz) in observation file indicating non-
precipitation echoes (default: -999.99)
The following options apply for use_radar_rqv only:
radar_non_precip_rh_w RH (%) with respect to water for non-precip retrieved Q_vapor (rqv) (de-
fault: 95)
radar_non_precip_rh_i RH (%) with respect to ice for non-precip retrieved rqv (default: 85)
cloudbase_calc_opt Option for calculating cloud-base height: below this height retrieved hu-
midity will not be assimilated for the use_radar_rqv option
0: fixed value of 1500 meters
1 (default): KNU scheme
2: NCAR scheme
radar_saturated_rf rf value (dBz) used to indicate precipitation for rqv (default 25.0)
radar_rqv_thresh1 rf value (dBz) used to scale down retrieved rqv (default 40.0)
radar_rqv_thresh2 rf value (dBz) used to scale down retrieved rqv (default 50.0)
radar_rqv_rh1 RH (%) for radar_saturated_rf < rf < radar_rqv_thresh1 (default 85)
radar_rqv_rh2 RH (%) for radar_rqv_thresh1 < rf < radar_rqv_thresh2 (default 95)
radar_rqv_h_lbound height (meters) lower bound for assimilating rqv (default -999.0)
radar_rqv_h_ubound height (meters) upper bound for assimilating rqv (default -999.0)
NOTE: both namelist settings radar_rqv_h_lbound and ra-
dar_rqv_h_ubound must be set and greater than zero for either to
have an impact
There are two different options for assimilating radar reflectivity data. The first
(use_radar_rf) directly assimilates the observed reflectivity using a reflectivity operator
to convert the model rainwater mixing ratio into reflectivity and the total mixing ratio as
the control variable, as described in Xiao and Sun, 2007
(http://journals.ametsoc.org/doi/full/10.1175/MWR3471.1); this is the only option availa-
ble in WRFDA prior to version 3.7. For this option, the hydrometeors are partitioned us-
ing a warm rain scheme described in the above reference.
There are many tunable parameters that go along with the use_radar_rqv option, which
retrieves a value of cloud humidity for assimilation. There are three possible options for
cloud base height (below which cloud humidity will not be assimilated) as specified by
cloudbase_calc_opt (0 is the previous default behavior and is not recommended). There
are also a few thresholds for scaling the calculated cloud humidity by certain amounts, as
well as an upper and lower altitude bound for assimilating cloud humidity.
New for version 3.9, WRFDA includes the capability to assimilate null-echo observations
(radar_non_precip_opt=1): reflectivity values with a set flag value (ra-
dar_non_precip_rf) will be assimilated as non-precipitation points. This can be an im-
portant radar assimilation technique, as normally you can not remove precipitation from
your analysis without using the retrieved water vapor option (use_radar_rqv). This ca-
pability was developed by Ki-Hong Min from Kyungpook National University, South
Korea (WRF Workshop abstract:
http://www2.mmm.ucar.edu/wrf/users/workshops/WS2016/short_abstracts/P78.pdf).
WRFDA 4D-Var can assimilate NCEP Stage IV radar and gauge precipitation data.
NCEP Stage IV archived data are available on the NCAR CODIAC web page at:
http://data.eol.ucar.edu/codiac/dss/id=21.093 (for more information, please see the NCEP Stage
IV Q&A Web page at http://www.emc.ncep.noaa.gov/mmb/ylin/pcpanl/QandA/). The original pre-
cipitation data are at 4-km resolution on a polar-stereographic grid. Hourly, 6-hourly and
24-hourly analyses are available. The following image shows the accumulated 6-h precip-
It should be mentioned that the NCEP Stage IV archived data is in GRIB1 format and it
cannot be ingested into the WRFDA directly. A tool “precip_converter” is provided to
reformat GRIB1 observations into the WRFDA-readable ASCII format. It can be down-
loaded from the WRFDA users page at
http://www2.mmm.ucar.edu/wrf/users/wrfda/download/precip_converter.tar.gz. The NCEP GRIB li-
braries, w3 and g2 are required to compile the precip_converter utility. These libraries are
available for download from NCEP at http://www.nco.ncep.noaa.gov/pmb/codes/GRIB2/. The
output file to the precip_converter utility is named in the format
ob.rain.yyyymmddhh.xxh; The 'yyyymmddhh' in the file name is the ending hour of the
accumulation period, and 'xx' (=01,06 or 24) is the accumulating time period.
For users wishing to use their own observations instead of NCEP Stage IV, it is the user’s
responsibility to write a Fortran main program and call subroutine writerainobs (in
write_rainobs.f90) to generate their own precipitation data. For more information please
refer to the README file in the precip_converter directory.
WRFDA 4D-Var is able to assimilate hourly, 3-hourly and 6-hourly precipitation data.
According to experiments and related scientific papers, 6-hour precipitation accumula-
tions are the ideal observations to be assimilated, as this leads to better results than direct-
ly assimilating hourly data.
The tutorial example is for assimilating 6-hour accumulated precipitation. In your work-
ing directory, link all the necessary files as follows,
Edit namelist.input (you can start with the same namelist as for the 4dvar tutorial case)
and pay special attention to &wrfvar1 and &wrfvar4 for precipitation-related options.
&wrfvar1
var4d true: Run WRFDA for 4DVAR. This is the only supported option for precipitation
assimilation (default value is false)
var4d_bin_rain length (seconds) of the precipitation assimilation window (default 3600). This can be
different from var4d_bin, which controls the assimilation window for all other ob-
servation types
/
…
&wrfvar4
use_rainobs true (default) : read precipitation data
thin_rainobs true (default): thin precipitation observations
thin_mesh_conv Size of thinning mesh (in km) for non-radiance observations, including precipitation
observations (default value 20.0)
/
x=i*(var4d_bin_rain/var4d_bin)+1,
In the example above, 6-hour accumulated precipitation data is assimilated in 6-hour time
window. In the namelist, values should be set at var4d_bin=3600 and
var4d_bin_rain=21600, and there is one observation file (i.e., i=1) in the time window,
Thus the value of x is 7. The file ob.rain.2008020518.06h should be renamed as
ob07.rain.
Let us take another example for how to rename observation files for 3-hourly precipita-
tion data in 6-hour time window. The sample namelist is as follows,
&wrfvar1
var4d=true,
var4d_lbc=true,
var4d_bin=3600,
var4d_bin_rain=10800,
……
/
The ultimate goal of WRFDA is to combine a WRF file (wrfinput or wrfout) with
observations and error information, in order to produce a “best guess” of the atmospheric
state for your domain. While this “best guess” can be useful on its own for research pur-
poses, it is often more useful as the initial conditions to a WRF forecast, so that the better
initial conditions will ultimately provide a better forecast.
1. Generate initial conditions for WRF (wrfinput) via WPS (as described in
Chapter 3 of this users guide) and real.exe (as described in Chapter 5 of this
users guide)
2. Run WRFDA on this wrfinput to assimilate observations and produce a
wrfvar_output file (a new, improved wrfinput)
3. Run da_update_bc.exe to update the WRF lateral boundary condi-
tions file created in step 1 (wrfbdy_d01) to be consistent with the new
wrfinput_d01 file
4. Run wrf.exe to produce a WRF forecast
discontinuities and poor results at the boundary. For nested domains, domain-2, domain-
3, etc., the lateral boundary conditions are provided by their parent domains, so no lateral
boundary update is needed for these domains. The update procedure is performed by the
WRFDA utility called da_update_bc.exe, and after compilation can be found in
$WRFDA_DIR/var/build.
> cd $WRFDA_DIR/var/test/update_bc
> cp –p $DAT_DIR/rc/2008020512/wrfbdy_d01 .
(IMPORTANT: make a copy of wrfbdy_d01, as the wrf_bdy_file will be over-
written by da_update_bc.exe)
> vi parame.in
&control_param
da_file = '../tutorial/wrfvar_output'
wrf_bdy_file = './wrfbdy_d01'
domain_id = 1
debug = .true.
update_lateral_bdy = .true.
update_low_bdy = .false.
update_lsm = .false.
iswater = 16
var4d_lbc = .false.
/
At this stage, you should have the files wrfvar_output and wrfbdy_d01 in your
WRFDA working directory. They are the WRFDA updated initial and boundary condi-
tion files for any subsequent WRF model runs. To use, link a copy of wrfvar_output
and wrfbdy_d01 to wrfinput_d01 and wrfbdy_d01, respectively, in your WRF
working directory.
You should also see two additional output files: fort.11 and fort.12. These contain
information about the changes made to wrfbdy_d01.
Note: The above instructions for updating lateral boundary conditions do not apply for
child domains (wrfinput_d02, wrfinput_d03, etc.). This is because the lateral boundary
conditions for these domains come from the respective parent domains, so update_bc is
not necessary after running WRFDA when a child domain is used as the first guess.
While the above procedure is useful, often for realtime applications it is better to run a
so-called “cycling” forecast. In a WRF/WRFDA cycling system, rather than using WPS
to generate the initial conditions for your assimilation/forecast, the output from a previ-
ous forecast is used. In this way, information from previous observations can be used to
improve the current “first guess” of the atmosphere, ultimately resulting in an even better
analysis and forecast. The procedure for cycling is as follows:
1. For your initial forecast time (T1), generate initial and boundary conditions
for WRF (wrfinput and wrfbdy_d01) via WPS (as described in Chapter
3 of this users guide) and real.exe (as described in Chapter 5 of this users
guide)
2. Run WRFDA on this wrfinput to assimilate observations to produce a
wrfvar_output file (a new, improved wrfinput)
3. Run da_update_bc.exe to update the WRF lateral boundary conditions
file created in step 1 (wrfbdy_d01) to be consistent with the new wrfin-
put file
4. Run wrf.exe to produce a WRF forecast (wrfout) for the next forecast
time (T2)
5. Repeat step 1 for the next forecast time (T2) to produce initial and boundary
conditions for WRF (wrfinput and wrfbdy_d01) via WPS and real.exe
6. Run da_update_bc.exe to update the lower boundary conditions of
the WRF forecast file (wrfout) with data from the wrfinput file gen-
erated in step 5.
7. Run WRFDA on this wrfout file to assimilate observations and produce a
wrfvar_output file (a new, improved wrfinput for the next WRF fore-
cast)
8. Run da_update_bc.exe again to update the WRF boundary conditions
file created in step 5 (wrfbdy_d01) to be consistent with the new wrfin-
put file
9. Run wrf.exe to produce a WRF forecast (wrfout) for the next forecast
time (T2)
10. Repeat steps 5-9 for the next forecast time(s) ad infinitum (T3, T4, T5…)
In cycling mode, as you can see above, the program da_update_bc.exe is used for
two distinct purposes: prior to running WRFDA it updates the lower boundary conditions
of the WRF forecast file that is used as the first guess for WRFDA, then after running
WRFDA it updates the lateral boundary conditions file (wrfbdy_d01) to be consistent
with the WRFDA output (a new, improved wrfinput for the next WRF forecast). The
use of da_update_bc.exe to update the lateral boundary conditions was covered in
the previous section, and this section will cover the second use: using
da_update_bc.exe to update the lower boundary conditions.
The reason that this additional step is necessary for cycling forecasts: While a WRF fore-
cast integrates atmospheric variables forward in time, it does not update certain lower
boundary conditions, such as vegetation fraction, sea ice, snow cover, etc, which are im-
portant for both forecasts and data assimilation. For short periods of time, this is not a
problem, as these fields do not tend to evolve much over the course of a few days. How-
ever, for a cycling forecast that runs for weeks, months, or even years, it is essential to
update these fields regularly from the initial condition files through WPS.
To do this, prior to the assimilation process, the first guess file needs to be updated based
on the information from the wrfinput file, generated by WPS/real.exe at analysis time.
You should run da_update_bc.exe with the following namelist options:
da_file = './fg'
wrf_input = './wrfinput_d01'
update_lateral_bdy = .false.
update_low_bdy = .true.
iswater = 16
Note: “iswater” (water point index) is 16 for USGS LANDUSE and 17 for MODIS LANDUSE.
If you activate the var4d_lbc option in a WRF 4D-Var run, in addition to the above-
mentioned files you will also need the ana02 file from the WRFDA working directory. In
parame.in, set var4d_lbc to TRUE and use “da_file_02” to point to the location of
the ana02 file.
da_file_02 = './ana02'
var4d_lbc = .true.
To run WRFDA with the generic CV3 option, simply link the provided be.dat file in the
var/run directory:
To run WRFDA with any other option, you will have to run GEN_BE first. GEN_BE
takes a series of forecasts initialized at different times, and compares the forecasts that
are valid at the same time (e.g., compare a 24-hour forecast initialized at 00Z with a 12-
hour forecast initialized at 12Z) to get an estimate of the background error statistics.
You will use the wrapper script gen_be_wrapper.ksh to run GEN_BE. For instructions
on how to set up your experiment to run GEN_BE, reference the test case as described in
the section “Domain-specific background error options: Running GEN_BE” below.
Users have four choices to define the background error covariance (BE). We call them
CV3, CV5, CV6, and CV7. Each of these has different properties, which are outlined in
the table below:
With CV3, the control variables are in physical space while with CV5, CV6, and CV7,
the control variables are in eigenvector space. The major difference between these two
kinds of BE is the vertical covariance; CV3 uses the vertical recursive filter to model the
vertical covariance but the others use an empirical orthogonal function (EOF) to represent
the vertical covariance. The recursive filters to model the horizontal covariance are also
different with these BEs. We have not conducted the systematic comparison of the anal-
yses based on these BEs. However, CV3 (a BE file provided with our WRFDA system) is
a global BE and can be used for any regional domain, while CV5, CV6, and CV7 BE’s
are domain-dependent, and so should be generated based on forecast or ensemble data
from the same domain.
As summarized in the above table, CV5, CV6, and CV7 differ in the control variables
they use. CV5 utilizes streamfunction (ψ), unbalanced velocity potential (χu), unbalanced
temperature (Tu), pseudo relative humidity (RHs), and unbalanced surface pressure (Ps,u).
The pseudo relative humidity is defined as Q/Qb,s, where Qb,s is the saturated specific hu-
midity from the background field. For CV6 the moisture control variable is the unbal-
anced portion of the pseudo relative humidity (RHs,u). Additionally, CV6 introduces six
additional correlation coefficients in the definition of the balanced part of analysis control
variables. See the section GEN_BE for CV6 for more details on this option. Finally, CV7
uses a different set of control variables: u, v, temperature, pseudo relative humidity
(RHs), and surface pressure (Ps).
CV3 is the NCEP background error covariance. It is estimated in grid space by what has
become known as the NMC method (Parrish and Derber 1992) . The statistics are esti-
mated with the differences of 24 and 48-hour GFS forecasts with T170 resolution, valid
at the same time for 357 cases, distributed over a period of one year. Both the amplitudes
and the scales of the background error have to be tuned to represent the forecast error in
the estimated fields. The statistics that project multivariate relations among variables are
also derived from the NMC method.
The variance of each variable, and the variance of its second derivative, are used to esti-
mate its horizontal scales. For example, the horizontal scales of the stream function can
be estimated from the variance of the vorticity and stream function.
The vertical scales are estimated with the vertical correlation of each variable. A table is
built to cover the range of vertical scales for the variables. The table is then used to find
the scales in vertical grid units. The filter profile and the vertical correlation are fitted lo-
cally. The scale of the best fit from the table is assigned as the scale of the variable at that
vertical level for each latitude. Note that the vertical scales are locally defined so that the
negative correlation further away, in the vertical direction, is not included.
Theoretically, CV3 BE is a generic background error statistics file which can be used for
any case. It is quite straightforward to use CV3 in your own case. To use the CV3 BE file
in your case, set cv_options=3 in &wrfvar7 in namelist.input in your working direc-
tory, and use the be.dat is located in WRFDA/var/run/be.dat.cv3.
The scaling factors for CV3 are stored as an array of values for each individual control
variable:
These variables are all 3-element vectors. The first element is the variance scaling factor.
The second is the horizontal length scale factor. The third is the vertical length scale fac-
tor. So setting the default values in your namelist would look like this:
&wrfvar7
cv_options = 3,
as1 = 0.25, 1.00, 1.50,
as2 = 0.25, 1.00, 1.50,
as3 = 0.25, 1.00, 1.50,
as4 = 0.25, 1.00, 1.50,
as5 = 0.25, 1.00, 1.50,
/
The first column is the variance, the second is the horizontal length scale factor, and the
third is the vertical length scale factor.
For multiple outer loops, the next 3 elements of each vector must be filled in. So for 2
outer loops (max_ext_its=2), to use the default values, the namelist should look like this:
&wrfvar7
cv_options = 3,
as1 = 0.25, 1.00, 1.50, 0.25, 1.00, 1.50,
as2 = 0.25, 1.00, 1.50, 0.25, 1.00, 1.50,
as3 = 0.25, 1.00, 1.50, 0.25, 1.00, 1.50,
as4 = 0.25, 1.00, 1.50, 0.25, 1.00, 1.50,
as5 = 0.25, 1.00, 1.50, 0.25, 1.00, 1.50,
/
Again, the first column is the variance, the second is the horizontal length scale factor,
and the third is the vertical length scale factor for the first outer loop. The fourth column
is the variance, the fifth is the horizontal length scale factor, and the sixth is the vertical
length scale factor for the second outer loop.
Continue in this manner for more outer loops. The values listed above are the default val-
ues, but can be adjusted for each individual experiment.
To use CV5, CV6 or CV7 background error covariance, it is necessary to generate your
domain-specific background error statistics with the gen_be utility. The default CV3
background error statistics file, supplied with the WRFDA source code, can NOT be used
with these control variable options.
The main source code for the various gen_be stages can be found in WRFDA/var/gen_be.
The executables of gen_be should have been created when you compiled the WRFDA
code (as described earlier). The scripts to run these codes are in
WRFDA/var/scripts/gen_be. The user can run gen_be using the wrapper script
WRFDA/var/scripts/gen_be/gen_be_wrapper.ksh.
The input data for gen_be are WRF forecasts, which are used to generate model perturba-
tions, used as a proxy for estimates of forecast error. For the NMC-method, the model
perturbations are differences between forecasts (e.g. T+24 minus T+12 is typical for re-
gional applications, T+48 minus T+24 for global) valid at the same time. Climatological
estimates of background error may then be obtained by averaging these forecast differ-
ences over a period of time (e.g. one month). Given input from an ensemble prediction
system (EPS), the inputs are the ensemble forecasts, and the model perturbations created
are the transformed ensemble perturbations. The gen_be code has been designed to work
with either forecast difference or ensemble-based perturbations. The former is illustrated
in this tutorial example.
It is important to include forecast differences valid at different parts of the day (for ex-
ample, forecasts valid at 00Z and 12Z through the forecast period) to remove contribu-
tions from the diurnal cycle (i.e. do not run gen_be using model perturbations valid for a
single time each day).
The inputs to gen_be are netCDF WRF forecast output ("wrfout") files at specified fore-
cast ranges. To avoid unnecessary large single data files, it is assumed that all forecast
ranges are output to separate files. For example, if we wish to calculate BE statistics us-
ing the NMC-method with (T+24)-(T+12) forecast differences (default for regional) then
by setting the WRF namelist.input options history_interval=720, and
frames_per_outfile=1 we get the necessary output datasets. Then the forecast output
files should be arranged as follows: directory name is the forecast initial time, time info
in the file name is the forecast valid time. 2008020512/wrfout_d01_2008-02-
06_00:00:00 means a 12-hour forecast valid at 2008020600, initialized at 2008020512.
Example dataset for a test case (90 x 60 x 41 gridpoints) can be downloaded from
http://www2.mmm.ucar.edu/wrf/users/wrfda/download/testdata.html. Untar the
gen_be_forecasts_20080205.tar.gz file. You will have:
>ls $FC_DIR
In the above example, only 1 day (12Z 05 Feb to 12Z 06 Feb. 2008) of forecasts, every
12 hours is supplied to gen_be_wrapper to estimate forecast error covariance. It is only
for demonstration. The minimum number of forecasts required depends on the applica-
tion, number of grid points, etc. Month-long (or longer) datasets are typical for the NMC-
method. Generally, at least a 1-month dataset should be used.
Note: The START_DATE and END_DATE are perturbation valid dates. As shown in the
forecast list above, when you have 24-hour and 12-hour forecasts initialized at
2008020512, through 2008020612, the first and final forecast difference valid dates are
2008020612 and 2008020700, respectively.
> gen_be_wrapper.ksh
Once the gen_be_wrapper.ksh run is completed, the be.dat can be found under the
$RUN_DIR directory.
CV6 background error statistics for WRFDA are generated by executing a top-level
script, gen_be/wrapper_gen_mbe.ksh, residing under SCRIPTS_DIR via a suitable wrap-
per script. The rest of the procedure remains the same as with normal running of the
gen_be utility. A successful run will create a be.dat file in the RUN_DIR directory.
After successfully generating the CV6 background error statistics file be.dat, the proce-
dure for running WRFDA is straight-forward: Include cv_options=6 in the namel-
ist.input file under the &wrfvar7 list of namelist options.
Below is a list of nine tuning parameters available in WRFDA; these can be specified un-
der &wrfvar7 in the namelist. Default values for these variables are set as “1.0”. Setting
corresponding values > 1.0 (< 1.0) will increase (decrease) the corresponding contribu-
tions:
With the single observation test, you may get some ideas of how the background and ob-
servation error statistics work in the model variable space. A single observation test is
done in WRFDA by setting num_pseudo=1, along with other pre-specified values in rec-
ord &wrfvar15 and &wrfvar19 of namelist.input.
With the settings shown below, WRFDA generates a single observation with a pre-
specified innovation (Observation − First Guess) value at the desired location; e.g. at (in
terms of grid coordinate) 23x23, level 14 for “U” observation with error characteristics 1
m/s, and innovation size = 1.0 m/s.
&wrfvar15
num_pseudo = 1,
pseudo_x = 23.0,
pseudo_y = 23.0,
pseudo_z = 14.0,
pseudo_err = 1.0,
pseudo_val = 1.0,
/
&wrfvar19
pseudo_var = 'u',
/
You may wish to repeat this exercise for other observation types. “pseudo_var” can take
any of the following values:
Run the single observation test with the following additional parameters in record
&wrfvar7 of namelist.input.
&wrfvar7
len_scaling1 = 0.5, # reduce psi length scale by 50%
len_scaling2 = 0.5, # reduce chi_u length scale by 50%
len_scaling3 = 0.5, # reduce T length scale by 50%
len_scaling4 = 0.5, # reduce q length scale by 50%
len_scaling5 = 0.5, # reduce Ps length scale by 50%
/
Note: You may wish to try the response of an individual variable by setting one parame-
ter at a time. Note the spread of analysis increment.
Run the single observation test with the following additional parameters in record
&wrfvar7 of namelist.input.
&wrfvar7
var_scaling1 = 0.25, # reduce psi variance by 75%
var_scaling2 = 0.25, # reduce chi_u variance by 75%
var_scaling3 = 0.25, # reduce T variance by 75%
var_scaling4 = 0.25, # reduce q variance by 75%
var_scaling5 = 0.25, # reduce Ps variance by 75%
/
Note: You may wish to try the response of individual variable by setting one parameter at
a time. Note the magnitude of analysis increments.
WRFDA Diagnostics
WRFDA produces a number of diagnostic files that contain useful information on how
the data assimilation has performed. This section will introduce you to some of these
files, and what to look for.
After running WRFDA, it is important to check a number of output files to see if the as-
similation appears sensible. The WRFDA package, which includes several useful scripts,
may be downloaded from http://www2.mmm.ucar.edu/wrf/users/wrfda/download/tools.html
cost_fn and grad_fn: These files hold (in ASCII format) WRFDA cost and gradient
function values, respectively, for the first and last iterations. If you run with calcu-
late_cg_cost_fn=true and write_detail_grad_fn=true, however, these values will
be listed for each iteration; this can be helpful for visualization purposes. The NCL script
in the WRFDA TOOLS package located at
var/graphics/ncl/plot_cost_grad_fn.ncl may be used to plot the content of
cost_fn and grad_fn, if these files are generated with calculate_cg_cost_fn=true
and write_detail_grad_fn=true.
namelist.input: This is the WRFDA input namelist file, which contains all the user-
defined non-default options. Any namelist-defined options that do not appear in this file
should have their names checked against the values in
$WRFDA_DIR/Registry/registry.var.
namelist.output.da: A list of all the namelist options used. If an option was not speci-
fied in namelist.input, the default listed in the registry value will be used.
rsl*: Files containing information for standard WRFDA output from individual proces-
sors when multiple processors are used. It contains a host of information on a number of
observations, minimization, timings, etc. Additional diagnostics may be printed in these
files by including various “print” WRFDA namelist options. To learn more about these
additional “print” options, search for the “print_” string in
$WRFDA_DIR/Registry/registry.var.
statistics: Text file containing OMB (OI) and OMA (OA) statistics (minimum, maxi-
mum, mean and standard deviation) for each observation type and variable. This infor-
mation is very useful in diagnosing how WRFDA has used different components of the
observing system. Also contained are the analysis minus background (A-B) statistics, i.e.
statistics of the analysis increments for each model variable at each model level. This in-
formation is very useful in checking the range of analysis increment values found in the
analysis, and where they are in the WRF-model grid space.
WRFDA
The WRFDA analysis file is wrfvar_output. It is in WRF (netCDF) format. It will be-
come the input file wrfinput_d01 of any subsequent WRF run after lateral boundary
and/or lower boundary conditions are updated by another WRFDA utility (See the section
Updating WRF boundary conditions).
As an example, if you are aiming to display the U-component of the analysis at level 18,
use the script WRF-Var_plot.ncl, and make sure the following pieces of codes are un-
commented:
var = "U"
fg = first_guess->U
an = analysis->U
plot_data = an
You may change the variable name, level, etc. in this script to display the variable of your
choice at the desired eta level.
Take time to look through the text output files to ensure you understand how WRFDA
works. For example:
How closely has WRFDA fit individual observation types? Look at the statis-
tics file to compare the O-B and O-A statistics.
How big are the analysis increments? Again, look in the statistics file to see
minimum/maximum values of A-B for each variable at various levels. It will give
you a feel for the impact of the input observation data you assimilated via
WRFDA by modifying the input analysis first guess.
How long did WRFDA take to converge? Does it really converge? You will get
the answers of all these questions by looking into the rsl.* -files, as it indicates
the number of iterations taken by WRFDA to converge. If this is the same as the
maximum number of iterations specified in the namelist (NTMAX), or its default
value (=200) set in $WRFDA_DIR/Registry/registry.var, then it means that the
analysis solution did not converge. If this is the case, you may need to increase
the value of “NTMAX” and rerun your case to ensure that the convergence is
achieved. On the other hand, a normal WRFDA run should usually converge
within 100 iterations. If it still doesn’t converge in 200 iterations, that means there
may be a problem in the observations or first guess.
A good way to visualize the impact of assimilation of observations is to plot the analysis
increments (i.e. analysis minus the first guess difference). Many different graphics pack-
ages (e.g. RIP4, NCL, GRADS etc) can do this.
You need to modify this script to fix the full path for first_guess and analysis files.
You may also use it to modify the display level by setting kl and the name of the variable
to display by setting var. Further details are given in this script.
If you are aiming to display the increment of potential temperature at level 18, after mod-
ifying $WRFDA_DIR/var/graphics/ncl/WRF-Var_plot.ncl, make sure the following
pieces of code are uncommented:
var = "T"
fg = first_guess->T ;Theta- 300
an = analysis->T ;Theta- 300
plot_data = an - fg
Note: Larger analysis increments indicate a larger data impact in the corresponding re-
gion of the domain.
In addition to the variational methods previously mentioned, the WRFDA system sup-
ports both ensemble and hybrid ensemble/variational assimilation methods. To utilize
these methods, having an ensemble of forecasts is necessary. WRFDA has a built-in
method for generating ensemble initial conditions known as RANDOMCV. RAN-
DOMCV works by adding random noise to the analysis in control variable space.
RANDOMCV is a capability of the main WRFDA executable, so you will run it by set-
ting the following variables in namelist.input and then running da_wrfvar.exe as you
would with any data assimilation run:
&wrfvar5
put_rand_seed true: enter your own seed numbers to generate random background perturbations.
The advantage of this setting is that the same seed numbers will always produce the
same perturbation
false: (default behavior) perturbations will be generated “randomly” and give new
perturbations each time
&wrfvar11
seed_array1 First integer for seeding the random function (default: 1)
seed_array2 Second integer for seeding the random function (default: 1) It is not necessary to
change both seeds to get different perturbations
&wrfvar17
analysis_type Set this to ‘RANDOMCV’ to use the RANDOMCV capability
When setting your own random seeds, a common good practice is to set the first seed as
the experiment date/time in integer form, and the second seed as the ensemble member
number. The seeds should not be set to zero.
Because the perturbations are made in control variable space, the general pattern of per-
turbations will depend on your background error. You should be able to use any back-
ground error option with RANDOMCV (CV3, CV5, CV6, or CV7). Additionally, this
means you can control their magnitude and lengthscales by modifying the background
error variance and length scaling variables respectively:
For CV3, see the section “Modifying CV3 length scales and variance”.
The WRFDA system also includes hybrid data assimilation techniques—both 3DEnVar
and 4DEnVar (new for version 3.9), which is based on the previously-described varia-
tional capability.
The difference between hybrid and variational schemes is that WRFDA 3DVAR and
4DVAR rely solely on a static covariance model to specify the background errors, while
the hybrid system uses a combination of static error covariances and ensemble-estimated
error covariances to incorporate a flow-dependent estimate of the background error statis-
tics. The following sections will give a brief introduction to using the hybrid system.
Please refer to these papers for a detailed description of the methodology used in the
WRFDA hybrid system:
Xuguang Wang, Dale M. Barker, Chris Snyder, and Thomas M. Hamill, 2008: A
hybrid ETKF–3DVAR data assimilation scheme for the WRF model. Part I: Ob-
serving system simulation experiment. Mon. Wea. Rev., 136, 5116–5131.
Xuguang Wang, Dale M. Barker, Chris Snyder, and Thomas M. Hamill, 2008: A
Hybrid ETKF–3DVAR Data Assimilation Scheme for the WRF Model. Part II:
Real Observation Experiments. Mon. Wea. Rev., 136, 5132–5147.
Four executables are used in the hybrid system. If you have successfully compiled the
WRFDA system, the following executables will exist in the WRFDA/var/build directory:
WRFDA/var/build/gen_be_ensmean.exe
WRFDA/var/build/gen_be_ep2.exe
WRFDA/var/build/da_wrfvar.exe
WRFDA/var/build/gen_be_vertloc.exe
The procedure is the same as running 3DVAR, with the exception of some extra input
files and namelist settings. The basic input files for WRFDA are LANDUSE.TBL,
ob.ascii or ob.bufr (depending on which observation format you use), and be.dat
(static background errors). Additional input files required for 3DEnVar are a single en-
semble mean file (used as the fg for the hybrid application) and a set of ensemble pertur-
bation files (used to represent flow-dependent background errors).
A set of initial ensemble members must be prepared before the hybrid application can be
started. The ensemble can be obtained from other ensemble model outputs, or you can
generate them yourself. This can be done, for example, adding random noise to the initial
conditions at a previous time and integrating each member to the desired time. A tutorial
case with a test ensemble can be found at
http://www2.mmm.ucar.edu/wrf/users/wrfda/download/V38/wrfda_hybrid_etkf_testdata.tar.gz. In this
example, the ensemble forecasts were initialized at 2015102612 and valid 2015102712.
A hybrid analysis at 2015102712 will be performed using the ensemble valid
2015102712 as input. Once you have the initial ensemble, the ensemble mean and pertur-
bations can be calculated following the steps below:
1) Set an environment variable for your working directory and your data directory
a) From your working directory, copy or link the ensemble forecasts to your work-
ing directory. The ensemble members are identified by the characters “.e###” at
the end of the file name, where ### represents three-digit numbers following the
valid time.
b) Provide two template files (ensemble mean and variance files) in your working
directory. These files will be overwritten with the ensemble mean and variance as
discussed below.
> cp $DAT_DIR/Hybrid/fc/2015102612/wrfout_d01_2015-10-
27_12:00:00.e001 ./wrfout_d01_2015-10-27_12:00:00.mean
> cp $DAT_DIR/Hybrid/fc/2015102612/wrfout_d01_2015-10-
27_12:00:00.e001 ./wrfout_d01_2015-10-27_12:00:00.vari
&gen_be_ensmean_nl
directory = '.'
filename = 'wrfout_d01_2015-10-27_12:00:00'
num_members = 10
nv = 7
cv = 'U', 'V', 'W', 'PH', 'T', 'MU', 'QVAPOR'
/
where directory is the folder containing the ensemble members and template files,
filename is the name of the files before their suffixes (e.g., .mean, .vari, etc),
num_members is the number of ensemble members you are using, nv is the number of
variables, and cv is the name of variables used in the hybrid system. Be sure nv and
cv are consistent!
c) Check the output files. A list of binary files should now exist. Among them,
4) Back in the working directory, create the input file for vertical localization. This pro-
gram requires one command-line argument: the number of vertical levels of the mod-
el configuration (same value as e_vert in the namelist; for the tutorial example, this
should be 42).
> cd $WORK_DIR
> ln –sf $WRFDA_DIR/var/build/gen_be_vertloc.exe .
> ./gen_be_vertloc.exe 42
a) In your hybrid working directory, link all the necessary files and directories as
follows:
&wrfvar7
je_factor = 2.0
/
&wrfvar16
ensdim_alpha = 10
alphacv_method = 2
alpha_corr_type=3
alpha_corr_scale = 500.0
alpha_std_dev=1.000
alpha_vertloc = .true.
/
Check the output files; the output file lists are the same as when you run WRF
3D-Var.
The procedure for 4DEnVar is very similar to the procedure for 3DEnVar. Unlike
4DVAR, 4DEnVar does not require WRFPLUS, the tangent linear/adjoint model. It is
more analogous to the First Guess at Appropriate Time (FGAT) method than full
4DVAR. Like FGAT, 4DEnVar requires multiple first guess files, one for each assimila-
tion time window. In addition, you must have ensemble output for each of the first guess
times, and generate ensemble perturbations from each of these sets of ensemble forecasts.
To activate the 4DEnVar option, set the namelist variable use_4denvar=.true.
under &wrfvar16. A tutorial case with a test ensemble can be found at
http://www2.mmm.ucar.edu/wrf/users/wrfda/download/V39/WRFDA_4denvar_test_data.tar.gz. In this
example, the ensemble forecasts were initialized at 2005071512 and valid for
2005071521—2005071603. The 4DEnVar hybrid analysis (wrfvar_output) will be valid
for 2005071600.
c. Dual-resolution hybrid
WRFDA has an option for dual-resolution hybrid data assimilation, where a high-
resolution background can make use of a lower-resolution ensemble for extracting the
flow-dependent contribution to the background error. The lower-resolution ensemble
should be the parent domain of the higher-resolution child domain that the analysis is per-
formed on.
Performing dual-resolution hybrid assimilation is similar to the process for regular
assimilation described above. The main difference is that you must include some settings
in the &domains section of the namelist in a different way: The setting max_dom=2 must
be used, and for each column of settings, the low-resolution domain settings must be
listed first, even though the second column will be the domain on which assimilation is
being performed. An example of the &domains namelist section is shown below; in this
case, the low-resolution ensemble domain is 222x128 grid points at 45 km resolution, and
the high-resolution analysis domain is 184x196 grid points at 15 km resolution:
&domains
time_step = 90,
max_dom = 2,
s_we = 1, 1,
e_we = 222, 184,
s_sn = 1, 1,
e_sn = 128, 196,
s_vert = 1, 1,
e_vert = 45, 45,
dx = 45000, 15000,
dy = 45000, 15000,
grid_id = 1, 2,
parent_id = 0, 1,
i_parent_start = 0, 89,
j_parent_start = 0, 22,
parent_grid_ratio = 1, 3,
/
For further details about any of the above settings, see Chapter 5 of this User’s
Guide.
In addition to the above, you must set the namelist variable hy-
brid_dual_res=true, as well as providing a file named “fg_ens” in the working directo-
ry. This file can be any WRF input or wrfout file that has the same domain as the low-
resolution ensemble; it is merely used for reading in mapping parameters for the low-
resolution ensemble domain.
The dual-resolution hybrid capability is described in more detail in the following
publication:
&wrfvar7
je_factor
ensemble covariance weighting factor. This factor controls the weighting compo-
nent of ensemble and static covariances. The corresponding jb_factor =
je_factor/(je_factor - 1).
&wrfvar16
use_4denvar
.true. will activate 4DEnVar
hybrid_dual_res
.true. will activate dual-resolution mode
ep_para_read
Method for reading ensemble perturbation files
0 (default): Serial read
1: Parallel read.
rden_bin
bins for parallel reading of ensemble perturbation files. Default is 1. Lower num-
bers use more memory, but are faster. If memory use becomes too large, increase
this value.
ensdim_alpha
the number of ensemble members. Hybrid mode is activated when ensdim_alpha
is larger than zero
alphacv_method
2 (default): perturbations in model space (“u”,”v”,”t”,”q”,”ps”). Option 2 is ex-
tensively tested and recommended to use.
1: perturbations in control variable space (“psi”,”chi_u”,”t_u”,”rh”,”ps_u”)
alpha_corr_type
correlation function. 1=Exponential; 2=SOAR; 3=Gaussian.
alpha_corr_scale
hybrid covariance localization scale in km unit. Default value is 200.
alpha_std_dev
alpha standard deviation. Default value is 1.0
alpha_vertloc
true: use vertical localization
false (default): no vertical localization
The WRFDA system also includes a ETKF assimilation technique. The ETKF system
updates the ensemble perturbations. Please refer to Bishop et al. (2001) and Wang et al.
(2003) for a detailed description of the methodology. The following section will give a
brief introduction of some aspects of using the ETKF system.
a. Source Code
Three executables are used in the ETKF system. If you have successfully compiled the
WRFDA system, you will see the following:
WRFDA/var/build/gen_be_etkf.exe
WRFDA/var/build/gen_be_addmean.exe
WRFDA/var/build/da_wrfvar.exe
The first procedure is to update the ensemble perturbations. A set of initial ensemble
members must be prepared before the ETKF application can be started. The ensemble can
be obtained from a previous ensemble forecast. A tutorial case with a test ensemble can
be found at
http://www2.mmm.ucar.edu/wrf/users/wrfda/download/V38/wrfda_hybrid_etkf_testdata.tar.gz. In this
example, the ensemble forecasts were initialized at 2015102612 and valid 2015102712.
ETKF will be performed using the ensemble valid 2015102712 as input. Once you have
the initial ensemble, the ensemble perturbations can be updated by following the steps
below:
&wrfvar17
analysis_type = 'QC-OBS',
/
Check the output files; you should see a 'filtered_obs_01' file which contains the filtered
observations.
a) In your ETKF working directory, make a subdirectory to prepare the omb files for
each ensemble member and link all the necessary files and directories as follows:
> cd $WORK_DIR_ETKF
> mkdir -p omb/working.e001
> cd omb/working.e001
> ln -fs $DAT_DIR/Hybrid/fc/2015102612/wrfout_d01_2015-10-
27_12:00:00.e001 ./fg (first guess is the ensemble member)
> ln -fs $WRFDA_DIR/run/LANDUSE.TBL .
> ln -fs $WORK_DIR_ETKF/obs_filter/filtered_obs_01 ./ob.ascii
> ln -fs $DAT_DIR/Hybrid/be/be.dat ./be.dat
> ln -fs $WRFDA_DIR/var/build/da_wrfvar.exe .
> cp $DAT_DIR/ETKF/namelist.input .
&wrfvar17
analysis_type = 'VERIFY',
Check the output files. The output files are the same as when you run WRF 3D-Var (ex-
cept wrfvar_output will NOT be created), and the 'ob.etkf.0*' files are omb files.
d) Combine the ob.etkf.0* files and add the observation number in the head of
ob.etkf.e0*
4) Run ETKF
a) Copy or link the ensemble mean and forecasts and ob.etkf.e0* files to your working
directory and make a parameter directory to save the parameter files.
> cd $WORK_DIR_ETKF
> setenv PAR_DIR_ETKF $WORK_DIR_ETKF/param
> mkdir $PAR_DIR_ETKF
> ln -sf $DAT_DIR/Hybrid/fc/2015102612/wrfout_d01_2015-10-
27_12:00:00.mean ./etkf_input
> ln -sf $DAT_DIR/Hybrid/fc/2015102612/wrfout_d01_2015-10-
27_12:00:00.e001 ./etkf_input.e001
...
> ln -sf $DAT_DIR/Hybrid/fc/2015102712/wrfout_d01_2015-10-
27_12:00:00.e010 ./etkf_input.e010
b) Provide template files. These files will be overwritten with the ensemble perturba-
tions.
> cp $DAT_DIR/Hybrid/fc/2015102612/wrfout_d01_2015-10-
27_12:00:00.e001 ./etkf_output.e001
...
> cp $DAT_DIR/Hybrid/fc/2015102612/wrfout_d01_2015-10-
27_12:00:00.e010 ./etkf_output.e010
&gen_be_etkf_nl
num_members = 10,
nv = 7,
cv = 'U', 'V', 'W', 'PH', 'T', 'QVAPOR', 'MU',
naccumt1 = 20,
naccumt2 = 20,
nstartaccum1 = 1,
nstartaccum2 = 1,
nout = 1,
tainflatinput = 1,
rhoinput = 1,
infl_fac_file = '$PAR_DIR_ETKF/inflation_factor.dat',
infl_let_file = '$PAR_DIR_ETKF/inflation_letkf.dat',
eigen_val_file = '$PAR_DIR_ETKF/eigen_value.dat',
inno2_val_file = '$PAR_DIR_ETKF/innovation_value.dat',
proj2_val_file = '$PAR_DIR_ETKF/projection_value.dat',
infl_fac_TRNK = .false.,
infl_fac_WG03 = .false.,
infl_fac_WG07 = .true.,
infl_fac_BOWL = .false.,
letkf_flg=.false.,
rand_filt = .false.,
rnd_seed = 2015102712,
rnd_nobs = 5000
etkf_erro_max = 20.
etkf_erro_min = .00001
etkf_inno_max = 20.
etkf_inno_min = .00001
etkf_erro_flg = .true.
etkf_inno_flg = .true.
etkf_wrfda = .false.
/
Important note: since environment variables are not parsed when reading namelists, you
MUST manually change $PAR_DIR_ETKF to its actual value in the namelist
Check the output files. etkf_output.* files are updated ensemble perturbations.
5) Add updated ensemble perturbations to the ensemble mean to get new ensemble
members
> cd $WORK_DIR_ETKF
&add_mean_nl
num_members = 10
cv = 'U', 'V', 'W', 'PH', 'T', 'QVAPOR', 'MU'
nv = 7
path = '$WORK_DIR_ETKF'
file_mean = 'etkf_input'
file_pert = 'etkf_output.e001' (for each member,
etkf_output.e0*...)
/
b) Run gen_be_addmean.exe.
Check the output files. etkf_output.e0* files are the new ensemble members.
&wrfvar2
wind_sd true: all wind values which are reported as speed/direction will be assimilated as
such
false: (default behavior) all wind obs are converted to u/v prior to assimilation
wind_stats_sd Assimilate wind in u/v format, but output speed/direction statistics
The following settings only matter if check_max_iv=true (if innovation is greater than
observation error times the error factor listed below, the observation will be rejected):
&wrfvar2
qc_rej_both true: if either u or v (spd or dir) do not pass quality control, both obs are rejected
false: (default behavior) qc on wind obs is handled individually
&wrfvar5
max_omb_spd Max absolute value of innovation for wind speed obs in m/s; greater than this and the
innovation will be set to zero (default: 100.0)
max_omb_dir Max absolute value of innovation for wind direction obs in degrees; greater than this
and the innovation will be set to zero (default: 1000.0)
max_error_spd Speed error factor (default: 5.0)
max_error_dir Direction error factor (default: 5.0)
The assimilation of wind speed/direction can also be controlled by observation type, us-
ing the following variables (note: setting wind_sd = .true. as above will override the-
se individual settings):
&wrfvar2
wind_sd_airep Aircraft reports
wind_sd_buoy Buoy reports
wind_sd_geoamv Geostationary satellite atmospheric motion vectors
wind_sd_metar METAR reports
wind_sd_mtgirs Meteosat Third Generation
wind_sd_pilot Pilot reports
wind_sd_polaramv Polar satellite atmospheric motion vectors
wind_sd_profiler Wind profiler reports
wind_sd_qscat QuikScat reports
wind_sd_ships Ship reports
wind_sd_sound Sounding reports
wind_sd_synop Synoptic reports
wind_sd_tamdar TAMDAR reports
true: wind values which are reported as speed/direction will be assimilated as such
false: (default behavior) all wind obs are converted to u/v prior to assimilation
Further details about this method can be found in the following publications:
Gao, Feng, Xiang-Yu Huang, Neil A. Jacobs, and Hongli Wang, 2015: Assimila-
tion of wind speed and direction observations: results from real observation ex-
periments. Tellus A, 67, 27132, doi:10.3402/tellusa.v67.27132.
For Version 3.8, a new “weak penalty constraint” (WPEC) option has been added to
WRFDA which aims to enforce quasi-gradient balance on a WRFDA analysis. It was de-
signed with the specific aim of improving assimilation of radar data within tropical cy-
clones, but may be useful for other weather phenomena of similar scales. It can be used
with 3DVAR or hybrid 3DVAR (4DVAR is not compatible with this new capability).
Further details about this method can be found in the following publication:
Li, X., J. Ming, M. Xue, Y. Wang, and K. Zhao, 2015: Implementation of a dy-
namic equation constraint based on the steady state momentum equations within
the WRF hybrid ensemble-3DVar data assimilation system and test with radar T-
TREC wind assimilation for tropical Cyclone Chanthu (2010). J. Geophys. Res.
Atmos., 120, 4017–4039, doi: 10.1002/2014JD022706.
&wrfvar12
use_wpec true: enables the constraint term
false: (default behavior) disables the constraint term
wpec_factor The constraint’s weighting factor (1/Γ) as described in the paper
balance_type 1 = geostrophic term
2 = cyclostrophic term
3 = geostrophic + cyclostrophic terms (default; recommended)
There are a number of options in WRFDA that are specifically for surface observations
(e.g. METAR, SYNOP). Surface observations should be handled especially cautiously, as
their impact can vary widely based on vertical and horizontal resolution, as well as other
factors. Adjusting the options listed below can help investigate the assimilation of surface
observations, especially in mountainous terrain.
&wrfvar11
These two options work for BUOY, METAR, SHIP, and SYNOP observations, as well as surface-
level sounding and TAMDAR observations.
sfc_assi_options 1 (default): surface observations will be assimilated based on the lowest
model level first guess. Observations are not used when the elevation dif-
ference between the observing site and the lowest model level is larger
than max_stheight_diff
2: surface observations will be assimilated based on surface similarity
theory in PBL. Innovations are computed based on 10-m wind, 2-m tem-
perature and 2-m moisture.
max_stheight_diff Stations whose model-interpolated elevation is different from the actual
observation elevation by greater than this value (default: 100.0) in meters
will be rejected.
&wrfvar1
Variable Name Default Value Description
write_increments false .true.: write out a binary analysis increment file
var4d false .true.: 4D-Var mode
var4d_lbc true .true.: on/off for lateral boundary control in 4D-Var
var4d_bin 3600 seconds, observation sub-window length for 4D-Var
var4d_bin_rain 3600 seconds, precipitation observation sub-window
length for 4D-Var
multi_inc 0 > 0: multi-incremental run
print_detail_radar false print_detail_xxx: output extra (sometimes can be
print_detail_xa false too many) diagnostics for debugging; not recom-
print_detail_xb false mended to turn these on for production runs
print_detail_obs false
print_detail_grad false .true.: to print out a detailed gradient of each obser-
vation type at each iteration
check_max_iv_print true obsolete (used only by Radar)
update_sfc_diags false .true.: update T2/Q2/U10/V10/TH2 with WRFDA
re-diagnosed values. Use only with
sf_sfclay_physics=91 in WRF
&wrfvar2
Variable Name Default Value Description
analysis_accu 900 in seconds: if the time difference between the
namelist date (analysis_date) and date info read-
in from the first guess is larger than analysis_accu,
WRFDA will abort.
num_fgat_time 1 1: 3DVar
> 1: number of time slots for FGAT and 4DVAR
&wrfvar4
Variable Name Default Value Description
thin_conv true Turns on observation thinning for ob_format=1
(NCEP PREPBUFR) only. thin_conv can be set to
.false., but this is not recommended.
thin_conv_ascii false Turns on observation thinning for ob_format=2
(ASCII from OBSPROC) only.
thin_mesh_conv 20. km, each observation type can set its thinning mesh
(max_instrumenand the index/order follows the definition in
ts) WRFDA/var/da/da_control/da_control.f90
use_synopobs true use_xxxobs - .true.: assimilate xxx obs if available
.false.: do not assimilate xxx obs even available
use_shipsobs true
use_metarobs true
use_soundobs true
use_pilotobs true
use_airepobs true
use_geoamvobs true
use_polaramvobs true
use_bogusobs true
use_buoyobs true
use_profilerobs true
use_satemobs true
use_gpspwobs true
use_gpsztdobs false Note: unlike most use_*obs variables, the default
for use_gpsztdobs is false. This is because PW and
ZTD observations can not be assimilated simultane-
ously, so one of them must be false.
use_gpsrefobs true
use_qscatobs true
use_radarobs false .true.: Assimilate radar data
use_radar_rv false Assimilate radar velocity observations
use_radar_rf false Assimilate radar reflectivity using original reflectiv-
ity operator (total mixing ratio)
use_radar_rhv false Assimilate retrieved hydrometeors (qr, qs, qg) from
radar reflectivity
use_radar_rqv false Assimilate estimated humidity (qv) from radar re-
flectivity
use_rainobs false .true.: Assimilate precipitation data
thin_rainobs true .true.: perform thinning on precipitation data
use_airsretobs true
; use_hirs2obs, use_hirs3obs, use_hirs4obs, use_mhsobs, use_msuobs,
; use_amsuaobs, use_amsubobs, use_airsobs, use_eos_amsuaobs, use_ssmisobs are
; radiance-related variables that only control if corresponding BUFR files are read
; into WRFDA or not, but do not control if the data is assimilated or not. Additional
; variables have to be set in &wrfvar14 in order to assimilate radiance data.
use_hirs2obs false .true.: read in data from hirs2.bufr
use_hirs3obs false .true.: read in data from hirs3.bufr
use_hirs4obs false .true.: read in data from hirs4.bufr
use_mhsobs false .true.: read in data from mhs.bufr
use_msuobs false .true.: read in data from msu.bufr
use_amsuaobs false .true.: read in data from amsua.bufr
use_amsubobs false .true.: read in data from amsub.bufr
use_airsobs false .true.: read in data from airs.bufr
use_eos_amsuaobs false .true.: read in data EOS-AMSUA data from
airs.bufr
use_ssmisobs false .true.: to read in data from ssmis.bufr
use_atmsobs false .true.: to read in data from atms.bufr
use_iasiobs false .true.: to read in data from iasi.bufr
use_seviriobs false .true.: to read in data from seviri.bufr
use_amsr2obs false .true.: to read in data from AMSR2 files (see section
&wrfvar11
Variable Name Default Value Description
check_rh 0 0 --> No supersaturation check after minimization.
1 --> supersaturation (rh> 100%) and minimum rh
(rh<10%) check, and make the local adjustment of
q.
2 --> supersaturation (rh> 95%) and minimum rh
(rh<11%) check and make the multi-level q adjust-
ment under the constraint of conserved column inte-
grated water vapor
sfc_assi_options 1 1 --> surface observations will be assimilated based
on the lowest model level first guess. Observations
are not used when the elevation difference between
the observing site and the lowest model level is
larger than max_stheight_diff.
2 --> surface observations will be assimilated based
on surface similarity theory in PBL. Innovations are
computed based on 10-m wind, 2-m temperature
and 2-m moisture.
max_stheight_diff 100.0 Height difference in meters. Stations whose model-
interpolated height is different from the actual ob-
servation station height by more than this value will
be rejected.
sfc_hori_intp_options 1 (SYNOP only) Specifies the method of interpolating
the background to observation space
1: 4-point interpolation
pseudo_err 1.0 set the error of the pseudo ob. Unit the same as
&wrfvar20
documentation_url “http://www.m
mm.ucar.edu/pe
ople/wrfhelp/wr
fvar/code/trunk”
&wrfvar21
time_window_min "2002-08- start time of assimilation time window used for
02_21:00:00.00 ob_format=1 and radiances to select observations
00" inside the defined time_window. Note: Start from
V3.1, this variable is also used for ob_format=2 to
double-check if the obs are within the specified time
window.
&wrfvar22
time_window_max "2002-08- end time of assimilation time window used for
03_03:00:00.00 ob_format=1 and radiances to select observations
00" inside the defined time_window. Note: this variable
is also used for ob_format=2 to double-check if the
obs are within the specified time window.
&perturbation (settings related to 4DVAR options)
jcdfi_use false .true.: Include JcDF term in cost function.
.false.: Ignore JcDF term in cost function.
jcdfi_diag 1 0: Doesn't print out the value of Jc.
1:Print out the value of Jc.
jcdfi_penalty 10 The weight to Jc term.
enable_identity .false. .true.: use identity adjoint and tangent linear model
in 4D-Var.
.false.: use full adjoint and tangent linear model in
4D-Var.
trajectory_io .true. .true.: use memory I/O in 4D-Var for data exchange
NOTE: trajectory_io=false is depreciated
and should not be used.
.false.: use disk I/O in 4D-Var for data exchange
var4d_detail_out false .true.: output extra diagnostics for debugging 4D-
Var
&radar_da (settings related to radar options)
radar_non_precip_opt 0 0 (default): no null-echo assimilation
1: KNU null-echo scheme
radar_non_precip_rf -999.99 Reflectivity flag value (dBz) in observation file in-
dicating non-precipitation echoes
radar_non_precip_rh_w 95 RH (%) with respect to water for non-precip re-
trieved Q_vapor (rqv)
radar_non_precip_rh_i 85 RH (%) with respect to water for non-precip rqv
cloudbase_calc_opt 1 Option for calculating cloud-base height: below this
height retrieved humidity will not be assimilated for
the use_radar_rqv option