Skip to content

Latest commit

 

History

History
193 lines (132 loc) · 13 KB

02_RunningREMIND.md

File metadata and controls

193 lines (132 loc) · 13 KB

Start running REMIND with default settings

Felix Schreyer (felix.schreyeru@pik-potsdam.de), Lavinia Baumstark (baumstark@pik-potsdam.de), David Klein (dklein@pik-potsdam.de), Tonn Rüter (tonn.rueter@pik-potsdam.de) 30 April, 2019

1. Your first run

This section will explain how you start your first REMIND run on the Potsdam Institute for Climate Impact Research (PIK) High Performance Cluster (HPC). Running REMIND on other hosts is theoretically possible but works slightly different depending on input data availability and operating system configuration.

Default Configurations

The main.gms and config/default.cfg files contain the default configuration for REMIND. main.gms is divided into several parts.

a. The first part, MODULES, contains settings for the various modules and their realizations. For example, the module 21_tax has the realizations on and off. The realizations within the particular module differ from each other in their features, for e.g., bounds, parametric values, different policy cases etc. For each module you choose which realization of the module will be activated for your current run:

cfg$gms$module_name

b. The SWITCHES section contains setting parameters to control, for e.g., how many iterations to run, which technologies to include.

c. The FLAGS section contains compilation flags (setGlobals) for further configuration, for e.g., which SSP to use.

d. The last part includes all model parts from the core and modules.

Accessing the HPC

Follow the instructions in the PIK-internal Wiki on how to access the HPC.

HPC terminal configuration: Adjust .profile & .bashrc

In order to ready your HPC session for REMIND operation, you'll need to have a properly configured .profile file in your HPC home folder. Log into the cluster, then type

nano ~/.profile

Add these lines in the text editor:

umask 0002

source /p/system/modulefiles/defaults/piam/module_load_piam
module load anaconda/2024.10

Save the file and exit the editor by pressing Ctrl + X and confirm with Enter. Please note that umask 0002 needs to be the first line in the .profile! This lines makes sure the files you create on the cluster will be writable by your coworkers. The subsequent lines load the piam environment, ensuring that all system libraries necessary to run REMIND are available.

For compatibility reasons you'll also need to add a .bashrc file in your home folder. It's the same procedure as with .profile: Open the file

nano ~/.bashrc

and add umask 0002 as the first line. A typical .bashrc file might look like

umask 0002 # Must be the first line

# Additional typical .bashrc configurations like aliases must come after
alias ll="ls -la"

Again save the file by pressing Ctrl + X and confirm with Enter.

Starting the run

Open a console session on the cluster and create a folder on the cluster where you want to store REMIND. It is discouraged to use the home directory. For your first experiments you can use a subfolder of the /p/tmp/<PIK user name>/ directory, but keep in mind that unused files are deleted after three months.

In case you are using console and are not familiar with shell commands, google a list of basic shell commands such as mkdir to create a folder or cd /p/tmp/<PIK user name>/ to switch to your folder. Download REMIND into a directory in this folder via cloneremind (see tutorial 00_Git_and_GitHub_workflow).

Go to your REMIND main folder (i.e. it contains subfolders such as config, core, and modules) and start a REMIND run by typing:

Rscript start.R

Without additional arguments this starts a single REMIND run using the settings from config/default.cfg and main.gms. Also, on Windows, you can double-click the start_windows.cmd file. You can control the script's behavior by providing additional arguments, for example starting a single REMIND run in one-region mode using the settings from config/default.cfg and main.gms (useful to quickly check if your changes to the code break the model):

Rscript start.R --quick

The shortcut is

Rscript start.R -q

A message similar to the following confirms that your runs has been submitted to a compute node on the cluster: Submitted batch job 15489230.

You can check if the run is actually running by using the command

sq

in the terminal.

To see how far your run is or whether it was stopped due to some problems, you can check based on the output folder (shown as WORK_DIR in sq) by typing

remindstatus output/default_2024-02-29_16.45.19

in the console. If you are in the folder, remindstatus is sufficient. For a short version, use rs2 (see help at rs2 -h). For more commands to manage your runs, type piaminfo.

NOTE: A few words on the scripts that we currently use to start runs. The scripts containing the string 'start' have a double functionality:

  • they submit the run to the cluster or to your GAMS system if you work locally
  • they create the full.gms file (this is the file that will eventually be submitted to GAMS once your run has been compiled) and compile the needed files to start a run in a subfolder of the output folder

Restarting runs

Sometimes you want to restart a run in its already existing results folder without creating a new results folder and without compiling a new full.gms, e.g. you want a nash run to perform additional nash iterations because you are not satisfied with the convergence so far. Adding the parameter --restart displays a list of existing runs and lets you choose the run(s) you want to restart:

Rscript start.R --restart
Rscript start.R -r

This will use the result of the previous optimization (fulldata.gdx) as input for the restart. Note that this will NOT continue the run from the last CONOPT iteration (which is impossible at the moment), but simply restart the run from the last fulldata.gdx. Accordingly, all outputs (like full.lst, gdx, etc) are overwritten if you do not first make a copy by hand.

2. What happens during a REMIND run?

This section will give some technical introduction into what happens after you have started a run. It will not be a tutorial, but rather an explanation of the different parts in the modeling routine. The whole routine is illustrated in Figure 1. The core of the model is the optimization written in GAMS. However, there is some pre-processing of the input data and some post-processing of the output data using R scripts.

REMIND modeling routine

REMIND modeling routine

3. What happens once you start REMIND on the cluster?

Let us go through each of the stages and briefly describe what happens:

a) renv Setup

REMIND is using renv for R package library management, see the REMIND renv tutorial for details. When starting a run the main renv is essentially copied to the run folder which ensures that the run is always using the same package versions for reproducibility and packages cannot become corrupt because of global package updates.

The R libraries required for indput data preparation and output processing (e.g. madrat, mrremind and remind2) are made available to the run this way.

b) Input Data Preparation

The optimization in REMIND requires a lot of input data. For example, the model needs to know energy production capacities per region for its initial time steps. Furthermore, it builds on GDP, population and energy demand projections that are results of other models. These kind of data are stored on the cluster in

/p/projects/rd3mod/inputdata/sources

The data are mostly in csv files. During the input data preparation, these files are read and processed, using functions from the mrremind package. Input data are available on country-level. Then, depending on the regionmapping file you chose in the config file of your run, the country-level data are aggregated into regions, e.g. to LAM (Latin America), EUR (Europe) and so on. Finally, the data are stored as .cs3r or .cs4r files in various input folders of your REMIND directory. These files are basically tables, too, that you can open with a text editor or Excel. For example, you find the input file pm_histCap.cs3r in your REMIND directory under core/input. It provides the model with historically observed values of installed capacities of some technologies in the respective regions. The regional resolution of the run is set in the config/default.cfg by

cfg$regionmapping

(default setting: regionmapping <- "config/regionmappingH12.csv"). Based on the regional resolution and the input data revision

cfg$inputRevision

the name of the needed input data is constructed. It is checked whether those input data are already available. If not they are automatically downloaded from /p/projects/rd3mod/inputdata/output/ and distributed.

c) Optimization

The actual REMIND is written in GAMS, a programming software to numerically solve optimization problems. The GAMS scripts are .gms files that you can find under the core (main part of the model) and the modules directories (subparts of the model). The general structure of the GAMS code is depicted in Figure 2. At each stage (e.g. sets), GAMS runs through the respective .gms files of the core and all chosen module realisations of that stage (core/sets.gms -> modules/01_macro/sets.gms, -> modules/02_welfare/sets.gms -> ...) before going to the next stage. The stages bounds, presolve, solve and postsolve are run in a loop that is followed by the final stage output.

Structure of the REMIND GAMS code

GAMS code structure

Fundamentally, we distinguish between two kinds of variables: variables (starting with v_) and parameters (starting with p_). Parameters are fixed (exogenous data in economists' lingo), while variables are free within a certain range and can be adjusted to maximize the objective function of the optimization problem (endogenous variables in economist's lingo). However, there are many constraints that fix relations between the variables and parameters. Within the remaining solution space, the optimization procedure tries to find the maximum of the objective function. The output file of the optimization is the fulldata.gdx which is under output in the folder of your REMIND run. You can open it, for instance, with GAMS IDE or load it into R using the command readGDX() (see details below). In the file, you can find, among other things, the optimal levels of the variables (variable.l) and all the predefined parameter values.

d) Output Processing

The output processing works with a number of R functions from the remind2 package (most of them start with report... .R). The wrapper function convGDX2MIF.R writes the most relevant output into the so-called .mif file. Again, it is a table that you can open in Excel for example. You find under output in the folder of your REMIND run as

REMIND_generic_YourRun.mif

where YourRun is the name of the run you specified in the first column of the config file. It is important to keep in mind that between fulldata.gdx and the .mif file and number of calculations and conversions are happening which makes the variables in both files different. For output analysis, the .mif file is often more helpful, while in case you want to trace back some problem with the GAMS optimization, it can be necessary to directly look at optimal levels, marginals (values that tell you whether a variation of the variable increase or decrease the welfare level) or bounds (maximum and minimum value allowed for variable) that you all find in the fulldata.gdx created right after the optimization.