R package piamInterfaces, version 0.40.7
Project specific interfaces to REMIND / MAgPIE.
- To understand how to submit to the IIASA database, read this REMIND tutorial.
- In the following, we differentiate templates (list of variables and corresponding units used in a project) and mappings (specifying which PIAM variable will be mapped to a project variable).
Mappings found in
the inst/mappings
folder
serve to map variables from the PIAM framework to variables needed for the submission to databases.
The mappings are ;
-separated files, using #
as comment character, with the following mandatory columns:
variable
: name of the variable in the project templateunit
: unit corresponding tovariable
. If the IIASA template has no unit, useunitless
.piam_variable
: name of the variable in REMIND / MAgPIE / EDGE-T etc. reportingpiam_unit
: unit corresponding topiam_variable
piam_factor
: factor with which thepiam_variable
has to be multiplied for units to match
Recommended column:
description
: description text defining thevariable
. Never use"
and;
in the text.source
: abbreviation of the PIAM part where thepiam_variable
comes from. UseB
= Brick,C
= MAGICC,M
= MAgPIE,R
= REMIND,S
= SDP postprocessing,T
= EDGE-Transport. This column is used to select the variables passed to remind2 and coupling tests. If the variable is not normally reported, add a smallx
after the model abbreviation for it to be skipped.interpolation
: sets the interpolation method for thevariable
(i.e. notpiam_variable
) (currently only supportslinear
). When set tolinear
, adds yearly values between 2005 and 2100 through linear interpolation for the selected output variables.
Additionally, some mappings use those columns:
idx
: serial number ofvariable
Tier
: importance of variable. 1 means most importantComment
: place for commentsweight
: calculates a weighted average of multiple entries ofpiam_variable
. Provide a differentpiam_variable
in this column, andgenerateIIASASubmission()
will split the data on the rows which contain weight pointers, resolve these weights into numerical values (via a join operation between the submission and the input data) and then modify the value based on the weighting. This takes place in the private .resolveWeights method.
To edit a mapping in R
, use:
mappingdata <- getMapping("AR6")
...
write.table(mappingdata, "inst/mappings/test_mapping.csv", na = "", dec = ".", sep = ";", row.names = FALSE, quote = FALSE)
Opening the csv files in Excel can be problematic, as it sometimes changes values and quotation marks. You can edit the files in LibreOffice Calc using these settings in the Text Import dialog:
- Text Import with:
- Character set: Unicode (UTF-8)
- Separated by: Semicolon.
- Save with:
- Character set: Unicode (UTF-8)
- Field Delimiter: ;
- String Delimiter: (none)
The github diff on a large semicolon-separated file is often unreadable. For a human-readable output, save the old version of the mapping and run:
remind2::compareScenConf(fileList = c("oldfile.csv", "mappingfile.csv"), row.names = NULL, expanddata = FALSE)
On the PIK cluster, you can run comparescenconf mapping_AR6.csv
in the inst/mappings
folder and it will compare to a recent master
version.
Since templates contain between several hundreds and a few thousand variables, relying on existing mappings can save substantial amounts of work compared to setting up a new mapping from scratch. Since the template itself is most likely built based on earlier templates from other projects, chances are good that existing mappings already provide parts of the required new mapping. Using R
, we describe a simple way to create a new mapping mapping_NEW.csv
based on existing mappings.
- Identify which existing mappings are most relevant for your new mapping. Criteria might include the time at which the existing mapping was created and the proximity of the templates (e.g. follow-up project). If you are unsure, ask your experienced colleagues for advice. This provides you with a list of existing mappings that is ordered by relevance, say
mapping_OLD1.csv
, ... ,mapping_OLD9.csv
. - Use
read.csv2
to get the template as a dataframetemplate
. - Looping over the existing mappings in descending order of relevance,
- use
getMapping
to get the existing mappingmapping_OLDi
as a dataframe, filter
mapping_OLDi
for variables which are contained intemplate
and which have not yet been added tomapping_NEW
,left_join
(by variable) the filteredmapping_OLDi
withtemplate
to add the information from the template (consider usingstr_to_lower
for case-insensitive matching when filtering and joining),select
/mutate
the columns of the joined dataframe to keep the desired columns for the new mapping (see above for description of mandatory and recommended columns),bind_rows
tomapping_NEW
- use
- Use
write.csv2
to exportmapping_NEW
asmapping_NEW.csv
. It is recommended to make a few checks (e.g. by looking at all variables for which the description or the unit does not agree between the existing mapping and the template).
-
To compare the results of different models, pass as
modeldata
a quitte object or a csv/xlsx file. You get a PDF document for each scenario and each model with area plots for all the summation groups inAR6
(orNAVIGATE
) summation files plus line plots for each variable in thelineplotVariables
vector you supplied. It takes some time, better use aslurm
job for:plotIntercomparison(modeldata, summationsFile = "AR6", lineplotVariables = c("Temperature|Global Mean", "Population"))
-
If your
modeldata
is not well filtered such that for example model regions are not too different, you can useinteractive = TRUE
which allows to select models, regions, scenarios and variables that you like in your PDF. AslineplotVariables
, you can also specify mapping names.plotIntercomparison(modeldata, summationsFile = "AR6", lineplotVariables = c("AR6", "AR6_NGFS"), interactive = TRUE)
For installation of the most recent package version an additional repository has to be added in R:
options(repos = c(CRAN = "@CRAN@", pik = "https://rse.pik-potsdam.de/r/packages"))
The additional repository can be made available permanently by adding the line above to a file called .Rprofile
stored in the home folder of your system (Sys.glob("~")
in R returns the home directory).
After that the most recent version of the package can be installed using install.packages
:
install.packages("piamInterfaces")
Package updates can be installed using update.packages
(make sure that the additional repository has been added before running that command):
update.packages()
In case of questions / problems please contact Falk Benke [email protected].
To cite package piamInterfaces in publications use:
Benke F, Richters O (2025). "piamInterfaces: Project specific interfaces to REMIND / MAgPIE." Version: 0.40.7, https://github.com/pik-piam/piamInterfaces.
A BibTeX entry for LaTeX users is
@Misc{,
title = {piamInterfaces: Project specific interfaces to REMIND / MAgPIE},
author = {Falk Benke and Oliver Richters},
date = {2025-01-08},
year = {2025},
url = {https://github.com/pik-piam/piamInterfaces},
note = {Version: 0.40.7},
}