3. Deal with errors

OGGM will not be able to run on a number of glaciers. We summarized the reasons for this in our GMD publication and showed that the number of failing glaciers can be quite high depending on the region considered.

In this example, we run the model on a list of three glaciers: two of them will end with errors: one because it already failed at preprocessing (i.e. prior to this run), and one will fail during the run.

Script

The important part of the script is the set-up of the continue_on_error global parameter to True. This will allow OGGM to continue the run despite of some glaciers having errors, a useful feature for regional or global applications.

# Python imports
import logging

# Locals
import oggm.cfg as cfg
from oggm import utils, workflow, tasks

# For timing the run
import time
start = time.time()

# Module logger
log = logging.getLogger(__name__)

# Initialize OGGM and set up the default run parameters
cfg.initialize(logging_level='WORKFLOW')

# Here we override some of the default parameters
# How many grid points around the glacier?
# We make it small because we want the model to error because
# of flowing out of the domain
cfg.PARAMS['border'] = 80

# This is the important bit!
# We tell OGGM to continue despite of errors
cfg.PARAMS['continue_on_error'] = True

# Local working directory (where OGGM will write its output)
WORKING_DIR = utils.gettempdir('OGGM_Errors')
utils.mkdir(WORKING_DIR, reset=True)
cfg.PATHS['working_dir'] = WORKING_DIR

rgi_ids = ['RGI60-11.00897', 'RGI60-11.01450', 'RGI60-11.03295']

log.workflow('Starting OGGM run')
log.workflow('Number of glaciers: {}'.format(len(rgi_ids)))

# Go - get the pre-processed glacier directories
gdirs = workflow.init_glacier_directories(rgi_ids, from_prepro_level=4)

# We can step directly to the experiment!
# Random climate representative for the recent climate (1985-2015)
# with a negative bias added to the random temperature series
workflow.execute_entity_task(tasks.run_random_climate, gdirs,
                             nyears=150, seed=0,
                             temperature_bias=-1)

# Write the compiled output
utils.compile_glacier_statistics(gdirs)
utils.compile_run_output(gdirs)

# Log
m, s = divmod(time.time() - start, 60)
h, m = divmod(m, 60)
log.workflow('OGGM is done! Time needed: %d:%02d:%02d' % (h, m, s))

If everything went “well”, you should see an output similar to:

2020-03-24 18:54:32: oggm.cfg: Using configuration file: /home/mowglie/disk/Dropbox/HomeDocs/git/oggm-fork/oggm/params.cfg
2020-03-24 18:54:32: oggm.cfg: Multiprocessing switched ON according to the parameter file.
2020-03-24 18:54:32: oggm.cfg: Multiprocessing: using all available processors (N=8)
2020-03-24 18:54:32: __main__: Starting OGGM run
2020-03-24 18:54:32: __main__: Number of glaciers: 3
2020-03-24 18:54:32: oggm.workflow: init_glacier_directories from prepro level 4 on 3 glaciers.
2020-03-24 18:54:32: oggm.workflow: Execute entity task gdir_from_prepro on 3 glaciers
2020-03-24 18:54:32: oggm.workflow: Initializing multiprocessing pool with N=8 processes.
2020-03-24 18:55:00: oggm.workflow: Execute entity task run_random_climate on 3 glaciers
2020-03-24 18:55:00: oggm.core.flowline: RuntimeError occurred during task run_random_climate on RGI60-11.03295: Need a valid `model_flowlines` file. If you explicitly want to use `inversion_flowlines`, set use_inversion_flowlines=True.
2020-03-24 18:55:10: oggm.core.flowline: RuntimeError occurred during task run_random_climate on RGI60-11.00897: Glacier exceeds domain boundaries, at year: 135.83333333333334
2020-03-24 18:55:31: oggm.workflow: Execute entity task glacier_statistics on 3 glaciers
2020-03-24 18:55:31: __main__: OGGM is done! Time needed: 0:00:59

Dealing with errors

The simplest way to deal with errors is to look for NaNS (“not a number”) in the run_output*.nc files: glaciers with errors will have NaNs in place of their timeseries. For an in-depth analysis of the cause of these errors, OGGM delivers some tools to help you out. We have prepared two notebooks to show you their usage:

  • deal_with_errors.ipynb builds upon the example above to analyse the output
  • preprocessing_errors.ipynb reproduces the error analysis of our GMD paper

You can open these tutorials online by following this link:

https://img.shields.io/badge/Launch-OGGM%20tutorials-579ACA.svg?style=popout&logo=