Skip to content

Repository for the GEOS Land Data Assimilation Fixture

License

Notifications You must be signed in to change notification settings

lbusschaert/GEOSldas

 
 

Repository files navigation

GEOSldas Fixture

This document explains how to build, set up, and run the GEOS land modeling and data assimilation system (GEOSldas) on the most common systems used by GMAO. Additional steps are needed on other systems.

How to Build GEOSldas

Step 1: Load the Build Modules

Load the GEOSenv module provided by the GMAO Software Infrastructure team. It contains the latest git, CMake, and mepo modules and must be loaded in any interactive window that is used to check out and build the model.

module use -a (path)
module load GEOSenv

where (path) depends on the computer and operating system:

System Path
NCCS /discover/swdev/gmao_SIteam/modulefiles-SLES12
NAS /nobackup/gmao_SIteam/modulefiles
GMAO desktops /ford1/share/gmao_SIteam/modulefiles

Step 2: Obtain the Model

For development work, clone the entire repository and use the develop branch as your starting point (equivalent to the UNSTABLE tag in the old CVS repository):

git clone -b develop [email protected]:GEOS-ESM/GEOSldas.git

For science runs, you can also obtain a specific tag or branch only (as opposed to the entire repository), e.g.:

git clone -b v17.9.1 --single-branch [email protected]:GEOS-ESM/GEOSldas.git

Step 3: Build the Model

To build the model in a single step, do the following:

cd ./GEOSldas
parallel_build.csh

from a head node. Doing so will check out all the external repositories of the model (albeit only on the first run, see section on mepo below) and build the model. When done, the resulting model build will be found in build/ and the installation will be found in install/, with setup scripts like ldas_setup in install/bin.

To obtain a build that is suitable for debugging, use parallel_build.csh -debug, which will build in build-Debug/ and install in install-Debug/. There is also an option for aggressive optimization. For details, see GEOSldas Wiki.

See below for how to build the model in multiple steps.


How to Set Up (Configure) and Run GEOSldas

a) Set up the job as follows:

cd (build_path)/GEOSldas/install/bin
source g5_modules                        [for bash or zsh: source g5_modules.[z]sh]
./ldas_setup setup [-v]  (exp_path)  ("exe"_input_filename)  ("bat"_input_filename)

where

Parameter Description
build_path path to build directory
exp_path path of desired experiment directory
"exe"_input_filename filename (with path) of "experiment" inputs
"bat"_input_filename filename (with path) of "batch" (job scheduler) inputs

The three arguments for ldas_setup are positional and must be ordered as indicated above.

The latter two files contain essential information about the experiment setup. Sample files can be generated as follows:

ldas_setup sample --exeinp > YOUR_exeinp.txt
ldas_setup sample --batinp > YOUR_batinp.txt

Edit these sample files following the examples and comments within the sample files.

The ldas_setup script creates a run directory and other directories at: [exp_path]/[exp_name]

Configuration input files will be created at: [exp_path]/[exp_name]/run

For more options and documentation, use any of the following:

ldas_setup        -h
ldas_setup sample -h
ldas_setup setup  -h

b) Configure the experiment output by editing the ./run/HISTORY.rc file as needed.

c) Run the job:

cd [exp_path]/[exp_name]/run/
sbatch lenkf.j

For more information, see the files in ./doc/. Moreover, descriptions of the configuration (resource) parameters are included in the sample "exeinp" and "batinp" files that can be generated using ldas_setup.


Additional Information

How to Build the Model in Multiple Steps

The steps detailed below are essentially those performed by parallel_build.csh in Step 3 above. Either method should yield identical builds.

mepo

The GEOSldas is comprised of a set of sub-repositories. These are managed by a tool called mepo. To clone all the sub-repositories, you can run mepo clone inside the fixture:

cd GEOSldas
mepo init
mepo clone

External sub-repositories are stored in directories pre-faced with @. After parallel_build.csh has run once and created ./@env/, parallel_build.csh skips mepo clone in subsequent runs. This means that the sub-repositories in your sandbox could get out of sync with the GEOSldas repository while you are working on your sandbox, which may result in a difficult-to-understand build error when parallel_build.csh is used. If this happens, try a fresh clone or use mepo commands to update the sub-repositories manually.

Load Compiler, MPI Stack, and Baselibs

On tcsh:

source @env/g5_modules

or on bash:

source @env/g5_modules.sh

Create Build Directory

We currently do not allow in-source builds of GEOSldas. So we must make a directory:

mkdir build

The advantages of this is that you can build both a Debug and Release version with the same clone if desired.

Run CMake

CMake generates the Makefiles needed to build the model.

cd build
cmake .. -DBASEDIR=$BASEDIR/Linux -DCMAKE_Fortran_COMPILER=ifort -DCMAKE_INSTALL_PREFIX=../install

This will install to a directory parallel to your build directory. If you prefer to install elsewhere change the path in:

-DCMAKE_INSTALL_PREFIX=<path>

and CMake will install there.

Build and Install with Make

make -j6 install

If you are at NCCS, you should run make -j6 install on an interactive compute node.

Contributing

Please check out our contributing guidelines.

License

All files are currently licensed under the Apache-2.0 license (LICENSE).

Previously, the code was licensed under the NASA Open Source Agreement, Version 1.3 (LICENSE-NOSA).

About

Repository for the GEOS Land Data Assimilation Fixture

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Fortran 90.6%
  • MATLAB 3.9%
  • Python 3.3%
  • Shell 2.0%
  • CMake 0.2%