NCAR and CESM Introduction

The NCAR Earth System Model

Overview

Teaching: min
Exercises: min
Questions
  • What is CESM?

  • How does it differ from other Earth system models?

  • Why do we use CESM in this class?

Objectives
  • Learn about CESM

A couple of weeks ago you learned about the various Earth system models being used by the research and operational communities. Today we will learn about the NCAR/Community Earth System Model.

NCAR/Community Earth System Model (CESM)

CESM

Key Points


CESM Workflow

Overview

Teaching: 0 min
Exercises: 0 min
Questions
  • What is the CESM Workflow?

Objectives

The NCAR/CESM consists of many component models which are their own software programs. These models talk to each other through another piece of software called a coupler. There is yet even another software system, called the Workflow. It allows us to select various model components and configurations for our experiments.

CESMCoupling

Workflow

The workflow used by CESM is called the Coupling Infrastructure for Modeling Earth (CIME). It includes:

CIME

CIME is being used by other modeling groups, so learning how to configure and run the CESM using CIME may translate to being able to work with other models.

Key Points


The NCAR Computing Environment

Overview

Teaching: 0 min
Exercises: 0 min
Questions
  • How do I use the NCAR Computers?

Objectives

You have now have accounts on the NCAR computers derecho.hpc.ucar.edu and casper.ucar.edu.

Login to derecho or casper

$ ssh -X -l username derecho.hpc.ucar.edu
$ ssh -X -l username casper.hpc.ucar.edu

Follow the instructions you received regarding Duo 2-factor authentication

Derecho

Derecho is a supercomputer, but to the user it is just like any Unix computer and we run the same Unix commands here.

Your home directory on NCAR

Use the pwd command to see what your home directory is called.

To run a model we will need disk space beyond just our home directory. By default, with your NCAR account, you have space in your home directory, a temporary space called scratch and a work directory all under a system called the GLADE shared file system. How do I know what directories I have and how much space is available?

Your disk space on glade

Use the gladequota command to see

Note that only the home directory is backed up.

Cheyenne

Key Points


Downloading CESM

Overview

Teaching: 0 min
Exercises: 0 min
Questions
  • How do I download CESM?

Objectives

We will now download the model and all the setup files needed for it. These are one-time steps.

Go to your /glade/work/ directory

$ cd /glade/work/cstan

Download the CESM from Github

$ git clone -b release-cesm2.1.5 https://github.com/ESCOMP/cesm.git cesm2.1.5 

Change to the cesm2.1.5 directory

$ cd cesm2.1.5

Let’s take a look in that directory and talk about what is there and what is not. Need to get the model components.

Checkout all the model components

$ ./manage_externals/checkout_externals

Sometimes this hangs and gives an error about connecting. If it does, try again. If it asks you a question about the certificate, you can select p for permanent.

Warning

If a problem was encountered during checkout_externals, which may happen with an older version of the svn client software, it may appear to have downloaded successfully, but in fact only a partial checkout has occurred.

To confirm a successful download of all components, you can run checkout_externals with the status flag to show the status of the externals:

./manage_externals/checkout_externals -S

This should show a clean status for all externals, with no characters in the first two columns of output, as in this example:

Processing externals description file : Externals.cfg
Processing externals description file : Externals_CLM.cfg
Processing externals description file : Externals_POP.cfg
Processing externals description file : Externals_CISM.cfg
Checking status of externals: clm, fates, ptclm, mosart, ww3, cime, cice, pop, cvmix, marbl, cism, source_cism, rtm, cam,
    ./cime
    ./components/cam
    ./components/cice
    ./components/cism
    ./components/cism/source_cism
    ./components/clm
    ./components/clm/src/fates
    ./components/clm/tools/PTCLM
    ./components/mosart
    ./components/pop
    ./components/pop/externals/CVMix
    ./components/pop/externals/MARBL
    ./components/rtm
    ./components/ww3

Leave this running over break.

Key Points


CESM Quickstart

Overview

Teaching: 0 min
Exercises: 0 min
Questions
  • How do I setup and run the CESM?

Objectives

You have now downloaded all the model components and the CIME workflow. Let’s take a look: From your /glade/work/username/cesm2.1.5 directory, see what is there.

$ ls

What was added after running manage_externals

Organization of the CESM Directory

CESM has a set of keywords that refer to specific directories, they are:

Find your SRCROOT and CIMEROOT

Your SRCROOT and CIMEROOT exist after downloading the CESM. What are the exact paths for you?

CIMEROOT

The cime subdirectory contains a subdirectory called scripts. This is the directory we will use initially for setting up the model. Change into this subdirectory and take a look.

$ cd cime/scripts
$ ls

The final one-time step is to create a directory called cases in your home directory.

$ mkdir ~/cases

The cases directory (also called your CASEROOT) will contain all the source code and configuration files for your model experiments.
Why do you think we would put something like this in our home directory?

Model Quickstart

Above were the one-time setup setps, now we move on to the steps you will do everytime to setup a new model experiment and run it.

Go into the scripts subdirectory in your CIMEROOT

$ cd /glade/work/cstan/cesm2.1.5/cime/scripts

Create a new case

$ ./create_newcase --case ~/cases/b.day1.0 --res f19_g17 --compset B1850 --project UGMU0049

This created a new subdirectory for your new case. Change to that directory.

$ cd ~/cases/b.day1.0 

Setup the case

$ ./case.setup

Build the executable (this will take while)

$ qcmd -A UGMU0049 -- ./case.build

This will take awhile. While the model is compiling, we will talk about what the create_newcase command did.

Potential Errors

Some users received an error indicating that their account was overspent or expired. This happened to users who already had a NCAR account associated with a project charge code that was no longer available. To resolve this, set the PBS_ACCOUNT environment variable to a valid charge code for this class.

$ export PBS_ACCOUNT=UGMU0049

This setting will go away after you logout, so you will need to set it everytime for the correct project charge code associated with the project you are working on.

What did we just do?

create_newcase takes 3 arguments

create_newcase

Case Name (case)

This is the name and location of your experiment

This experiment is called b.day1.0 and it is located in my cases directory in my home directory.

Resoultion (res)

Specifies the resolution and grid of the model components. Each model resolution can be specified by its alias or long name.

grid

How to know what grids are available? There’s a tool

$ CIMEROOT/scripts/query_config --grids --long 

and a website

Understanding grids

The resolution f09_g17 is the standard resolution used for CMIP simulations with the CESM. What is the resolution of the atmosphere/land and ocean in this model?

Component Set (compset)

Sets which versions and component models are active vs. inactive and what forcings are used.
The first letter B in this compset indicate that all components are active. The 1850 means that the 1850 greenhouse gas forcings will be used.

How do I know what the different compsets are?

There’s a tool

$ CIMEROOT/scripts/query_config --compsets

and a website

Some Common Compset Starting Characters

Certain compsets are scientifically validated meaning they have been extensively tested.
You can create your own compsets. It is strongly suggested that you start developing any experiments from a scientifically validated compset, then make changes. The selected compset determines which grids are available.

The CASEROOT directory

This was created when you ran create_newcase. Change directory and take a look at it:

$ cd ~/cases/b.day1.0
$ ls

It contains a bunch of .xml files which are configuration files. We will learn how to modify them next week.

What happened when we ran case.setup?

What happened when we ran case.build?

How can I find out what my CASEROOT, CIMEROOT, etc. are if I forget?

$ ./xmlquery RUNDIR,EXEROOT,CASEROOT,CIMEROOT

Now what?

If your build has completed, then you can submit your model run to the queue.

$ ./case.submit

You can see that is is in the queue, using

$ qstat -u username

What do we see regarding the model run in the queue?

You can logout now. While we are away, our model will run. We will return next week to take a look!

Key Points