Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Confirmed.

...


 

Section


Column


Info

OpenIFS includes a number of idealised configurations. In this article we explain how to:

  • setup and run a shallow-water model
  • set idealized (e.g. Rossby-Haurwitz wave) or real single level field.
  • enable semi-Lagrangian or Euler timestepping
  • create the initial fields

Configuration

The shallow-water (SW) configuration is one of several that exist in OpenIFS (and IFS). The configuration is set by the variable NCONF in namelist NAMCT0 (see yomct0.F90). The normal 3D primitive equation configuration uses NCONF=1.

For the 2D SW configuration, NCONF=201, with NCONF=202 the vorticity equation model.

The 2D SW model can be initialised in various idealized states or from a single level real field. This initialisation is controlled by another variable, N2DINI in the namelist NAMCT0.

As these idealized configurations are primarily research tools, they may vary from one major model release to another and not all options found in the code are guaranteed to work.

N2DINI = 1 in NAMCT0 will initialise the Rossby-Haurwitz wave case (Williamson et al, J. Comput. Phys., 1992).
N2DINI = 3 in NAMCT0 will initialise the SW model with real fields read from GRIB.

The reader is invited to look in suspecb.F90 to see what other initialisation options as possible .(N2DINI=42 does not work).

Although there is mention of NCONF=202 (the Vorticity Equation configuration) in the code, this does not work.

Warning
titleWarning: code changes required for OpenIFS 38r1

OpenIFS 38r1 (all versions) require code changes in order to be able to run with N2DINI=3 (initialized with real fields). Please see Code Changes below.



Column

Image Added

Panel
bgColorwhite
titleBGColor#f0f0f0
title
Column

Image Removed

 

Panel
bgColorwhite
titleBGColor#f0f0f0
titleOn this page...
Table of Contents
 
maxLevel
toc
2



Getting data

The SW model still needs the ICMSH (spectral fields) and ICMGG (gridpoint) files to correctly start. In the idealized case, these are read solely to set the model's spectral and gridpoint resolution and the model will overwrite the initial state read from file (see the code in suspecb.F90). 

...

Panel
bgColorwhite
titleBGColor#f0f0f0
titleT255 shallow-water test case

A test for the shallow-water model at spectral horizontal resolution T255 is available from the OpenIFS ftp site to try. Note: Only licensed institutes are provided with the userid/password to access the OpenIFS ftp site.

Code Block
ftp
Code Block
ftp ftp.ecmwf.int
cd case_studies/shallow_water
get t255_swtest.tar.gz

This example comes with initial files, namelist and job script. The namelist is configured to run the semi-Lagrangian advection. A few lines in the job script may need altering for your local setup.

...

Panel
bgColorwhite
titleBGColor#f0f0f0
titleCreating initial fields from existing GRIB files

The GRIB files from an existing experiment can also be used to create initial files for the shallow-water model. In the following example, the initial files from the T21 test case distributed with the OpenIFS tarfile are used.

Code Block
titleExtract starting files from existing experiment
collapsetrue
#  Extract a single level (level 1) for the shallow water model
#  and change the experiment id in the file.

expid="epc8"
newid="sw01"

grib_copy -w level=1,shortName=vo ICMSHepc8INITICMSH${expid}INIT tmp
grib_set -s experimentVersionNumber=epc9"$newid" -w experimentVersionNumber=epc8"$expid" tmp vo.grb

grib_copy -w level=1,shortName=d  ICMSHepc8INITICMSH${expid}INIT tmp
grib_set -s experimentVersionNumber=epc9"$newid" -w experimentVersionNumber=epc8"$expid" tmp d.grb

grib_copy -w shortName=z          ICMSHepc8INIT zICMSH${expid}INIT z.grb

#  Combine the 3 files to form the spectral initial file
cat vo.grb d.grb z.grb  > ICMSHepc9INIT ICMSH${newid}INIT

#  Create gridpoint file (stl1 is used in this example)
grib_copy -w shortName=stl1 ICMGGepc8INITICMGG${expid}INIT gg.grb
grib_set -s experimentVersionNumber=epc9${newid} -w experimentVersionNumber=epc8${expid} gg.grb ICMGGepc9INITICMGG${newid}INIT

For idealized configurations the field in the initial data file is used correctly set the grid. The actual values are overwritten by the model code to set the idealized start. Hence Note that the initial fields themselves are not used with the idealized configurations. The initial files are there to correctly set the grid, hence stl1 is used in this example to get for the initial gridpoint file .

...

because its values will be overwritten and not used to initialize the model fields.


If you have access to the MARS archive at ECMWF then an example of how to retrieve single level fields for use with the SW model is:

Panel
bgColorwhite
titleBGColor#f0f0f0

The following MARS request will retrieve ERA-Interim (T255) vorticity, divergence and geopotential fields together with a gridpoint field that can be used to create the initial ICMSH and ICMGG files in a similar way to the above method.

Change the model level if required.

Code Block
titleRetrieve spectral fields from MARS for shallow-water model
collapsetrue
retrieve,
  class="ei",
  type=an,
  stream=oper,
  date=20100212,
  time=12,
  step=0,
  expver=1,
  param=VOR/D/Z,
  levelist=1,
  levtype=ml,
  target="sh_ml"


Code Block
titleRetrieve gridpoint field from MARS for shallow-water model
collapsetrue
 retrieve,
  class="ei",
  type=an,
  stream=oper,
  date=20091227,
  time=12,
  step=0,
  expver=1,
  param=139,
  levelist=off,
  levtype=sfc,
  target="sfc_gg"

and then set the appropriate ICMSH and ICMGG file names and experiment number as shown in the previous example.

...

It is extremely important to correctly set the NAMELIST to configure the shallow-water model.

Two examples are given here, one for semi-Lagrangian advection, the other for Euler advection. Euler advection must use a regular gaussian grid. It will not work with a reduced grid. The user is free to alter some parameters such as the timestep, filtering etc.

...

Code Block
titlesemi-Lagrangian advection namelist (43r3)
collapsetrue
!  Shallow-water model with semi-Lagrangian
&NAMDYN
 HDIRVOR=1.e15, advection.
!  The variables below must be set in order to correctly configure
! horizontal diffusion parameters
 HDIRDIV=1.e15,        ! see code for further description
 HDIRSPthe shallow-water model.
!  Other variables (if present) can be left as-is.

For namelist : NAMDYN
 HDIRVOR=1.e15,
 LHDIFFM=true,
 NDIFFACT=6,
 TSTEP=1800.0,        ! horizontal diffusion parameters
 HDIRDIV=1.e15,        ! see code for !further model timestep (resolution dependent)description
 HDIRSP=1.e15,
 LHDIFFM=true,
 NDIFFACT=6,
 LSETTLS=true,         ! ensure SL scheme is enabled
 LSETTLST=true,
 SITR=350.,            ! reference temperature
 REFGEO=78452.0,       ! reference geopotential for SWshallow-water model

 /
&For namelist: NAMCT0
 LRFRICNFPOS=false0,         ! turn of Rayleigh friction
 LFPOS=false,          ! disable fullpos post-processing
 N2DINI=1,             ! 2D initialisation switch
 NCONF=201,            ! select shallow-water configuration
 LTWOTL=true,          ! enable two-time level SL scheme
 LSLAGLSLPHY=truefalse,         ! turn !off enableSl SLphysics schemeoption
 LSLPHYLSPRT=false,          ! turn off Sl physics option
 LSPRT=false,          ! turn off 'virtual temperature' as spectral variable
 LFRHISNFRHIS=10,            ! frequency of results output
 /
&NAEPHY
 LEPHYSNUNDEFLD=false0,            ! turnmake offsure ECMWFuninitialised Physicsvariables packageare (master switch)
 LERADI=false,    all set to zero

For namelist: NAMARG
 NCONF=201,            ! turnselect off radiation scheme
/
&NAMDYNA
 LGRADSP=.false.shallow-water configuration
 LSLAG=true,        ! disable de-aliasing the! pressureenable gradientSL term
/
&NAMDIM
  NUNDEFLD=scheme
 UTSTEP=1800.0,         ! model timestep ! make sure uninitialised variables are all set to zero
/
Code Block
titleEuler advection namelist
collapsetrue
!  Shallow-water model with Euler
&NAMDYN
 TSTEP=300.0, (resolution dependent)

For namelist: NAMPAR0
 NPROC=1,              ! reduceonly timestepuse for1 EulerMPI stepping
 REPS1=0.01,  process in 2-D.
 NPRGPEW=1,              ! turnrequired onfor Asselin time2-filteringD coefficient
 REPS2=0.01,
 LHDIFFM=.false.configurations

For namelist: NAEPHY
 LEPHYS=false,           ! turn off horizontalECMWF diffusionPhysics onpackage /(master offswitch)
 LSETTLSLERADI=.false.,           ! extrapolationsturn inoff SLradiation scheme
 LSETTLST
For namelist: NAMDYNA
 LGRADSP=.false.,          ! ditto
/
&NAMCT0
 NCONF=201,     disable de-aliasing the pressure gradient term
 LRFRIC=false,            ! modelturn configuration:off Rayleigh friction


Code Block
titlesemi-Lagrangian advection namelist (40r1)
collapsetrue
!  Shallow-water model with semi-Lagrangian advection.
!  The variables below must be set in order to correctly configure
!  the shallow-water model.
!  Other variables (if present) can be left as-is.

For namelist : NAMDYN
 HDIRVOR=1.e15201 = shallow-water (see yomct0.F90)
 LSLAG=.false.,             ! turn off semi-lagrangian scheme
 LTWOTL=.false.,            ! disable two-time-level SL scheme.
 LRFRIC=.false.,            ! turnhorizontal offdiffusion Rayleigh frictionparameters
 LSLPHYHDIRDIV=1.false.e15,        ! see code for !further turn off split time-step physics
 LVERTFE=.false.,  description
 HDIRSP=1.e15,
 LHDIFFM=true,
 NDIFFACT=6,
 TSTEP=1800.0,         ! turnmodel offtimestep vertical finite element scheme(resolution dependent)
 N2DINILSETTLS=1true,         ! ensure SL scheme is enabled
 LSETTLST=true,
 SITR=350.,  ! initialise  1 =   Haurwitz wave, 2 =! realreference fieldstemperature
 LSPRTREFGEO=78452.false.0,       ! reference geopotential for SW  ! if T temperature is 'virtual temperature'
 LFPOSmodel

For namelist: NAMCT0
 LRFRIC=false,         ! turn of Rayleigh friction
 LFPOS=false, ! turn off fullpos diagnostics, does not work with SW
 N3DINI=0  ! disable fullpos post-processing
 N2DINI=1,             ! 2D initialisation switch
 NCONF=201,     ! no 3D initialisation
 NSTOP=600,   ! select shallow-water configuration
 LTWOTL=true,          ! no. of steps to run
 NFRHIS=10enable two-time level SL scheme
 LSLAG=true,           ! enable     ! frequency of results output
/
&NAEPHY
 LEPHYSSL scheme
 LSLPHY=false,           ! turn off ECMWFSl Physics package (master switch)physics option
 LERADILSPRT=false,           ! turn off radiation scheme
/
&NAMDYNA
 LGRADSP=.false., 'virtual temperature' as spectral variable
 NFRHIS=10,          ! disable de-aliasing! thefrequency pressureof gradientresults termoutput
/
&NAMDIM
For namelist: NAEPHY
  NUNDEFLDLEPHYS=0,false,           ! turn off ECMWF Physics package (master  ! make sure uninitialised variables are all set to zero
/

 

Gotchas

There are a number of issues that can cause the model to fail. Please make sure:

Info
titleGRIB_GRIBEX_MODE_ON

 The model will fail unless the environment variable:

export GRIB_GRIBEX_MODE_ON=1

is set in the job script. This is because the shallow-water code uses a different set of subroutines for output and does not go through the usual code path for 3D forecasts (if NCONF=1).

Otherwise the model will crash at the first output attempt. Users will usually see a failure from the grib_api library (typically grib_set_real8_array).

Info
titleMake sure FULLPOS is off

 Related to the above, the shallow-water model does not use the FULLPOS part of the model for output (namelist NAMFPC) normally used when NCONF=1 (3D primitive equation model).

Make sure FULLPOS is off by setting:

Code Block
&NAMCT0
   LFPOS=false,

in the fort.4 namelist file.

Info
titleUndefined fields initialized to zero

 Make sure that all variables in the model are initialized to zero. The SW model can output fields that are not used.

To do this set the namelist variable:

Code Block
&NAMDIM
  NUNDEFLD=0,

Plotting

The shallow-water model outputs fields only in spectral space, only ICMSH output files are generated. To plot the fields they will first need converting to gridpoint form.

The figure at the top of this page was generated using 'Metview'. The 'GRIB Filter' icon was used:

Code Block
titleMetview GRIB filter icon example for plotting spectral data
READ,
    DATA       = 'ICMSHepc9+000594',
    INTERPOLATION = LINEAR FIT,
    GRID       = 5/5,
    GAUSSIAN   = REGULAR

...

switch)
 LERADI=false,           ! turn off radiation scheme

For namelist: NAMDYNA
 LGRADSP=.false.,        ! disable de-aliasing the pressure gradient term

For namelist: NAMDIM
  NUNDEFLD=0,            ! make sure uninitialised variables are all set to zero


Code Block
titleEuler advection namelist
collapsetrue
!  Shallow-water model with Euler advection.
!  The variables below must be set in order to correctly configure
!  the shallow-water model.
!  Other variables (if present) can be left as-is.

For namelist: NAMDYN
 TSTEP=300.0,               ! reduce timestep for Euler stepping
 REPS1=0.01,                ! turn on Asselin time-filtering coefficient
 REPS2=0.01,
 LHDIFFM=.false.,           !  horizontal diffusion on / off
 LSETTLS=.false.,           ! extrapolations in SL scheme
 LSETTLST=.false.,          ! ditto

For namelist: NAMCT0
 NCONF=201,                 ! model configuration: 201 = shallow-water (see yomct0.F90)
 LSLAG=.false.,             ! turn off semi-lagrangian scheme
 LTWOTL=.false.,            ! disable two-time-level SL scheme.
 LRFRIC=.false.,            ! turn off Rayleigh friction
 LSLPHY=.false.,            ! turn off split time-step physics
 LVERTFE=.false.,           ! turn off vertical finite element scheme
 N2DINI=1,                  ! initialise  1 = Haurwitz wave, 2 = real fields
 LSPRT=.false.,             ! if T temperature is 'virtual temperature'
 LFPOS=false,               ! turn off fullpos diagnostics, does not work with SW
 N3DINI=0,                  ! no 3D initialisation
 NSTOP=600,                 ! no. of steps to run
 NFRHIS=10,                 ! frequency of results output

For namelist: NAEPHY
 LEPHYS=false,           ! turn off ECMWF Physics package (master switch)
 LERADI=false,           ! turn off radiation scheme

For namelist: NAMDYNA
 LGRADSP=.false.,        ! disable de-aliasing the pressure gradient term

For namelist: NAMDIM
  NUNDEFLD=0,            ! make sure uninitialised variables are all set to zero


Also, add a blank namelist to fort.4 for the idealized cases. Some configurations selected using N2DINI will expect to find a namelist NAMSWE.

Code Block
&NAMSWE
/


Gotchas

There are a number of issues that can cause the model to fail. Please make sure:

Info
titleGRIB_GRIBEX_MODE_ON

 The model will fail unless the environment variable:

export GRIB_GRIBEX_MODE_ON=1

is set in the job script. This is because the shallow-water code uses a different set of subroutines for output and does not go through the usual code path for 3D forecasts (if NCONF=1).

Otherwise the model will crash at the first output attempt. Users will usually see a failure from the grib_api library (typically grib_set_real8_array).


Info
titleMake sure FULLPOS is off

 Related to the above, the shallow-water model does not use the FULLPOS part of the model for output (namelist NAMFPC) normally used when NCONF=1 (3D primitive equation model).

Make sure FULLPOS is off by setting:

Code Block
&NAMCT0
   LFPOS=false,

in the fort.4 namelist file.


Info
titleUndefined fields initialized to zero

 Make sure that all variables in the model are initialized to zero. The SW model can output fields that are not used.

To do this set the namelist variable:

Code Block
&NAMDIM
  NUNDEFLD=0,


Plotting

The shallow-water model outputs fields only in spectral space, only ICMSH output files are generated. To plot the fields they will first need converting to gridpoint form.

The figure at the top of this page was generated using 'Metview'. The 'GRIB Filter' icon was used:

Code Block
titleMetview GRIB filter icon example for plotting spectral data
READ,
    DATA       = 'ICMSHepc9+000594',
    INTERPOLATION = LINEAR FIT,
    GRID       = 5/5,
    GAUSSIAN   = REGULAR

For more information about Metview please see Using Metview with OpenIFS or contact openifs-support@ecmwf.int.

Anchor
codechanges
codechanges
Code changes

Warning

if running OpenIFS 38r1 (all versions), code changes are required before using the shallow water option initialized with real fields (N2DINI=3 & NCONF=201).

Changes are required because the shallow-water code uses older code for reading GRIB data that was omitted from OpenIFS before the shallow-water option was made available.

Required steps to enable shallow-water code option

  • Download the OpenIFS 38r1 shallow-water replacement source tarball: openifs38r1_sw_newsrc.tgz
    (this file is also available on the OpenIFS ftp site)
  • Make a backup copy of the OpenIFS source code  in the directory where the OpenIFS model files were unpacked:

    Code Block
    cp -r src src.orig


  • Delete some files that will be replaced:

    Code Block
    rm src/openifs/dummy/decops2.f90
    rm src/openifs/dummy/gribex.f90
    rm src/openifs/emos/pbio/emosnum.F
    rm src/openifs/emos/pbio/fortint.h
    rm -r src/openifs/emos/gribex		# delete entire 'gribex' director


  • Unpack the tarfile downloaded above. This will create a new directory 'src/openifs/emos/gribex'.
    Make sure the tarfile is in the top level directory that contains 'src':

    Code Block
    # Make sure openifs38r1_sw_newsrc.tgz is in the directory that contains 'src.
    tar xzvf openifs38r1_sw_newsrc.tgz

    Verify that 'src/openifs/emos/gribex' exists and contains source code.

  • To compile the code if using GNU/gfortran, it may be necessary to enable the use of cray pointers.
    Edit 'make/oifs.cfg' and change:

    Code Block
    oifs.prop{fc}       = $OIFS_FC

    to:

    Code Block
    oifs.prop{fc}       = $OIFS_FC -fcray-pointer


Code notes

Other switches related to the shallow-water model setup are used internally: LR2D & LRSHW.

...

In the routine suspecb, you can choose between idealized cases or read one level of a grib file (N2DINI is the key for this choice). suspecb is called at cnt3 level - the first part of the GP computations are done from a routine called CPG2 which is a very simplified version of the 3D GP computation, the other (lagged, mostly SL computation) are done in CPG2_LAG Both cpg2 and cpg2_lag are called by the driver routine gp_model which is also the driver routine of the 3D GP computation. - the spectral computation are done under spc with the 2D configurations calling spc2.


Info

with thanks to Nils Wedi and Sylvie Malardel, ECMWF.


Excerpt Include
Credits
Credits
nopaneltrue