Versions Compared

Key

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

Warning

This page is out of date and will shortly be taken offline. The description is no longer applicable since the move to the new HPC system in Bologna.

Info

Note that you need:

  • an account on the ECMWF 'ecgate' system
  • access to the ECMWF HPCF system

granted by your member state Meteorological Service in order to be able to run thisthe steps below.

Initial setup

There are a number of required steps before the extraction can be done. These are steps that only need to be done once.

Access to 'ifs' group

You need to be in the 'ifs' unix group in order to run the scripts to generate the SCM forcing.

To check you have access, login to ecgate, and type:

 

Code Block
groups

 

If you do not see 'ifs' listed in the output, please contact ECMWF user support Service Desk (advisory@ecmwfservicedesk@ecmwf.int) and ask to be added, explaining why.

ssh keys

Make sure you have set up your ssh_keys so that you don't need to use password to go from ecgate to cca and from cca to ecgate: 

Code Block
ssh-keygen (no passphrase)
ssh-copy-id -i ~/.ssh/id_rsa.pub name_of_remote_host
 

Install workflow suite

The forcing data is created using a 'workflow' developed at ECMWF.

A workflow is a defined order in which a number of separate scripts are run. The workflow software used at ECMWF is called 'sms'. SMS is a 'workflow manager' that a user interacts with to control the executation of scripts (or 'tasks') in the workflow.

The workflow 'suite', the sequence of the scripts that will be run, is defined in a .def file.

The following steps explain how to install and customize this workflow and it's scripts for your use.

  1. Download the workflow suite:sms.tar.gz  (last updated Jan/2018)  and unpack it to your ecgate user home directory:

    Code Block
    cd $HOME
    mkdir sms
    tar zxvf sms.tar.gz


  2. Choose either ECMWF operational analysis (OPER-cray.def) or the ERA-Interim analyses (ERAI-cray.def) and copy to 'cray.def'.

    Code Block
    titlee.g. for operational analyses
    cp OPER-cray.def cray.def


  3. Edit cray.def to correct it for your user details:

    i)  replace all '/home/ms/se/usr' by your actual home directory path where “usr” 'usr' is your username (e.g. /home/ms/se/batman)
    ii) replace "'acnt" ' by your billing units account.
        To find your account, type the command:

    Code Block
    account -sl your_user_name

         where your_user_name is replaced by your username (e.g. batman).
    iii) replace 'usr' in OWNER and USER to your username.
    iv) set LOGDIR to a directory on the HPC (where this job runs) where you want to store the log files.

4. Edit
  1. In the directory, 'sms/cray', edit the files:  sms/cray/getdata_scm.sms

and
  1.   and  sms/cray/getmars_scm.sms

files to have paths accessible
by your user (both files setting should be consistent, copy either from ERA-I or from OPERA
depending on choice of data, copy to sms/cray to be used by extraction routine):export
  1.   to set the unix directory paths to your user account:

    Code Block
    titleChange these lines in both files:
    export SCRATCH=/ws/scratch/rd/rdx     # only useful for $SCMDATA definition
  1. 
    export SCMDATA=$SCRATCH/pafv/data     # will define the place your resulting profiles are stored
5. Edit
  1. 
    TMPDIR=/scratch/rd/pafv/scm_cray      # working directory on cca
  1. It is important that these directories are set the same in both getdata_scm.sms and getmars_scm.sms.

  2. In the directory sms/include_cray, you need copy the script files from either 'OPER' if you want to use operational analyses, or 'ERAI-0_12' if you want to use ERA-Interim.
    Copy the files into the sms/include_cray directory:

    Code Block
    titlee.g. for operational analyses
    cd sms/include_cray
    cd OPER					# we will use the ECMWF operational analysis to create the forcing files
    cp getini1c* ..         # copy the files to sms/include_cray


  3. Edit the files:

  1. sms/include_cray/getini1c_setup_cycle_validation_SCM_FC_cray*

replace “usr” in
  1. ,  and replace the text 'usr' in "EXPVER=usr" to your real username.

7.
  1. Invoke the sms server to find your 'sms identifier', which is the number in the command output after the PROGNUM parameter, needed to log in to ecgate and set up server.

-->
  1. Code Block
    /usr/local/apps/sms/current/bin/sms_start
8.
  1. This command starts up your personal workflow manager on ecgate.

  2. Set up server in the xcdp viewer

--> xcdp &

Add your server by
  1. . This is a visual view of the workflow and the tasks as they execute.

    Code Block
    xcdp &  # run the workflow viewer 'xcdp' in the background


  2. Once the xcdp window appears, add your server to the list of servers known to xcdp by the menus: Edit → Preferences → Servers

Choose ”Name”, state “Host server”
  1. Add entry to 'Name' (e.g. myserver), add entry to 'Host' (e.g. ecgate) and set PROGNUM value (step 7)

as “Number”Steps to set up an experiment1.
  1. for the 'Number' field.
    After configuring the server, select it's name from the Servers menu. You may need to click the red circle arrow top right, to load the suite.

Set up the job to retrieve forcing

  1. Define the starting day(s) of your experiment(s) by adapting the YMD variable in sms/cray.def

:
  1. . The current setting uses the starting date of 1st of April 2016:

    Code Block
    define rcmd { repeat string YMD 20160401 }

    If you want to do multiple experiments simply add other dates in the following way:

    Code Block
    define rcmd { repeat string YMD 20160401 20160402 20160403 }
2.

  1. Edit following two files:

    Code Block
    sms/include_cray/getini1c_setup_cycle_validation_SCM_FC_cray
  1. 
    sms/include_cray/getini1c_setup_cycle_validation_SCM_FC_cray.dataonly

    between the lines labelled as "definition area" to reflect your

desirable setting for points.Note that when you ask for
  1. desired points.

  2. If using only one time step keep the forward slash '/' afterwards for correct use of sed command.

    Info

    If you request fields at 1 hour frequency, some fields won't be available from

Mars. So
  1. the MARS archive. It is better to

stick with
  1. use a 3 hour interval for the operational forecast.

If using only one time step keep slash afterwards for correct call of sed command.

Note that
  1. Note  the start time has to be either 00 or 12

(
  1. for the operational forecast

). So while you can have multiple dates at one go where
  1. archive. While multiple dates can be specified, there is no way to have multiple starting time in the similar way.

    getini1c_mars_run_validation_SCM_FC has information on which variables are read from MARS archive

Steps to run an experiment:1. Invoke

Run the job to retrieve forcing

  1. Make sure the sms server

.(Most likely it
  1. is already running

. But then the invocation will just do nothing.):-->
  1. by using the following command. If it is, this command will do nothing:

    Code Block
    /usr/local/apps/sms/current/bin/sms_start
2.

  1. Load your suite

under
  1. into the SMS server and start running it:

    Code Block
-->
  1. cd
~/sms

--> cdp

> set SMS_PROG your_sms_identifier
  1.  ~/sms                               #  change to the directory with the SMS scripts
    cdp                                    #  start the workflow manager 'cdp'
    CDP> set SMS_PROG your_sms_identifier  #  the command prompt will change to 'CDF'; set the SMS_PROG value

    where your_sms_identifier is given in the the output after invoking the sms server, look for variable called PROGNUM.

    Code Block
>
  1. login -t 60 ecgate your_user_name
314159password
  1.  314159    # password 314159, can also be 1 instead of 314159


    Info
if
  1. If errors

here:
  1. occur, likely need to invoke sms server


  1. Run (or 'play') the workflow suite:

    Code Block
    CDP>  play -r /cray<cray.def		# load the workflow suite into the workflow manager
    CDP>  begin /cray<cray.def          # start running the suite
    CDP>  ctrl-D                        # CTRL-D to quit the CDP workflow manager


  2. To cancel a running application:

    Code Block
    CDP> cancel -y -f 

> play -r /cray<cray.def

> begin /cray<cray.def

> ctrl-D

to cancel a running application put

> /cancel -y -f
  1. /cray

    before entering the play command.

3. Invoke
  1. Start the xcdp viewer, a graphical display of the running tasks:

    Code Block
-->
  1. xcdp &
4. Expand
  1.         # run the viewer in the background


  2. In the viewer, xcdp window, expand the branch of jobs on the host by middle mouse click on the symbol to right. Get further information on the job by right

clicking
  1. mouse button.

Color coding

explanation

for xcdp

:

tasks

Status
titleQueuing

Status
colourGreen
titleRunning

Status
colourYellow
titleCompleted

Status
colourRed
titleAborted

More

grey/light blue: queuing job

green: job is running

yellow: job has successfully completed

red: job was aborted with errors

more information on errors can be found in either getmars_scm.* or getmars_scm.* in folder LOGDIR on cca (cray) depending on which process crashes.

Restart failed tasks

before Before restarting a failed job check via--> qstat -u ('task') check the job is not still running by the command:

Code Block
qstat -u your_user_name

which will list all batch jobs for your user name.

if If the job is still running, if yes, kill it by $ :

Code Block
qdel process_id

where the process_id should be replaced by from the list returned by qstat.

To restart a failed task, select the task, violet: right click and select ”Restart”all 'Restart'. All scripts in tree below will also be restarted and exectuables executables again copied to the Cray (cca) (changes included on ecgate will be activated)however: . However, there is no restart of cray.def file , need to needed. If a date change is required, login to cdp to change the date.

Retrieving data

After all your boxes turns to yellow your task is completed the tasks are completed (shown as yellow in the xcdp window),  your forcing data is retrieved successfully and you should find your results in the directory specified in $SCMDATA.

Download data (more information httpsthe data from the web interface to ecgate, http://softwareecaccess.ecmwf.int/wiki/display/UDOC/File+Transfer)

e.g. http://ecaccess.ecmwf.int

. For instructions see: ECMWF User Docs: File Transfer.

The data can be download from: Browsing → ECscratch files → data → click on symbol to left (page with red arrow) to download.

Adapting extraction to other operational systems

than current one (from 8 March 2016)

The scripts in this workflow are configured for the most recent operational IFS operational since March 2016 (IFS cycle 43r1).

Changes to the following scripts are required for dates prior to this:

change scripts:

Code Block
sms/include_cray/getini1c_setup_cycle_validation_SCM_FC_cray

sms/include_cray/getini1c_setup_cycle_validation_SCM_FC_cray.dataonly

in the way to modify there (for For example, retrieving forcing data from the period June 2013 – March 2016), the operational model was IFS cycle 40r3. Modify the scripts by setting:

Code Block
CYCLE=40r3


dataid2="t1279_2010"


CLIMVERSION=climate.v011


GTYPE=l_2

and substitute therethe script:

Code Block
$TMPDIR/run_parallel /home/rd/nag/bin/getini1c_TCo1279_geostr

by older the script (as used for ERA-I):

Code Block
$TMPDIR/run_parallel /home/rd/nag/bin/getini1c_lowres_geostr


Info

Extracting operational forecasts or analyses further back in time needs different

adaptions

changes to the two include_cray/getini1c_setup_cycle* scripts.

IFS operational updates

DateHorizontal resolution
updates:
Vertical resolution
21 Nov 2000
: T511
Tl511L60
1 Feb 2006
: T799
Tl799L91
26 Jan 2010
: T1279
Tl1279L137
8 March
2916: T2047

Vertical resolution updates:
21 Nov 2000: L60
1 Feb 2006: L91
June 2013: L137

If changing
2016Tco1279L137

Changing horizontal resolution:

Also
  • change ZDELTA with a coarser grid so that the point is found in circle around desired location.
Choose
  • choose large enough but not to large so that point further away is detected.
  • TSTEP is not used in getini1c script, not
as
  • important to set.
If changing

Changing vertical resolution:

In addition to LEVELS
  • change the value of the variable LEVELS.
  • change option
  • -l
137”
  • 137 in getini1c_mars_run_validation_SCM_FC call in include_cray/getini1c_setup_cycle_validation_SCM_FC_cray.dataonly according to new number of levels (default 137).
Extraction

Extracting forcing from ERA-

I:

Interim

use Use the scripts in directory include_cray/ERA-I instead and also ERAI-cray.def.

Data availability

:



00
:
forecast step0, 3, 6, 9, 12
06
:
analysis step0
12
:
forecast step0, 3, 6, 9, 12
18
:
analysis step0


Acknowledgements

The following people contributed to the development and documentation: Filip Váña (ECMWF), Nils Wedi (ECMWF), Paul Dando (ECMWF), Kerstin Hartung (University of Stockholm) and Glenn Carver (ECMWF).


Excerpt Include
Credits
Credits
nopaneltrue




Panel
titleOn this page...

Table of Contents

 

indent

 

 

12px