ClimaLSM folder structure
ClimaLSM home directory has 5 main folders:
- docs: contains files to generate the documentation website.
- experiments: contains simple runs of
ClimaLSM
models. - parameters: contains a file to retrieve constants such as avogadro's number, the speed of light, etc.
- src: contains the code of
ClimaLSM
models. - test: contains unit tests, which are meant to ensure small pieces of ClimaLSM source code work as intended before merging pull requests.
and 3 GitHub actions folders. GitHub actions are .yml
files, which are bash scripts that runs on a remote computer on each git push.
- .buildkite: contains a script building outputs such as figures from experiments and tests folders. These runs are carried out as part of CI and must run without error in order to merge a PR.
- .dev: contains useful tools for developers, such as a format checker for Julia (which is run as part of CI and must pass before a PR can be merged into main).
- .github: contains various scripts, for example, this documentation website is built each time a change is push to
ClimaLSM
.
as well as 5 files:
- .gitignore: commonly used git file, contains files, files type, and folders that should be ignored by git.
- LICENSE: License file of
ClimaLSM
, you can read it to learn about legal practice regarding use ofClimaLSM
open source code. - Project.toml: The Julia programming language requires a
Project.toml
file to create an environment, which specify dependencies of a project as well as its version, name, authors and a unique identifier number (uuid). Every Julia registered package has aProject.toml
file. - README.md: This markdown file contains the info that you can read on ClimaLSM GitHub web page
- bors.toml: This file ensure unit tests and other continuous integration requirements are met before merging a pull request to
ClimaLSM
main branch.
/docs folder
Julia packages are recommended to have a \docs
folder that builds a standardised documentation following the official documentation generator for Julia: Documenter.jl.
The folder /docs contains:
- a
/src
folder: It is recommended to put your markdown pages inside this folder. Each markdown file (.md extension text file) is a page accessible through the menu of the documentation. For example,docs/src/Contributing.md
contains the text you can read on the documentation "contribution guide" menu. The path to this .md file and the name of the menu is set in thedocs/make.jl
file. - a
make.jl
file: This Julia file contains your documentation website structure. Running this file will build your website pages, you can run it locally, but it is commonly built remotely via .github/workflows/docs.yml to generate the github static page hosted on the gh-pages branch.
Note: the documentation can have submenu. For example, APIs
have submenu ClimaLSM
which has many submenu... This structure is built in our current framework via a file docs/list_of_apis.jl
in that example, which is then included in docs/make.jl
.
/experiments folder
The experiments
folder contains scripts to run ClimaLSM models. It contains a folder for integrated
models and a folder for standalone
models. It is meant to provide users with simple examples of ClimaLSM runs. The files contains meteorological inputs (such as precipitation), values for every parameters, and the domains and timestepper are specified.
For example, /experiments/LSM/ozark/
contains:
- ozark_domain.jl: Describes the soil domain (depth, number of layer), and the canopy (number and height of stems and leaves).
- ozarkmetdrivers_FLUXNET.jl: This files load meteorological input data from the ozark FLUXNET file, and does additional things such as spline interpolation of these drivers.
- ozark_parameters.jl: In this file, parameters values are defined.
- ozark_simulation.jl: In this file, initial and final time are set, as well as time resolution and time stepper algorithm.
- ozark.jl: running this script will include all the above scripts, and run ClimaLSM for the single-site ozark. It will produce output in a text file as well as some figures comparing data and simulation.
/src folder
The /src
folder contains the source code of ClimaLSM
models. It contains 3 folders:
- sharedutilities: This is a core folder that defines functions and data structures used across all modules and models types of
ClimaLSM
. For example, `sharedutilities/models.jldefines and export the function
makeupdateauxwhich will be used to create a function which updates the auxiliary parameters, stored in the vector
p,
sharedutilities/boundaryconditions.jl` defines functions for setting boundary condition for PDE domains, etc. - standalone: This folder contains standalone models, which are submodels that can be run independently of each other. This is an important aspect of
ClimaLSM
code design: to maximise modularity, sub-models can be run alone, and many different methods of the same sub-model can be defined via Julia multiple-disptach. The standalone folder is independent from the integrated folder. - integrated: This folder contains integrated models. It assembles standalone models together, as one would assemble pieces of a puzzle. Thanks to the modularity of
ClimaLSM
design, many configuration of LSM can be assembled in integrated models. The same functions (update_aux!
,exp_tendency!
, etc.) can be used for standalone and integrated models, and an can be stepped in the same way.
As well as one file:
- ClimaLSM.jl: This file is the main Julia module of
ClimaLSM.jl
repository. It contains all functions defined in/src
in a nested way, for exampleClimaLSM.X
,ClimaLSM.Soil.X
, 'ClimaLSM.Canopy.X, etc. When a Julia user install and uses ClimaLSM via
]add ClimaLSM, using ClimaLSM`, they are loading those functions, and are ready to use ClimaLSM codebase.