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.
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 |
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 git@github.com: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 git@github.com:GEOS-ESM/GEOSldas.git
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.
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
.
The steps detailed below are essentially those performed by parallel_build.csh
in Step 3 above. Either method should yield identical builds.
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.
On tcsh:
source @env/g5_modules
or on bash:
source @env/g5_modules.sh
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.
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.
make -j6 install
If you are at NCCS, you should run make -j6 install
on an interactive compute node.
Please check out our contributing guidelines.
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
).