Skip to content

GEOS-Chem "Science Codebase" repository. Contains GEOS-Chem science routines, run directory generation scripts, and interface code. This repository is used as a submodule within the GCClassic and GCHP wrappers, as well as in other modeling contexts (external ESMs).

License

Notifications You must be signed in to change notification settings

ltmurray/geos-chem

 
 

Repository files navigation

DOI License

README for the GEOS-Chem science codebase repository

Overview

This repository (https://github.com/geoschem/geos-chem) contains the GEOS-Chem science codebase (aka the GEOS-Chem chemical module). Included in this repository are:

  • The source code for GEOS-Chem science routines;

  • Scripts to create GEOS-Chem run directories;

  • Scripts to run GEOS-Chem tests;

  • Driver routines (e.g. "main.F90") that enable GEOS-Chem to be run in several different contexts, including:

    • GEOS-Chem "Classic" (suitable for running with less than ~64 cores on a single node)
    • GCHP (GEOS-Chem "High Performance, which can run across multiple nodes for high scalability)
    • GEOS-GC (GEOS-Chem coupled to the NASA GEOS ESM)
    • WRF-GC (GEOS-Chem coupled with WRF)
    • and GEOS-Chem coupled to other Earth System Models (e.g. CESM2, NCAR "next-generation" models, etc.)

HEMCO is no longer part of the geoschem/GEOS-Chem repository

One important note: The Harmonized Emissions Component (HEMCO) source code has been removed, and is maintained as a separate repository (geoschem/HEMCO). This is because HEMCO is now being developed independently of GEOS-Chem. This will facilitate HEMCO being used in external models (such as at NOAA and NCAR).

Wrapper repositories

You should not clone geoschem/geos-chem directly. Instead, you should clone one of the "wrapper" repositories:

  • geoschem/GCClassic

  • geoschem/GCHP

which will then treat geoschem/geos-chem (and geoschem/HEMCO for that matter) as a Git submodule. For details, we refer you to our "Getting Started with GEOS-Chem" manual or our Youtube tutorial videos (discussed in the Documentation section below).

GEOS-Chem Development

Branches

This repository contains several branches. Each branch contains code updates belonging to a particular line of development.

  • The main branch always contains the current stable version. You should never add new code directly into this branch. Instead, open a new branch off of main and add your code there.

  • The dev/X.Y.Z branches always contains in-development code for upcoming version X.Y.Z. Code in dev/X.Y.Z is very much "work in progress" and should not be relied upon until it has been fully debugged, validated, and merged back into the master branch.

  • From time to time, you will see other branches pertaining to new lines of development being created. These branches usually will start with feature/ or bugfix/. Once the code in these branches has been sufficiently validated, these branches will be merged back into the master branch. You should not use code in these branches.

  • You may also see branches beginning with e.g. GEOS, CESM, etc. These branches are intended for ongoing development to connect GEOS_Chem within other Earth System Models. You may ignore the code in these branches.

Versions

GEOS-Chem versions are now denoted by 3 digits (X.Y.Z):

  • The X digit is the major version number. A change in X denotes that the current version contains a significant update that breaks backwards-compatibility with the prior series of GEOS-Chem versions. Major structural updates typically will require an update to X. In the past we have changed the X digit when replacing SMVGEAR with FlexChem (version 10 to version 11) and replacing legacy emissions with HEMCO (version 9 to version 10).

  • The Y digit is the feature version number. A change in Y denotes that a 1-month benchmark has been performed to validate a new feature or set of features. Some (but not all) Y versions will have 1-year benchmarks performed as well. In general, the Y digit changes whenever a new feature breaks backwards compatibility with one or more run directories from the prior version.

  • The Z digit is the bug fix (or patch) version number. A change in Z denotes that a bug fix was made that does not break backwards compatibility with run directories from the prior verison. Z will also be updated when bug fixes or minor updates are made to one or more of the GEOS-Chem "Specialty" simulations. Updating specialty simulations should not affect the output of the GEOS-Chem 1-month or 1-year benchmark simulations.

For more information, please see this wiki page: http://wiki.geos-chem.org/GEOS-Chem_version_numbering_system

All benchmarked GEOS-Chem versions are tagged in the Git history. Use git tag in your terminal to see a list of available tags. Tags will also be highlighted in the gitk browser window.

Citing GEOS-Chem versions with DOI's

You can now cite GEOS-Chem in publications with a Digital Object Identifier (DOI). Each GEOS-Chem release will be assigned its own individual DOI. DOI's for each GEOS-Chem version will be posted on the GEOS-Chem website and GEOS-Chem wiki.

We have also generated a concept DOI, which will always point to the current stable version of GEOS-Chem (i.e. corresponding to the master branch): DOI

Documentation

Web site

The GEOS-Chem web site is a good place to get started. It will point you to many important GEOS-Chem resources.

Online user's manual

You can find the The GEOS-Chem User's Guide online here:

NOTE: The above link currently points to Getting Started with GEOS-Chem on the GEOS-Chem wiki. In the near future, we will migrate this documentation to readthedocs.io.

Wiki

The most up-to-date information about GEOS-Chem is posted on the GEOS-Chem wiki. Here you will find information about technical issues, bug fixes, and other pertinent topics.

Youtube

We have created several tutorial videos at our GEOS-Chem Youtube channel (https://youtube.com/c/geos-chem). Please take a few moments to view the following tutorials

Support

We encourage GEOS-Chem users to use the Github issue tracker attached to this repository to report bugs or technical issues with the GEOS-Chem code.

License

GEOS-Chem (and related software) is distributed under the MIT license. Please see the license documents LICENSE.txt and AUTHORS.txt in the root folder.

06 Jan 2021 GEOS-Chem Support Team geos-chem-support@g.harvard.edu

About

GEOS-Chem "Science Codebase" repository. Contains GEOS-Chem science routines, run directory generation scripts, and interface code. This repository is used as a submodule within the GCClassic and GCHP wrappers, as well as in other modeling contexts (external ESMs).

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Fortran 98.5%
  • Makefile 0.7%
  • Perl 0.4%
  • Shell 0.2%
  • C++ 0.1%
  • CMake 0.1%