Contents:
This page contains a guide for building and using OpenIFS 48r1 at model version 48R1.1.
We describe how to build the model and carry out a few basic tests, how to run an example forecast experiment, for which initial experiment data is made available, and how to visualise the model output by creating plots.
Worked Example:
We explain the model installation and the process of running of a forecast experiment on the ECMWF Atos Sequana XH2000 HPC facility (hpc2020).
- All data files and configuration scripts that are required for the worked example experiment described in this guide can be found on the ECMWF file system here:
/perm/openifs/oifs_data/48r1/example
- For users without access to the ECMWF HPC facility we provide URLs for downloading all required data files and configuration scripts.
- The model will be installed into
$HOME/openifs-48r1.1/
- The example forecast experiment will be set up in directory
$OIFS_EXPT/ab2a/
It is important to note that the installation process on hpc2020 will not directly translate to alternative systems. To address this we present details about a docker install in the last section of this guide.
Access requirements
OpenIFS is licensed software and using the model requires your affiliation with an institute that has signed the ECMWF OpenIFS software licence agreement.
In order to access the model sources and other required data packages, you need to have a personal ECMWF account which you can create on the ECMWF web site or by clicking here.
If you are a new model user you should in the first instance contact OpenIFS support (by emailing openifs-support@ecmwf.int) requesting access to OpenIFS by providing the following information: your full name, your affiliation and related institutional email address, and your ECMWF account user name. OpenIFS staff will then activate OpenIFS user policies for your personal ECMWF account. In some cases we may need to request additional verification of your affiliation with your licensed institute prior to giving you access.
Extract the OpenIFS package
Create your local installation of OpenIFS 48R1.1 by downloading and extracting the tarball containing the model source package.
The tarball can be downloaded from this web site: https://sites.ecmwf.int/openifs/openifs-data/src/48r1/openifs-48r1.tar.gz. Please note that access to this web site is restricted to registered OpenIFS users, i.e. your personal ECMWF account must have been added to the OpenIFS user policy.
In the example below we assume that the OpenIFS model shall be installed in the user's HOME
directory, and that the wget
utility is available for convenient download:
cd $HOME wget https://sites.ecmwf.int/openifs/openifs-data/src/48r1/openifs-48r1.tar.gz tar -xvzf openifs-48r1.tar.gz
- You will need approximately 4 GB of disk space for the model sources, the bundle packages, and the built model binaries.
- Please note that in future access to the OpenIFS source package will be provided through a git repository. Therefore the provision of the package as a tarball is only a temporary arrangement.
Set up the platform configuration file
The OpenIFS model requires a number of Linux environment variables to be set for both installation and runs. These are referred to as global environment variables.
The most important environment variable is OIFS_HOME
, which is required by all scripts used by the model.
OIFS_HOME
describes the location of the OpenIFS model installation and is general the path where the git repository was extracted. For example, if you clone the repository into your $HOME directory then you should set:
export OIFS_HOME=$HOME/openifs-48r1.1/
The other model environment variables are
OIFS_CYCLE
- describes the model cycle (e.g. 48r1) for which this configuration file can be used - this should not be editedOIFS_EXPT
- path to the location of the openifs experiments. Setting this is a convenience for the OpenIFS 3D model but is a requirement for the SCM experimentsOIFS_ARCH
- if available on for a system, this variable describes the location of the arch directory, which provides specific information about the system and compiler, e.g.$OIFS_HOME/arch/ecmwf/hpc2020/gnu
- Such a directory is not always required, i.e., if a system has all the appropriate libraries installed. If this is the case
OIFS_ARCH
can be set to an empty string, i.e.,OIFS_ARCH=""
- Such a directory is not always required, i.e., if a system has all the appropriate libraries installed. If this is the case
OIFS_DATA_DIR
- describes the location of climatological input files that are required to run OpenIFS. These have been installed on the ECMWF hpc2020 in a central and accessible location under/perm/openifs/oifs_data
and the information is organised by model cycle.
If you do not have access to the ECMWF hpc2020 file system, or if you wish to install the climatological input files in a local directory of your choice, then you can download the required data from this site: https://sites.ecmwf.int/openifs/openifs-data/ifsdata/48r1/
As a minimum you will require the packages ifsdata_rtables_48r1.tgz
, ifsdata_climatology_48r1.tgz
, and the files required for your selected horizontal grid resolution, which in the case of our example is ifsdata_48r1_climate.v020_255.tgz
.
Download and extract these files to your chosen location, the filepath of which should then be set to variable OIFS_DATA_DIR
.
OIFS_EXEC
- describes the location and file name for the OpenIFS 3D executable, e.g.$OIFS_HOME/build/bin/ifsMASTER.DP
, which is a double-precision executable for the 3D model
All the global environment variables described above, as well as some other variables that are dependent on the above, are defined in the Platform configuration file, which needs to be modified for your local OpenIFS installation.
- This file can be located anywhere on your file system, however the recommended default location
is $OIFS_HOME
. - We provide
$OIFS_HOME/oifs-config.edit_me.sh
, which is a commented template of this configuration file. - You should edit this file and update the path set in variable
OIFS_HOME
with your installation's path.
Once edited the platform configuration file is loaded using the following command:
source /path/to/file/location/oifs-config.edit_me.sh # using our installation example: # source $HOME/openifs-48r1.1/oifs-config.edit_me.sh
We recommend to include this command in your Linux shell startup configuration (e.g. in .bashrc).
The above command should also be include in any batch job scripts that are intended to run OpenIFS (described in Section 3)
$OIFS_HOME/oifs-config.edit_me.sh
also contains a environment variables that relate to the SCM. These are discussed in <add link to SCM documentation>
Build OpenIFS
In the next step the model binary executable (and other helper programs) will be built.
OpenIFS build system
In contrast to earlier model versions, the building of OpenIFS 48r1 is no longer based on the FCM configuration manager; instead, the build system for OpenIFS is now based on the same ecbuild / CMake system used for the ECMWF IFS model.
Similar to the IFS, OpenIFS 48r1 also employs a software bundle which, as part of the build process, automatically finds, downloads and installs many of the required software packages, e.g., ecbuild, ecCodes, metkit, etc. Hence, a separate installation of these libraries is no longer required as they have now become part of the OpenIFS distribution.
Starting the build process
The $OIFS_HOME/scripts/build_test/openifs-test.sh
script can be used to build the model and run initial tests.
- The script requires key environment variables, such as $OIFS_HOME, to be assigned. Make sure you have sourced the platform configuration script first.
- The usage of the script is shown with the command:
openifs-test.sh -h
Run the build process and the tests using the following commands (assumes the platform configuration file has been sourced) :
cd $OIFS_HOME $OIFS_TEST/openifs-test.sh -cbt
where
$OIFS_TEST
is defined in the platform configuration file (oifs-config.edit_me.sh) as $OIFS_HOME/scripts/build_test
and the command line options are
-c
creates source
directory in $OIFS_HOME
, which is used to bring all the sources, e.g. ifs-source, ifs-test and any packages in the bundle (ecbuild, eccodes etc.), together in preparation for the build
-b
builds the source. This step creates the directory build
in $OIFS_HOME
, which is used to build and store
- the OpenIFS double and single precision master executables (ifsMASTER.DP and ifsMASTER.SP, respectively) , which are used to run 3-D OpenIFS. The executables are located in
$OIFS_HOME/build/bin
.- The location and name of the executable for OpenIFS is defined in the platform configuration file (oifs-config.edit_me.sh) as
$OIFS_EXEC
.
- The location and name of the executable for OpenIFS is defined in the platform configuration file (oifs-config.edit_me.sh) as
- the double and single precision Single Column Model (SCM) executables (MASTER_scm.DP and MASTER_scm.SP, respectively), which are used to run the SCM derived from OpenIFS. The executables are located in
$OIFS_HOME/build/bin
.- The location and name of the executable for the SCM is defined in the platform configuration file (oifs-config.edit_me.sh) as
$SCM_EXEC
.
- The location and name of the executable for the SCM is defined in the platform configuration file (oifs-config.edit_me.sh) as
-t
will run the ifs-test t21 tests, which comprise of
- 21 3-D OpenIFS forecast-only tests with and without chemistry
- 1 SCM test (based on TWP-ICE)
In addition to the command line options defined above (-cbt
) , openifs-test.sh invokes some default ecbuild options and allows a user to add ecbuild options from command line using the --
notation, e.g., $OIFS_TEST/openifs-test.sh -cbt --without-single-precision.
Openifs-test - build options describes some of these options.
If everything has worked correctly with $OIFS_TEST/openifs-test.sh -cbt
, then all tests should have passed and the script returns the following
[INFO]: Good news - ctest has passed openifs is ready for experiment and SCM testing ---------------------------------------------------------------- END ifstest on OpenIFS build
100% pass with $OIFS_TEST/openifs-test.sh -cbt
shows that the low resolution (t21) ifs-test cases can run to completion on the chosen system. These tests do not check bit comparibility with known good output. If this is a requirement, e.g., if a user makes a code change and needs to test whether the code has led to unexpected behaviour in the code, then Openifs - bit identical testing page describes how to set this up with openifs-test.
Next Steps:
This page has shown you how to download, extract, build and test the OpenIFS 3D global model on your local computing system. The next step will be to carry out a first global forecast experiment for which we have prepared an example case study experiment. To do this please continue on the page Setting up and running a forecast experiment.