Title: | May All Data be Reproducible and Transparent (MADRaT) * |
---|---|
Description: | Provides a framework which should improve reproducibility and transparency in data processing. It provides functionality such as automatic meta data creation and management, rudimentary quality management, data caching, work-flow management and data aggregation. * The title is a wish not a promise. By no means we expect this package to deliver everything what is needed to achieve full reproducibility and transparency, but we believe that it supports efforts in this direction. |
Authors: | Jan Philipp Dietrich [aut, cre] (Potsdam Institute for Climate Impact Research, <https://orcid.org/0000-0002-4309-6431>), Lavinia Baumstark [aut] (Potsdam Institute for Climate Impact Research), Stephen Wirth [aut] (Potsdam Institute for Climate Impact Research), Anastasis Giannousakis [aut], Renato Rodrigues [aut] (Potsdam Institute for Climate Impact Research), Benjamin Leon Bodirsky [aut] (Potsdam Institute for Climate Impact Research), Debbora Leip [aut] (Potsdam Institute for Climate Impact Research), Ulrich Kreidenweis [aut], David Klein [aut] (Potsdam Institute for Climate Impact Research), Pascal Sauer [aut] (Potsdam Institute for Climate Impact Research) |
Maintainer: | Jan Philipp Dietrich <[email protected]> |
License: | BSD_2_clause + file LICENSE |
Version: | 3.16.1 |
Built: | 2025-01-09 10:24:42 UTC |
Source: | https://github.com/pik-piam/madrat |
Package provides a basic framework which should improve reproducibility and transparency in data processing. It provides functionality such as automatic meta data creation and management, rudimentary quality management, data caching, work-flow management an data aggregation.
* The title is a wish not a promise. By no means we expect this package to deliver everything what is needed to achieve full reproducibility and transparency, but we believe that it supports efforts in this direction.
Maintainer: Jan Philipp Dietrich [email protected] (ORCID) (Potsdam Institute for Climate Impact Research)
Authors:
Lavinia Baumstark [email protected] (Potsdam Institute for Climate Impact Research)
Stephen Wirth [email protected] (Potsdam Institute for Climate Impact Research)
Anastasis Giannousakis [email protected]
Renato Rodrigues [email protected] (Potsdam Institute for Climate Impact Research)
Benjamin Leon Bodirsky [email protected] (Potsdam Institute for Climate Impact Research)
Debbora Leip [email protected] (Potsdam Institute for Climate Impact Research)
Ulrich Kreidenweis [email protected]
David Klein [email protected] (Potsdam Institute for Climate Impact Research)
Pascal Sauer [email protected] (Potsdam Institute for Climate Impact Research)
Useful links:
Report bugs at https://github.com/pik-piam/madrat/issues
Function whichs adds another mapping to the current list of extramappings
in the madrat configuration (see setConfig
) and stores
the mapping in the mapping folder as well as output folder.
addMapping(filename, mapping = NULL)
addMapping(filename, mapping = NULL)
filename |
The name of the the region mapping that should added including file ending (e.g. "regionmappingREMIND.csv"). Supported formats are currently ".csv" and ".rds". |
mapping |
Mapping provided as data.frame, or NULL. If a mapping is provided the data will be written in the mapping file of the given file (potentially replacing existing data). If NULL the mapping from the given file is used. |
Jan Philipp Dietrich
## Not run: addMapping("regionmappingH12.csv") ## End(Not run)
## Not run: addMapping("regionmappingH12.csv") ## End(Not run)
Calculate hash from given function arguments for given call
cacheArgumentsHash(call, args = NULL)
cacheArgumentsHash(call, args = NULL)
call |
A function as a string or symbol. Passing a vector of functions is possible, but is only intended for corresponding read/correct/convert functions. If multiple functions in a vector define arguments with the same name but different default values only the default defined in the first function is considered. |
args |
A list of named arguments used to call the given function(s). If duplicates of arguments exists the first occurrence of the argument will be used. |
A hash representing the given arguments hash for the given call. NULL, if no argument deviates from the default argument settings.
Jan Philipp Dietrich
cachePut
, cacheName
, getNonDefaultArguments
madrat:::cacheArgumentsHash("madrat:::readTau", args = list(subtype = "historical")) madrat:::cacheArgumentsHash("madrat:::readTau", args = list(subtype = "paper")) calls <- c(madrat:::readTau, madrat:::convertTau) madrat:::cacheArgumentsHash(calls, args = list(subtype = "historical"))
madrat:::cacheArgumentsHash("madrat:::readTau", args = list(subtype = "historical")) madrat:::cacheArgumentsHash("madrat:::readTau", args = list(subtype = "paper")) calls <- c(madrat:::readTau, madrat:::convertTau) madrat:::cacheArgumentsHash(calls, args = list(subtype = "historical"))
Delete files older than the specified number of days, based on file time metadata (per default atime = last access time).
cacheCleanup( daysThreshold, path = getConfig("cachefolder", verbose = FALSE), timeType = c("atime", "mtime", "ctime"), ask = TRUE, readlineFunction = readline )
cacheCleanup( daysThreshold, path = getConfig("cachefolder", verbose = FALSE), timeType = c("atime", "mtime", "ctime"), ask = TRUE, readlineFunction = readline )
daysThreshold |
Files older than this many days are deleted/returned. |
path |
Path to where to look for old files. |
timeType |
Which file metadata time should be used. One of atime (last access time, default), mtime (last modify time), ctime (last metadata change). |
ask |
Whether to ask before deleting. |
readlineFunction |
Only needed for testing. A function to prompt the user for input. |
File time metadata is not available on all systems and the semantics are also system dependent, so please be careful and check that the correct files are deleted. This function will return a data.frame containing all files that would be deleted if the user answers 'n' to the question. If deleting files fails a warning is created.
If the user answers 'n', a data.frame as returned by base::file.info, containing only files older than <daysThreshold> days.
Copy cache files which were used for a given preprocessing.
cacheCopy(file, target = NULL, filter = NULL)
cacheCopy(file, target = NULL, filter = NULL)
file |
Path to a log file or content of a log as character vector. |
target |
Folder to which the files should be copied. If NULL no data is copied. |
filter |
Regular expression to filter the cache files shown in the log file. |
A vector of cache files which match the given log information and filter.
Jan Philipp Dietrich
Load fitting cache data (if available)
cacheGet(prefix, type, args = NULL, graph = NULL, ...)
cacheGet(prefix, type, args = NULL, graph = NULL, ...)
prefix |
function prefix (e.g. "calc" or "read") |
type |
output type (e.g. "TauTotal") |
args |
a list of named arguments used to call the given function |
graph |
A madrat graph as returned by |
... |
Additional arguments for |
cached data, if cache is available, otherwise NULL
Jan Philipp Dietrich
madrat:::cacheGet("calc", "TauTotal", packages = "madrat")
madrat:::cacheGet("calc", "TauTotal", packages = "madrat")
Load fitting cache data (if available)
cacheName( prefix, type, args = NULL, graph = NULL, mode = "put", packages = getConfig("packages"), globalenv = getConfig("globalenv") )
cacheName( prefix, type, args = NULL, graph = NULL, mode = "put", packages = getConfig("packages"), globalenv = getConfig("globalenv") )
prefix |
function prefix (e.g. "calc" or "read") |
type |
output type (e.g. "TauTotal") |
args |
a list of named arguments used to call the given function |
graph |
A madrat graph as returned by |
mode |
Context in which the function is used. Either "get" (loading) or
"put" (writing). In case of "put" the potential file name is returned.
When set to "get", a file name will only be returned if the file exists
(otherwise NULL) and in combination which |
packages |
A character vector with packages for which the available Sources/Calculations should be returned |
globalenv |
Boolean deciding whether sources/calculations in the global environment should be included or not |
Name of fitting cache file, if available, otherwise NULL
setConfig(forcecache=TRUE)
strongly affects the behavior
of cacheName
. In read model it will also return cache names
with deviating hashes if no fitting cache file is found (in that case
it will just return the newest one). In write mode the hash in the name
will be left out since due to cache forcing it cannot be guaranteed
that the cache file agrees with the state represented by the hash.
Jan Philipp Dietrich
madrat:::cacheName("calc", "TauTotal")
madrat:::cacheName("calc", "TauTotal")
Save data to cache
cachePut(x, prefix, type, args = NULL, graph = NULL, ...)
cachePut(x, prefix, type, args = NULL, graph = NULL, ...)
x |
data that should be written to cache |
prefix |
function prefix (e.g. "calc" or "read") |
type |
output type (e.g. "TauTotal") |
args |
a list of named arguments used to call the given function |
graph |
A madrat graph as returned by |
... |
Additional arguments for |
Jan Philipp Dietrich
## Not run: example <- 1 madrat:::cachePut(example, "calc", "Example", packages = "madrat") ## End(Not run)
## Not run: example <- 1 madrat:::cachePut(example, "calc", "Example", packages = "madrat") ## End(Not run)
Calculate a specific output for which a calculation function exists. The function is a wrapper for specific functions designed for the different possible output types.
calcOutput( type, aggregate = TRUE, file = NULL, years = NULL, round = NULL, signif = NULL, supplementary = FALSE, append = FALSE, warnNA = TRUE, na_warning = NULL, try = FALSE, regionmapping = NULL, writeArgs = NULL, ... )
calcOutput( type, aggregate = TRUE, file = NULL, years = NULL, round = NULL, signif = NULL, supplementary = FALSE, append = FALSE, warnNA = TRUE, na_warning = NULL, try = FALSE, regionmapping = NULL, writeArgs = NULL, ... )
type |
output type, e.g. "TauTotal". A list of all available source
types can be retrieved with function |
aggregate |
Boolean indicating whether output data aggregation should be performed or not, "GLO" (or "glo") for aggregation to one global region, "REG+GLO" (or "regglo") for a combination of regional and global data. |
file |
A file name. If given the output is written to that file in the outputfolder as specified in the config. |
years |
A vector of years that should be returned. If set to NULL all available years are returned. |
round |
Number of decimal places to round to. Ignored if |
signif |
Number of significant digits to round to. Ignored if |
supplementary |
boolean deciding whether supplementary information such as weight should be returned or not. If set to TRUE a list of elements will be returned! |
append |
boolean deciding whether the output data should be appended in the existing file. Works only when a file name is given in the function call. |
warnNA |
boolean deciding whether NAs in the data set should create a warning or not |
na_warning |
deprecated, please use |
try |
if set to TRUE the calculation will only be tried and the script will continue even if the underlying calculation failed. If set to FALSE calculation will stop with an error in such a case. This setting will be overwritten by the global setting debug=TRUE, in which try will be always interpreted as TRUE. |
regionmapping |
alternative regionmapping to use for the given calculation. It will temporarily overwrite the global setting just for this calculation. |
writeArgs |
a list of additional, named arguments to be supplied to the corresponding write function |
... |
Additional settings directly forwarded to the corresponding calculation function |
magpie object with the requested output data either on country or on regional level depending on the choice of argument "aggregate" or a list of information if supplementary is set to TRUE.
The underlying calc-functions are required to provide a list of information back to
calcOutput
. Following list entries should be provided:
x - the data itself as magclass object
weight - a weight for the spatial aggregation
unit - unit of the provided data
description - a short description of the data
note (optional) - additional notes related to the data
class (optional | default = "magpie") - Class of the returned object. If set to something other than "magpie" most functionality, such as aggregation or unit tests will not be available and is switched off!
isocountries (optional | default = TRUE (mostly) or FALSE (if global)) - a boolean indicating whether data is in iso countries or not (the latter will deactivate several features such as aggregation)
mixed_aggregation (optional | default = FALSE) - boolean which allows for mixed aggregation (weighted mean mixed with summations). If set to TRUE weight columns filled with NA will lead to summation, otherwise they will trigger an error.
min (optional) - Minimum value which can appear in the data. If provided calcOutput will check whether there are any values below the given threshold and warn in this case
max (optional) - Maximum value which can appear in the data. If provided calcOutput will check whether there are any values above the given threshold and warn in this case
structure.spatial (optional) - regular expression describing the name structure of all
names in the spatial dimension (e.g. "^[A-Z]\{3\}$"
). Names will be checked against this regular expression and
disagreements will be reported via a warning.
structure.temporal (optional) - regular expression describing the name structure of all
names in the temporal dimension (e.g. "^y[0-9]\{4\}$"
). Names will be checked against this regular expression and
disagreements will be reported via a warning.
structure.data (optional) - regular expression describing the name structure of all
names in the data dimension (e.g. "^[a-z]*\\\\.[a-z]*$"
). Names will be checked against this regular expression and
disagreements will be reported via a warning.
aggregationFunction (optional | default = toolAggregate) - Function to be used to
aggregate data from country to regions. The function must have the argument x
for
the data itself and rel
for the relation mapping between countries and regions and
must return the data as magpie object in the spatial resolution as defined in rel.
aggregationArguments (optional) - List of additional, named arguments to be supplied
to the aggregation function. In addition to the arguments set here, the function will be
supplied with the arguments x
, rel
and if provided/deviating from the default
also weight
and mixed_aggregation
.
putInPUC (optional) boolean which decides whether this calculation should be added to a puc file
which contains non-aggregated data and can be used to later on aggregate the data to resolutions of own choice.
If not set calcOutput
will try to determine automatically, whether a file is being required for the puc file
or not, but in more complex cases (e.g. if calculations below top-level have to be run as well) this setting can
be used to manually tweak the puc file list. CAUTION: Incorrect settings will cause corrupt puc files,
so use this setting with extreme care and only if necessary.
cache (optional) boolean which decides whether a cache file should be written (if caching is active) or not. Default setting is TRUE. This can be for instance useful, if the calculation itself is quick, but the corresponding file sizes are huge. Or if the caching for the given data type does not support storage in RDS format. CAUTION: Deactivating caching for a data set which should be part of a PUC file will corrupt the PUC file. Use with care.
Jan Philipp Dietrich
## Not run: a <- calcOutput(type = "TauTotal") ## End(Not run)
## Not run: a <- calcOutput(type = "TauTotal") ## End(Not run)
This function prepares total tau values for use. As the source data already provides all required information this function purely removes not required data and moves xref values to the weighting object which is required for aggregation.
calcTauTotal(source = "paper")
calcTauTotal(source = "paper")
source |
data source, either "paper" (default) or "historical". |
Total tau data and corresponding weights as a list of two MAgPIE objects
Jan Philipp Dietrich
calcOutput
, readTau
,
convertTau
## Not run: calcOutput("TauTotal") ## End(Not run)
## Not run: calcOutput("TauTotal") ## End(Not run)
Helper function to clean a comment from additional metadata information
cleanComment( x, remove = c("unit", "description", "comment", "origin", "creation date", "note") )
cleanComment( x, remove = c("unit", "description", "comment", "origin", "creation date", "note") )
x |
magclass object the comment should be read from |
remove |
Vector of categories to be removed |
Jan Philipp Dietrich
x <- maxample("animal") getComment(x) <- c("unit: bla", "comment: hallo", "blub: ble") madrat:::cleanComment(x)
x <- maxample("animal") getComment(x) <- c("unit: bla", "comment: hallo", "blub: ble") madrat:::cleanComment(x)
Compares the content of two data archives and looks for similarities and differences
compareData(x, y, tolerance = 10^-5, yearLim = NULL)
compareData(x, y, tolerance = 10^-5, yearLim = NULL)
x |
Either a tgz file or a folder containing data sets |
y |
Either a tgz file or a folder containing data sets |
tolerance |
tolerance level below which differences will get ignored |
yearLim |
year until when the comparison should be performed. Useful to check if data is identical until a certain year. |
Jan Philipp Dietrich, Florian Humpenoeder
With 'compareMadratOutputs' you can easily compare the output of a madrat function (read, calc, ...) with and without your changes. First, run 'compareMadratOutputs' without your changes, so a '.rds' file with the original output is saved. Then apply your changes and run 'compareMadratOutputs' again to compare the new output to the original output.
compareMadratOutputs(package, functionName, subtypes, overwriteOld = FALSE)
compareMadratOutputs(package, functionName, subtypes, overwriteOld = FALSE)
package |
[character(1)] The package where the given function is located. It will be attached via 'library'. |
functionName |
[character(1)] The name of the function from which you want to compare outputs. Must be a madrat function whose name starts with read, correct, convert, or calc. |
subtypes |
[character(n)] The subtypes you want to check. For calc functions this must be NULL. |
overwriteOld |
If TRUE: overwrite a "*-old-*.rds" previously created with compareMadratOutputs. |
If there are differences a '<functionName>-new.rds' containing the new output is saved for closer inspection. All files are created in the current working directory.
Invisibly the result of 'waldo::compare' or 'all.equal' if a comparison was made, otherwise a named list of the outputs for each subtype.
Pascal Sauer
## Not run: # save original output to readTau-old.rds compareMadratOutputs("madrat", "readTau", c("paper", "historical")) # now apply your changes to madrat:::readTau, reinstall madrat, restart the R session # compare new output to original output from readTau-old.rds compareMadratOutputs("madrat", "readTau", c("paper", "historical")) ## End(Not run)
## Not run: # save original output to readTau-old.rds compareMadratOutputs("madrat", "readTau", c("paper", "historical")) # now apply your changes to madrat:::readTau, reinstall madrat, restart the R session # compare new output to original output from readTau-old.rds compareMadratOutputs("madrat", "readTau", c("paper", "historical")) ## End(Not run)
Convert landuse intensity data (tau) to data on ISO country level.
convertTau(x)
convertTau(x)
x |
MAgPIE object containing tau values and corresponding weights xref at 0.5deg cellular level. |
Tau data and weights as MAgPIE object aggregated to country level
Jan Philipp Dietrich
Download a source. The function is a wrapper for specific functions designed for the different possible source types.
downloadSource(type, subtype = NULL, overwrite = FALSE, numberOfTries = 300)
downloadSource(type, subtype = NULL, overwrite = FALSE, numberOfTries = 300)
type |
source type, e.g. "IEA". A list of all available source types can be retrieved with
function |
subtype |
For some sources there are subtypes of the source, for these source the subtype can be specified with this argument. If a source does not have subtypes, subtypes should not be set. |
overwrite |
Boolean deciding whether existing data should be overwritten or not. |
numberOfTries |
Integer determining how often readSource will check whether a running download is finished before exiting with an error. Between checks readSource will wait 30 seconds. Has no effect if the sources that should be read are not currently being downloaded. |
The underlying download-functions are required to provide a list of information
back to downloadSource
. Following list entries should be provided:
url - full path to the file that should be downloaded
title - title of the data source
author - author(s) of the data set
license - license of the data set. Put unknown if not specified.
description - description of the data source
unit - unit(s) of the data
doi (optional) - a DOI URL to the data source
version (optional) - version number of the data set
release_date (optional) - release date of the data set
reference (optional) - A reference for the data set (e.g. a paper, if the data was derived from it)
This user-provided data is enriched by automatically derived metadata:
call - Information about the used madrat function call to download the data will check whether there are any values below the given threshold and warn in this case
accessibility - A measure of quality for the accessibility of the data. Currently it distinguished between iron (manual access), silver (automatic access via URL) and gold (automatic access via DOI).
Besides the names above (user-provided and automatically derived) it is possible to add custom metadata entries by extending the return list with additional, named entries.
Jan Philipp Dietrich, David Klein, Pascal Sauer
## Not run: a <- downloadSource("Tau", subtype = "historical") ## End(Not run)
## Not run: a <- downloadSource("Tau", subtype = "historical") ## End(Not run)
Analyzes a log from a retrieveData run, extracts runtime information for all called functions and identifies most critical bottlenecks.
findBottlenecks(file, unit = "min", cumulative = TRUE)
findBottlenecks(file, unit = "min", cumulative = TRUE)
file |
path to a log file or content of a log as character vector |
unit |
unit for runtime information, either "s" (seconds), "min" (minutes) or "h" (hours) |
cumulative |
boolean deciding whether calls to the same function should be aggregated or not |
A data.frame sorted by net runtime showing for the different data processing functions their total runtime "time" (including the execution of all sub-functions) and net runtime "net" (excluding the runtime of sub-functions) and their share of total runtime.
Jan Philipp Dietrich
Function which creates a unique fingerprint for a madrat function based on the code of the function itself, other madrat functions which are called by this function and of all source folders involved in the process. The fingerprint can serve as an indication whether the workflow for the given function has been most likely changed, or not. If all involved source folders and the code of all involved functions remains the same, also the fingerprint will stay the same, otherwise it will change. Hence, it can be to figure out whether a cache file can be used for further calculations, or whether the calculation should be redone.
fingerprint(name, details = FALSE, graph = NULL, ...)
fingerprint(name, details = FALSE, graph = NULL, ...)
name |
Name of the function to be analyzed |
details |
Boolean indicating whether additional details in form of an attribute with underlying hash information should be added or not |
graph |
A madrat graph as returned by |
... |
Additional arguments for |
A fingerprint (hash) of all provided sources, or "fingerprintError"
For a better performance only the first 300 bytes of each file and the corresponding file size is hashed. As the fingerprint function only takes madrat-based functions into account (e.g. read-functions or calc-functions), but does ignore all other functions there might be cases where calculations actually changed, but the fingerprint is still the same. In a similar fashion it is possible that the fingerprint changes even though the workflow stayed the same (as the dependencies are sometimes overestimated).
Jan Philipp Dietrich, Pascal Sauer
madrat:::fingerprint("toolGetMapping", package = "madrat")
madrat:::fingerprint("toolGetMapping", package = "madrat")
Example for class of fullX functions. Can be used as template for a new function or for testing the basic functionality
fullEXAMPLE(rev = 0, dev = "", extra = "Example argument")
fullEXAMPLE(rev = 0, dev = "", extra = "Example argument")
rev |
data revision which should be used/produced. Will be converted to
|
dev |
development suffix to distinguish development versions for the same data revision. This can be useful to distinguish parallel lines of development. |
extra |
additional argument which - when changed - does not require a re-computation
of the portable unaggegrated collection (puc) file.
|
Jan Philipp Dietrich
readSource
,getCalculations
,calcOutput
,setConfig
## Not run: retrieveData("example", rev = "2.1.2", dev = "test", regionmapping = "regionmappingH12.csv") ## End(Not run)
## Not run: retrieveData("example", rev = "2.1.2", dev = "test", regionmapping = "regionmappingH12.csv") ## End(Not run)
Create a string representation for a function call. If the resulting string is longer than getConfig("maxLengthLogMessage") arguments are printed as passed (e.g. as variable name instead of the evaluated content of that variable), if that is still too long it is cropped.
functionCallString(functionName, argumentValues)
functionCallString(functionName, argumentValues)
functionName |
name of the called function |
argumentValues |
the list of arguments passed |
A string representing the given function call
Pascal Sauer
This function can be used to retrieve a list of currently available sources and outputs (based on the availability of corresponding conversion functions in the loaded data data processing packages.)
getCalculations( prefix = "calc", packages = getConfig("packages"), globalenv = getConfig("globalenv") )
getCalculations( prefix = "calc", packages = getConfig("packages"), globalenv = getConfig("globalenv") )
prefix |
Type of calculations, vector of types or search term (e.g. "read|calc"). Available options are "download" (source download), "read" (source read), "correct" (source corrections), "convert" (source conversion to ISO countries), "calc" (further calculations), and "full" (collections of calculations) |
packages |
A character vector with packages for which the available Sources/Calculations should be returned |
globalenv |
Boolean deciding whether sources/calculations in the global environment should be included or not |
A data frame containing all currently available outputs of all loaded data processing packages including its name, its function call and its package origin.
Jan Philipp Dietrich
print(getCalculations()) print(getCalculations("read"))
print(getCalculations()) print(getCalculations("read"))
Extract function code from madrat-style functions in specified packages
getCode( packages = installedMadratUniverse(), globalenv = getConfig("globalenv") )
getCode( packages = installedMadratUniverse(), globalenv = getConfig("globalenv") )
packages |
A character vector with packages for which the available Sources/Calculations should be returned |
globalenv |
Boolean deciding whether sources/calculations in the global environment should be included or not |
A named vector with condensed function code
Jan Philipp Dietrich
This function returns the madrat config which is currently loaded. If no configuration has been loaded so far the configuration will be initialized with default settings or system settings (if available).
getConfig(option = NULL, raw = FALSE, verbose = TRUE, print = FALSE)
getConfig(option = NULL, raw = FALSE, verbose = TRUE, print = FALSE)
option |
The option for which the setting should be returned. If set to NULL all options are returned. |
raw |
If set to FALSE some settings will be calculated, e.g. if the cache folder is set to FALSE the full path will be calculated using the main folder, or if the verbosity is not set the default verbosity will be returned. If raw is set to TRUE settings are returned as they are currently stored. |
verbose |
boolean deciding whether status information/updates should be shown or not |
print |
if TRUE and verbose is TRUE a configuration overview will also get printed |
A config list with all settings currently set for the madrat package
getConfig
is primarily designed to make the overall madrat
configuration available to system tools of the madrat framework. There are
only a few exceptions for which configuration settings are also readable
from within a download-, read-, convert-, correct-, calc- or full-function.
These exceptions are the setting "debug" (which can be used to add additional
debug messages when active), the "tmpfolder" which can be used to temporarily
store data and the setting "hash" (which can only be accessed from within a
full function and can there be used to apply the identical hash algorithm for
other calculations in which hashing is being used).
Besides that "regionmapping" and "extramappings" can also be read from within
calc- and full-functions but their use is at least for the calc-functions
discouraged as it either might lead to incorrect caching behavior, or - if
implemented correctly - lead to significant slow-downs of overall calculations.
All other settings are currently still accessible but trigger a warning that
this option will soon be removed. So, please make sure that your code runs
without reading these options!
As a background note: Read access to these settings will be restricted as they
otherwise would allow access to code elements or data in a form which is
violating the overall madrat logic and thereby can lead to erroneous results.
Jan Philipp Dietrich
Returns information about dependencies of a madrat-based calc- read- or full-function.
getDependencies( name, direction = "in", graph = NULL, type = NULL, self = FALSE, ... )
getDependencies( name, direction = "in", graph = NULL, type = NULL, self = FALSE, ... )
name |
name of the function to be analyzed |
direction |
Character string, either “in”, “out”, "both", “full”, "din" or "dout". If “in” all sources feeding into the function are listed. If “out” consumer of the function are listed. If “both” the union of "in" and "out" is returned. If "full" the full network this function is connected to is shown, including indirect connections to functions which neither source nor consume the given function but serve as sources to other consumer functions. "din" and "dout" (short for "direct in" and "direct out") behave like "in" and "out" but only show direct calls in or from the function (ignoring the network of functions attached to it). |
graph |
A madrat graph as returned by |
type |
type filter. Only dependencies of that type will be returned. Currently available types are "calc", "read" and "tool" |
self |
boolean defining whether the function itself, which is analyzed, should be included in the output, or not |
... |
Additional arguments for |
Jan Philipp Dietrich
getCalculations
, getMadratGraph
, getMadratInfo
Support function which extracts flags from code. Flags are string literals in a function body, for example '"!# @pucArguments extra"'.
getFlags(code)
getFlags(code)
code |
A character vector with code from functions to be analyzed |
A list of found flag entries
Jan Philipp Dietrich
Helper function extract a metadata comment
getFromComment(x, name)
getFromComment(x, name)
x |
object the metadata should be extracted from |
name |
name of the metadata to be extracted (e.g. unit) |
Jan Philipp Dietrich
x <- as.magpie(1) getComment(x) <- c(" description: example description", " unit: kg") getFromComment(x, "unit") getFromComment(x, "description")
x <- as.magpie(1) getComment(x) <- c(" description: example description", " unit: kg") getFromComment(x, "unit") getFromComment(x, "description")
Function which returns the ISO list which is used as default for the input data preparation. It contains the countries to which all source data has to be up- or downscaled to.
getISOlist(type = "all", threshold = 1)
getISOlist(type = "all", threshold = 1)
type |
Determines what countries should be returned. "all" returns all countries, "important" returns all countries which are above the population threshold set in the configuration and "dispensable" returns all countries which are below the threshold. |
threshold |
Population threshold in million capita which determines whether the country is put into the "important" or "dispensable" class (default = 1 mio. people) |
vector of default ISO country codes.
Please always use this function instead of directly referring to the data object as the format in this data list might change in the future!
Jan Philipp Dietrich
head(getISOlist()) head(getISOlist("dispensable"))
head(getISOlist()) head(getISOlist("dispensable"))
Returns a function that creates a symlink, hardlink, junction, or copy of files and directories, depending on OS capabilities (usually symlinks are not supported on Windows).
getLinkFunction()
getLinkFunction()
A function with arguments "from" and "to" which should behave like file.symlink on all platforms.
Pascal Sauer
Returns names of packages in which functions matching the description are found
getLocation(name, packages = installedMadratUniverse(), globalenv = TRUE)
getLocation(name, packages = installedMadratUniverse(), globalenv = TRUE)
name |
name of the function to be found. Can be either the full name (e.g. "calcTauTotal"), or just the type name (e.g. "TauTotal"). |
packages |
A character vector with packages in which should be looked for the function |
globalenv |
Boolean deciding whether functions in the global environment should be included or not |
vector of packages in which a function matching the description could be found
Jan Philipp Dietrich
getCalculations
, getDependencies
Function returns the madrat graph of all linkages of full, calc, and read functions of the given madrat based packages. Linkages to subfunctions of read functions (i.e. download, correct or convert functions) are not listed separately, but collectively referred to through the corresponding read function.
getMadratGraph( packages = installedMadratUniverse(), globalenv = getConfig("globalenv") )
getMadratGraph( packages = installedMadratUniverse(), globalenv = getConfig("globalenv") )
packages |
A character vector with packages for which the available Sources/Calculations should be returned |
globalenv |
Boolean deciding whether sources/calculations in the global environment should be included or not |
A data frame with 4 columns: from (source function), from_package (package the source function originates from), to (function which is using the source), to_package (package of the using function)
Jan Philipp Dietrich
Collects and returns detailed information about the currently loaded network of madrat functions.
getMadratInfo(graph = NULL, cutoff = 5, extended = FALSE, ...)
getMadratInfo(graph = NULL, cutoff = 5, extended = FALSE, ...)
graph |
A madrat graph as returned by |
cutoff |
Integer introducing a cutoff of items to be returned for outputs which can become quite verbose. |
extended |
Will add additional outputs which has been removed from standard output due to limited usefulness. |
... |
Additional arguments for |
Jan Philipp Dietrich
getCalculations
, getMadratGraph
Read a madrat message from the madrat environment. The madrat environment behaves similar like global options, except that 1) messages will also be stored in cache files and restored when a cache file is being loaded and 2) messages are always stored in lists with messages split by function calls where the message was triggered.
getMadratMessage(name = NULL, fname = NULL)
getMadratMessage(name = NULL, fname = NULL)
name |
The category in which the message should be stored |
fname |
function name. If specified only messages belonging to the functions history will be returned (this includes entries from the function itself, but also entries from functions which were called by this function). |
Jan Philipp Dietrich
putMadratMessage("test", "This is a toast", fname = "readTau") getMadratMessage("test", fname = "calcTauTotal")
putMadratMessage("test", "This is a toast", fname = "readTau") getMadratMessage("test", fname = "calcTauTotal")
Functions checks for a global setting of the mainfolder (either by setting the environment variable "MADRAT_MAINFOLDER" or by setting the R option with the same name). If none of these is available the user will be asked for a directory. If this is not provided a temporary folder will be used.
getMainfolder(verbose = TRUE, .testmode = FALSE)
getMainfolder(verbose = TRUE, .testmode = FALSE)
verbose |
boolean deciding whether status information/updates should be shown or not |
.testmode |
boolean switch only relevant for internal testing (will simulate user inputs) |
Jan Philipp Dietrich
initializeConfig
, getConfig
, setConfig
Given a function and an argument list, identify which arguments are different from their default.
getNonDefaultArguments(call, args = NULL)
getNonDefaultArguments(call, args = NULL)
call |
A function name as a string or symbol. Passing a vector of functions is possible, but is only intended for corresponding read/correct/convert functions. If multiple functions in a vector define arguments with the same name but different default values only the default defined in the first function is considered. |
args |
A list of named arguments used to call the given function(s). If duplicates of arguments exists the first occurrence of the argument will be used. |
A subset of args that is used by the function/s and is different from default values.
Jan Philipp Dietrich
cacheArgumentsHash
, toolstartmessage
madrat:::getNonDefaultArguments("madrat:::readTau", args = list(subtype = "historical")) madrat:::getNonDefaultArguments("madrat:::readTau", args = list(subtype = "paper")) calls <- c(madrat:::readTau, madrat:::convertTau) madrat:::getNonDefaultArguments(calls, args = list(subtype = "historical"))
madrat:::getNonDefaultArguments("madrat:::readTau", args = list(subtype = "historical")) madrat:::getNonDefaultArguments("madrat:::readTau", args = list(subtype = "paper")) calls <- c(madrat:::readTau, madrat:::convertTau) madrat:::getNonDefaultArguments(calls, args = list(subtype = "historical"))
Return the path to source data files for the given type and subtype. This
applies redirections, see redirectSource
for more details.
getSourceFolder(type, subtype)
getSourceFolder(type, subtype)
type |
Dataset name, e.g. "Tau" for |
subtype |
Subtype of the dataset, e.g. "paper" for |
Path to source data files
Pascal Sauer
These functions can be used to retrieve a list of currently available sources and outputs (based on the availability of corresponding conversion functions in the loaded data data processing packages.)
getSources( name = NULL, type = NULL, packages = getConfig("packages"), globalenv = getConfig("globalenv") )
getSources( name = NULL, type = NULL, packages = getConfig("packages"), globalenv = getConfig("globalenv") )
name |
name of function for which sources should get returned. If not specified, all sources in the specified environment are returned |
type |
Type of source, either set to "read", "convert", "correct", "download" or NULL. If specified, a vector containing the sources with the corresponding function type are returned, otherwise a data.frame with all sources and their available function types is returned. |
packages |
A character vector with packages for which the available Sources/Calculations should be returned |
globalenv |
Boolean deciding whether sources/calculations in the global environment should be included or not |
A vector or data.frame containing all corresponding sources
Please be aware that these functions only check the availability of corresponding functions of the package, not whether the functions will properly work.
Jan Philipp Dietrich
print(getSources())
print(getSources())
Checks whether configuration already has been set. If not, it will be initialized
with default settings or (if available) system settings. All madrat folders (see
setConfig
for documentation which folders are available) will be set
to the system environment variables MADRAT_SOURCEFOLDER, MADRAT_CACHEFOLDER, etc.
if they exist, NA otherwise. NA means subfolders of the mainfolder are used.
initializeConfig(verbose = TRUE)
initializeConfig(verbose = TRUE)
verbose |
boolean deciding whether status information/updates should be shown or not |
Jan Philipp Dietrich
getMainfolder
, getConfig
, setConfig
Returns a name vector of installed packages which supposedly belong to the madrat universe. They are currently derived as the union of
all packages registered under getConfig("packages")
,
all packages with a name starting with "mr" or "ms" (as the usual indicator for madrat-packages and madrat-support-packages), and
all packages having madrat
as either a Depends
or Imports
dependency.
installedMadratUniverse()
installedMadratUniverse()
A name vector of installed packages which supposedly belong to the madrat universe
Jan Philipp Dietrich
## Not run: installedMadratUniverse() ## End(Not run)
## Not run: installedMadratUniverse() ## End(Not run)
Support functions which checks whether a given wrapper function is currently in-use or not or which locally activate or deactivate a wrapper (setting will be automatically resetted when a function finishes).
isWrapperActive(name) setWrapperActive(name) setWrapperInactive(name)
isWrapperActive(name) setWrapperActive(name) setWrapperInactive(name)
name |
name of the wrapper in question (e.g. "calcOutput") |
setWrapperActive()
: set wrapper activity status to on
setWrapperInactive()
: set wrapper activity status to off
Jan Philipp Dietrich
This function is defunct and will be completely removed soon.
madapply(...)
madapply(...)
... |
placeholder |
Jan Philipp Dietrich
This function is defunct and will be completely removed soon.
madlapply(...)
madlapply(...)
... |
placeholder |
Jan Philipp Dietrich
Attaches the madrat functions of a package to the currently active madrat universe or detaches it again from it.
madratAttach(package) madratDetach(package)
madratAttach(package) madratDetach(package)
package |
name of the package to be loaded. Alternative, the path to the package. |
madratDetach()
: detach package from madrat universe
Jan Philipp Dietrich
## Not run: madratAttach("madrat") ## End(Not run)
## Not run: madratAttach("madrat") ## End(Not run)
returns a temporary directory as a subfolder of the tempfolder set in
getConfig("tmpfolder")
.
madTempDir()
madTempDir()
path to the temp folder
Jan Philipp Dietrich
## Not run: madrat:::madTempDir() ## End(Not run)
## Not run: madrat:::madTempDir() ## End(Not run)
Function to extract metadata information of a data set hosted at GFZ dataservices (https://dataservices.gfz-potsdam.de/portal/).
metadataGFZ(doi)
metadataGFZ(doi)
doi |
DOI of a data set hosted at GFZ dataservices |
a list with entries "license", "citation", "authors" and "year"
Jan Philipp Dietrich
## Not run: metadataGFZ("10.5880/pik.2019.004") ## End(Not run)
## Not run: metadataGFZ("10.5880/pik.2019.004") ## End(Not run)
Helper function to properly format a metadata comment entry
prepComment(x, name, warning = NULL)
prepComment(x, name, warning = NULL)
x |
content to be added as metadata comment |
name |
Name of the metadata entry |
warning |
Either NULL (no warning) or a warning text that should be returned if x is NULL |
Jan Philipp Dietrich
madrat:::prepComment("example comment", "example")
madrat:::prepComment("example comment", "example")
Helper function condense metadata information into an extended comment entry
prepExtendedComment(x, type, functionCallString, warn = TRUE)
prepExtendedComment(x, type, functionCallString, warn = TRUE)
x |
list containing the metadata to be condensed |
type |
output type, e.g. "TauTotal" |
functionCallString |
A string representation of the function call that created the object this comment is attached to |
warn |
boolean indicating whether warnings should be triggered if entries are missing, or not. |
Jan Philipp Dietrich, Pascal Sauer
Function to prepare a function call for a given type and prefix
prepFunctionName(type, prefix = "calc", ignore = NULL, error_on_missing = TRUE)
prepFunctionName(type, prefix = "calc", ignore = NULL, error_on_missing = TRUE)
type |
name of calculation/source |
prefix |
Type of calculations. Available options are "download" (source download), "read" (source read), "correct" (source corrections), "convert" (source conversion to ISO countries), "calc" (further calculations), and "full" (collections of calculations) |
ignore |
vector of arguments which should be ignored (not be part of the function call) |
error_on_missing |
boolean deciding whether a missing type should throw an error or return NULL |
A function call as character to the specified function with corresponding package as attribute
Jan Philipp Dietrich
print(madrat:::prepFunctionName("Tau", "read")) print(madrat:::prepFunctionName("TauTotal", "calc")) print(madrat:::prepFunctionName("EXAMPLE", "full"))
print(madrat:::prepFunctionName("Tau", "read")) print(madrat:::prepFunctionName("TauTotal", "calc")) print(madrat:::prepFunctionName("EXAMPLE", "full"))
Function which takes a puc-file ("portable unaggregated collection") as created
via retrieveData
and computes the corresponding aggregated
collection with the provided arguments (e.g. the provided region mapping).
The resulting tgz-file containing the collection will be put to the
madrat outputfolder as defined in getConfig("outputfolder")
.
pucAggregate( puc, regionmapping = getConfig("regionmapping"), ..., renv = TRUE, strict = FALSE )
pucAggregate( puc, regionmapping = getConfig("regionmapping"), ..., renv = TRUE, strict = FALSE )
puc |
path to a puc-file |
regionmapping |
region mapping to be used for aggregation. |
... |
(Optional) Settings that should be changed in addition. NOTE: which settings can be modified varies from puc to puc. Allowed settings are typically listed in the file name of the puc file after the revision number. |
renv |
Boolean which determines whether data should be aggregated from
within a renv environment (recommended) or not. If activated, |
strict |
Boolean or NULL which allows to trigger a strict mode. During strict mode
warnings will be taken more seriously and will cause 1. to have the number of
warnings as prefix of the created tgz file and 2. will prevent |
Jan Philipp Dietrich
## Not run: pucAggregate("rev1_example.puc", regionmapping = "regionmappingH12.csv") ## End(Not run)
## Not run: pucAggregate("rev1_example.puc", regionmapping = "regionmappingH12.csv") ## End(Not run)
Store a madrat message in the madrat environment. The madrat environment behaves similar like global options, except that 1) messages will also be stored in cache files and restored when a cache file is being loaded and 2) messages are always stored in lists with messages split by function calls where the message was triggered.
putMadratMessage(name, value, fname = -1, add = FALSE)
putMadratMessage(name, value, fname = -1, add = FALSE)
name |
The category in which the message should be stored |
value |
The message that should be recorded as character. Alternatively,
if |
fname |
function name the entry belongs to or the frame number from which the function name should be derived from (e.g. -1 to recieve function name from parent function). |
add |
boolean deciding whether the value should be added to a existing value (TRUE) or overwrite it (FALSE) |
Jan Philipp Dietrich
putMadratMessage("test", "This is a toast", fname = "readTau") getMadratMessage("test", fname = "calcTauTotal")
putMadratMessage("test", "This is a toast", fname = "readTau") getMadratMessage("test", fname = "calcTauTotal")
Read in a source file and convert it to a MAgPIE object. The function is a wrapper for specific functions designed for the different possible source types.
readSource( type, subtype = NULL, subset = NULL, convert = TRUE, supplementary = FALSE )
readSource( type, subtype = NULL, subset = NULL, convert = TRUE, supplementary = FALSE )
type |
A character string referring to the source type, e.g. "IEA" which would
internally call a function called 'readIEA' (the "wrapped function"). A list of
available source types can be retrieved with function |
subtype |
A character string. For some sources there are subtypes of the source, for these sources the subtype can be specified with this argument. If a source does not have subtypes, subtypes should not be set. |
subset |
A character string. Similar to |
convert |
Boolean indicating whether input data conversion to ISO countries should be done or not. In addition it can be set to "onlycorrect" for sources with a separate correctXXX-function. |
supplementary |
Boolean deciding whether a list including the actual data and metadata, or just the actual data is returned. |
The read-in data, usually a magpie object. If supplementary is TRUE a list including the data and metadata is returned instead. The temporal and data dimensionality should match the source data. The spatial dimension should either match the source data or, if the convert argument is set to TRUE, should be on ISO code country level.
If a magpie object is returned magclass::clean_magpie is run and if convert = TRUE ISO code country level is checked.
Jan Philipp Dietrich, Anastasis Giannousakis, Lavinia Baumstark, Pascal Sauer
setConfig
, downloadSource
, readTau
#' @note The underlying read-functions can return a magpie object or a list of information
(preferred) back to readSource
. In list format the object should have the following
structure:
x - the data itself as magclass object
unit (optional) - unit of the provided data
description (otional) - a short description of the data
note (optional) - additional notes related to the data
class (optional | default = "magpie") - Class of the returned object. If set to something other than "magpie" most functionality will not be available and is switched off!
cache (optional) boolean which decides whether a cache file should be written (if caching is active) or not. Default setting is TRUE. This can be for instance useful, if the calculation itself is quick, but the corresponding file sizes are huge. Or if the caching for the given data type does not support storage in RDS format. CAUTION: Deactivating caching for a data set which should be part of a PUC file will corrupt the PUC file. Use with care.
## Not run: a <- readSource("Tau", "paper") ## End(Not run)
## Not run: a <- readSource("Tau", "paper") ## End(Not run)
Read-in landuse intensity data (tau) following the methodology published in Dietrich J.P., Schmitz C., Mueller C., Fader M., Lotze-Campen H., Popp A., Measuring agricultural land-use intensity - A global analysis using a model-assisted approach, Ecological Modelling, Volume 232, 10 May 2012, Pages 109-118, ISSN 0304-3800, 10.1016/j.ecolmodel.2012.03.002.
readTau(subtype = "paper")
readTau(subtype = "paper")
subtype |
Type of Tau data that should be read. Available types are:
|
Tau data and weights as MAgPIE object in original resolution
Jan Philipp Dietrich
## Not run: a <- readSource("Tau") ## End(Not run)
## Not run: a <- readSource("Tau") ## End(Not run)
Redirect a given dataset type to a different source folder. The redirection is local, so it will be reset when the current function call returns. See example for more details.
redirect(type, target, linkOthers = TRUE, local = TRUE)
redirect(type, target, linkOthers = TRUE, local = TRUE)
type |
Dataset name, e.g. "Tau" for |
target |
Either path to the new source folder that should be used instead of the default, or NULL to remove the redirection, or a vector of paths to files which are then symlinked into a temporary folder that is then used as target folder; if the vector is named the names are used as relative paths in the temporary folder, e.g. target = c('a/b/c.txt' = "~/d/e/f.txt") would create a temporary folder with subfolders a/b and there symlink c.txt to ~/d/e/f.txt. |
linkOthers |
If target is a list of files, whether to symlink all other files in the original source folder to the temporary folder. |
local |
The scope of the redirection, passed on to setConfig. Defaults to the current function. Set to an environment for more control or to FALSE for a permanent/global redirection. |
Invisibly, the source folder that is now used for the given type
Pascal Sauer
## Not run: f <- function() { redirect("Tau", target = "~/TauExperiment") # the following call will change directory # into ~/TauExperiment instead of <getConfig("sourcefolder")>/Tau readSource("Tau") } f() # Tau is only redirected in the local environment of f, # so it will use the usual source folder here readSource("Tau") ## End(Not run)
## Not run: f <- function() { redirect("Tau", target = "~/TauExperiment") # the following call will change directory # into ~/TauExperiment instead of <getConfig("sourcefolder")>/Tau readSource("Tau") } f() # Tau is only redirected in the local environment of f, # so it will use the usual source folder here readSource("Tau") ## End(Not run)
redirectSource will call a source specific redirect function if it exists
(called e.g. redirectTau), in which case the arguments are passed on to that
function. If such a function is not available redirect
is called.
redirectSource(type, target, ..., linkOthers = TRUE, local = TRUE)
redirectSource(type, target, ..., linkOthers = TRUE, local = TRUE)
type |
The source dataset type. Passed on to the specific redirect
function or |
target |
The target folder or files. Passed on to the specific redirect
function or |
... |
Additional arguments, passed on to the specific redirect function. |
linkOthers |
Passed on to the specific redirect function or |
local |
Passed on to the specific redirect function or |
The result of the specific redirect function or redirect
.
Pascal Sauer
redirectTau will be called by redirectSource when type = "Tau". Redirects the Tau source folder to the target folder.
redirectTau(target, ...)
redirectTau(target, ...)
target |
The target folder or files. |
... |
Passed on to |
Pascal Sauer
## Not run: redirectSource("Tau", "a/different/tau-source-folder") a <- readSource("Tau", "paper") ## End(Not run)
## Not run: redirectSource("Tau", "a/different/tau-source-folder") a <- readSource("Tau", "paper") ## End(Not run)
Given a regionmapping (mapping between ISO countries and regions) the function calculates a regionscode which is basically the md5sum of a reduced form of the mapping. The regionscode is unique for each regionmapping and can be used to clearly identify a given regionmapping. In addition several checks are performed to make sure that the given input is a proper regionmapping
regionscode(mapping = NULL, label = FALSE, strict = TRUE)
regionscode(mapping = NULL, label = FALSE, strict = TRUE)
mapping |
Either a path to a mapping or an already read-in mapping as data.frame. If set to NULL (default) the regionscode of the region mapping set in the madrat config will be returned. |
label |
logical deciding whether the corresponding label of a regionscode should be returned instead of the regionscode. |
strict |
If set to TRUE region mappings with mapping to ISO countries with exactly 2 columns or more than 2 colums (if the first colum contains irrelevant information which will be deleted automatically) will be accepted. In this case data will be transformed and even cases with different ordering will yield the same regionscode. If set to FALSE all these checks will be ignored and the regionscode will be just computed on the object as it is. Please be aware the regionscode will differ with strict mode on or off! |
A md5-based regionscode which describes the given mapping or, if label=TRUE
and a corresponding label is available, the label belonging to the regionscode
Jan Philipp Dietrich
toolCodeLabels
, fingerprint
, digest
file <- system.file("extdata", "regionmappingH12.csv", package = "madrat") regionscode(file)
file <- system.file("extdata", "regionmappingH12.csv", package = "madrat") regionscode(file)
Delete stored madrat messages from the madrat environment. The madrat environment behaves similar like global options, except that 1) messages will also be stored in cache files and restored when a cache file is being loaded and 2) messages are always stored in lists with messages split by function calls where the message was triggered.
resetMadratMessages(name = NULL, fname = NULL)
resetMadratMessages(name = NULL, fname = NULL)
name |
The category for which the messages should be reset (if not set messages in all categories will be reset) |
fname |
function name for which the entries should be reset (if not specified messages for all function names will be reset) |
Jan Philipp Dietrich
putMadratMessage
, getMadratMessage
putMadratMessage("test", "This is a toast", fname = "readTau") getMadratMessage("test", fname = "calcTauTotal") resetMadratMessages("test")
putMadratMessage("test", "This is a toast", fname = "readTau") getMadratMessage("test", fname = "calcTauTotal") resetMadratMessages("test")
Function to retrieve a predefined collection of calculations for a specific regionmapping.
retrieveData( model, rev = 0, dev = "", cachetype = "def", puc = identical(dev, ""), strict = FALSE, renv = TRUE, ... )
retrieveData( model, rev = 0, dev = "", cachetype = "def", puc = identical(dev, ""), strict = FALSE, renv = TRUE, ... )
model |
The names of the model for which the data should be provided (e.g. "magpie"). |
rev |
data revision which should be used/produced. Will be converted to
|
dev |
development suffix to distinguish development versions for the same data revision. This can be useful to distinguish parallel lines of development. |
cachetype |
defines what cache should be used. "rev" points to a cache shared by all calculations for the given revision and sets forcecache to TRUE, "def" points to the cache as defined in the current settings and does not change forcecache setting. |
puc |
Boolean deciding whether a fitting puc file (if existing) should be read in and if a puc file (if not already existing) should be created. |
strict |
Boolean which allows to trigger a strict mode. During strict mode
warnings will be taken more seriously and will cause 1. to have the number of
warnings as prefix of the created tgz file and 2. will prevent |
renv |
Boolean which determines whether calculations should run
within a renv environment (recommended) or not (currently only applied in
|
... |
(Optional) Settings that should be changed using |
Invisibly, the path to the newly created tgz archive.
The underlying full-functions can optionally provide a list of information back to
retrieveData
. Following list entries are currently supported:
tag (optional) - additional name tag which will be included in the file name of the aggregated collection (resulting tgz-file). This can be useful to highlight information in the file name which otherwise would not be visible.
pucTag (optional) - identical purpose as tag but for the resulting unaggregated collections (puc-files).
Jan Philipp Dietrich, Lavinia Baumstark
## Not run: retrieveData("example", rev = "2.1.1", dev = "test", regionmapping = "regionmappingH12.csv") ## End(Not run)
## Not run: retrieveData("example", rev = "2.1.1", dev = "test", regionmapping = "regionmappingH12.csv") ## End(Not run)
robustOrder: A wrapper around base::order that always uses the locale independent method = "radix". If the argument x is a character vector it is converted to utf8 first. robustSort: A convenience function using order to sort a vector using radix sort. The resulting vector will have the same encoding as the input although internally character vectors are converted to utf8 before ordering.
robustOrder(..., na.last = TRUE, decreasing = FALSE, method = "radix")
robustOrder(..., na.last = TRUE, decreasing = FALSE, method = "radix")
... |
One or more vectors of the same length |
na.last |
If TRUE missing values are put last, if FALSE they are put first, if NA they are removed |
decreasing |
If TRUE decreasing/descending order, if FALSE increasing/ascending order. For the "radix" method, this can be a vector of length equal to the number of arguments in ... . For the other methods, it must be length one. |
method |
Default is "radix", which is locale independent. The alternatives "auto" and "shell" should not be used in madrat because they are locale dependent. |
Pascal Sauer
This function manipulates the current madrat configuration. In general, NULL means that the argument remains as it is whereas all other inputs will overwrite the current setting. For values which can be reset to NULL (currently only "extramappings") you can achieve a reset by setting the value to "".
setConfig( regionmapping = NULL, extramappings = NULL, packages = NULL, globalenv = NULL, enablecache = NULL, verbosity = NULL, mainfolder = NULL, sourcefolder = NULL, cachefolder = NULL, mappingfolder = NULL, outputfolder = NULL, pucfolder = NULL, tmpfolder = NULL, nolabels = NULL, forcecache = NULL, ignorecache = NULL, cachecompression = NULL, hash = NULL, diagnostics = NULL, debug = NULL, maxLengthLogMessage = NULL, redirections = NULL, .cfgchecks = TRUE, .verbose = TRUE, .local = FALSE ) localConfig(...)
setConfig( regionmapping = NULL, extramappings = NULL, packages = NULL, globalenv = NULL, enablecache = NULL, verbosity = NULL, mainfolder = NULL, sourcefolder = NULL, cachefolder = NULL, mappingfolder = NULL, outputfolder = NULL, pucfolder = NULL, tmpfolder = NULL, nolabels = NULL, forcecache = NULL, ignorecache = NULL, cachecompression = NULL, hash = NULL, diagnostics = NULL, debug = NULL, maxLengthLogMessage = NULL, redirections = NULL, .cfgchecks = TRUE, .verbose = TRUE, .local = FALSE ) localConfig(...)
regionmapping |
The name of the csv file containing the region mapping that should be used for aggregation (e.g. "regionmappingREMIND.csv"). |
extramappings |
Names of additional mappings supplementing the given region mapping. This allows for additional aggregation levels such as subnational aggregation. |
packages |
A character vector with packages in which corresponding read and calc functions should be searched for |
globalenv |
Boolean deciding whether sources/calculations in the global environment should be included or not |
enablecache |
Is deprecated and will be ignored. Please use
|
verbosity |
an integer value describing the verbosity of the functions (2 = full information, 1 = only warnings and execution information, 0 = only warnings, -1 = no information) |
mainfolder |
The mainfolder where all data can be found and should be written to. |
sourcefolder |
The folder in which all source data is stored (in sub-folders with the name of the source as folder name). In the default case this argument is set to NA meaning that the default folder should be used which is <mainfolder>/sources |
cachefolder |
The folder in which all cache files should be written to. In the default case this argument is set to NA meaning that the default folder should be used which is <mainfolder>/cache |
mappingfolder |
A folder containing all kinds of mappings (spatial, temporal or sectoral). In the default case this argument is set to NA meaning that the default folder should be used which is <mainfolder>/mappings |
outputfolder |
The folder all outputs should be written to. In the default case this argument is set to NA meaning that the default folder should be used which is <mainfolder>/output |
pucfolder |
The path where portable unaggregated collection (puc) files are located. NA by default, which means <mainfolder>/puc |
tmpfolder |
Path to a temp folder for temporary storage of files. By default set to <mainfolder>/tmp |
nolabels |
vector of retrieve models (e.g. "EXAMPLE" in case of "fullEXAMPLE") which should NOT apply a replacement of known hashes with given code labels |
forcecache |
Argument that allows to force madrat to read data from cache if the corresponding cache files exist. It is either a boolean to fully activate or deactivate the forcing or a vector of files (e.g. readTau, calcTauTotal) or type (e.g. Tau, TauTotal) that should be read from cache in any case. |
ignorecache |
Argument that allows madrat to ignore the forcecache argument for the given vector of files (e.g. readTau, calcTauTotal) or types (e.g. Tau, TauTotal) called by calcOutput or readSource. The top level function must always be part of this list. |
cachecompression |
logical or character string specifying whether cache files use compression. TRUE corresponds to gzip compression, and character strings "gzip", "bzip2" or "xz" specify the type of compression. |
hash |
specifies the used hashing algorithm. Default is "xxhash32" and
all algorithms supported by |
diagnostics |
Either FALSE (default) to avoid the creation of additional log files or a file name for additional diagnostics information (without file ending). |
debug |
Boolean which activates a debug mode. In debug mode all calculations will be executed with try=TRUE so that calculations do not stop even if the previous calculation failed. This can be helpful to get a full picture of errors rather than only seeing the first one. In addition debug=TRUE will add the suffix "debug" to the files created to avoid there use in productive runs. Furthermore, with debug=TRUE calculations will be rerun even if a corresponding tgz file already exists. |
maxLengthLogMessage |
in log messages evaluated arguments are printed if the resulting message is shorter than this value, otherwise arguments are shown as passed, potentially with unevaluated variable names |
redirections |
A list of source folder redirections, intended to be set
by |
.cfgchecks |
boolean deciding whether the given inputs to setConfig should be checked for consistency or just be accepted (latter is only necessary in very rare cases and should not be used in regular cases) |
.verbose |
boolean deciding whether status information/updates should be shown or not |
.local |
boolean deciding whether options are only changed until the end of the current function execution OR environment for which the options should get changed. |
... |
Arguments forwarded to setConfig |
localConfig()
: A wrapper for setConfig(..., .local = TRUE)
setConfig
must only be used before the data processing is started and changes in the configuration
from within a download-, read-, correct-, convert-, calc-, or full-function are not allowed! Only allowed
configuration update is to add another extramapping
via addMapping
.
Currently the use of setConfig
within any of these functions will trigger a warning, which is planned
to be converted into an error message in one of the next package updates!
Jan Philipp Dietrich
## Not run: setConfig(forcecache = c("readSSPall", "convertSSPall")) ## End(Not run)
## Not run: setConfig(forcecache = c("readSSPall", "convertSSPall")) ## End(Not run)
(Dis-)aggregates a magclass object from one resolution to another based on a relation matrix or mapping
toolAggregate( x, rel, weight = NULL, from = NULL, to = NULL, dim = 1, wdim = NULL, partrel = FALSE, negative_weight = "warn", mixed_aggregation = FALSE, verbosity = 1, zeroWeight = "warn" )
toolAggregate( x, rel, weight = NULL, from = NULL, to = NULL, dim = 1, wdim = NULL, partrel = FALSE, negative_weight = "warn", mixed_aggregation = FALSE, verbosity = 1, zeroWeight = "warn" )
x |
magclass object that should be (dis-)aggregated |
rel |
relation matrix, mapping or file containing a mapping in a format
supported by |
weight |
magclass object containing weights which should be considered for a weighted aggregation. The provided weight should only contain positive values, but does not need to be normalized (any positive number>=0 is allowed). Please see the "details" section below for more information. |
from |
Name of source column to be used in rel if it is a mapping (if not set the first column matching the data will be used). |
to |
Name of the target column to be used in rel if it is a
mapping (if not set the column following column |
dim |
Specifying the dimension of the magclass object that should be (dis-)aggregated. Either specified as an integer (1=spatial,2=temporal,3=data) or if you want to specify a sub dimension specified by name of that dimension or position within the given dimension (e.g. 3.2 means the 2nd data dimension, 3.8 means the 8th data dimension). |
wdim |
Specifying the according weight dimension as chosen with dim for the aggregation object. If set to NULL the function will try to automatically detect the dimension. |
partrel |
If set to TRUE allows that the relation matrix does contain less entries than x and vice versa. These values without relation are lost in the output. |
negative_weight |
Describes how a negative weight should be treated. "allow" means that it just should be accepted (dangerous), "warn" returns a warning and "stop" will throw an error in case of negative values |
mixed_aggregation |
boolean which allows for mixed aggregation (weighted mean mixed with summations). If set to TRUE weight columns filled with NA will lead to summation. |
verbosity |
Verbosity level of messages coming from the function: -1 = error, 0 = warning, 1 = note, 2 = additional information, >2 = no message |
zeroWeight |
Describes how a weight sum of 0 for a category/aggregation target should be treated. "allow" accepts it and returns 0 (dangerous), "setNA" returns NA, "warn" throws a warning, "stop" throws an error. |
Basically toolAggregate is doing nothing more than a normal matrix multiplication which is taking into account the 3 dimensional structure of MAgPIE objects. So, you can provide any kind of relation matrix you would like. However, for easier usability it is also possible to provide weights for a weighted (dis-)aggregation as a MAgPIE object. In this case rel must be a 1-0-matrix or a mapping between both resolutions. The weight needs to be provided in the higher spatial aggregation, meaning for aggregation the spatial resolution of your input data and in the case of disaggregation the spatial resolution of your output data. The temporal and data dimension must be either identical to the resolution of the data set that should be (dis-)aggregated or 1. If the temporal and/or data dimension is 1 this means that the same transformation matrix is applied for all years and/or all data columns. In the case that a column should be just summed up instead of being calculated as a weighted average you either do not provide any weight (then all columns are just summed up) or your set this specific weighting column to NA and mixed_aggregation to TRUE.
the aggregated data in magclass format
Jan Philipp Dietrich, Ulrich Kreidenweis
# create example mapping p <- magclass::maxample("pop") mapping <- data.frame(from = magclass::getItems(p, dim = 1.1), region = rep(c("REG1", "REG2"), 5), global = "GLO") print(mapping) # run aggregation toolAggregate(p, mapping) # weighted aggregation toolAggregate(p, mapping, weight = p) # combined aggregation across two columns toolAggregate(p, mapping, to = "region+global")
# create example mapping p <- magclass::maxample("pop") mapping <- data.frame(from = magclass::getItems(p, dim = 1.1), region = rep(c("REG1", "REG2"), 5), global = "GLO") print(mapping) # run aggregation toolAggregate(p, mapping) # weighted aggregation toolAggregate(p, mapping, weight = p) # combined aggregation across two columns toolAggregate(p, mapping, to = "region+global")
This function replaces a hash code (e.g. regioncode) or another cryptic code with a human readable code via a given dictionary. This can be useful to make outputs better readable in cases where hash codes are already known to the user. If no entry exists in the dictionary the hash code is returned again.
toolCodeLabels(get = NULL, add = NULL)
toolCodeLabels(get = NULL, add = NULL)
get |
A vector of hash codes which should be replaced |
add |
Additional entries that should be added to the dictionary. Need to be provided in the form of a named vector with the structure c(<label>=<hash>), e.g. c(h12="62eff8f7") |
A vector with either labels (if available) or hash codes (if no label was available).
Jan Philipp Dietrich
toolCodeLabels("62eff8f7")
toolCodeLabels("62eff8f7")
Sets values (NA, negative, ..) to value replaceby
toolConditionalReplace(x, conditions, replaceby = 0)
toolConditionalReplace(x, conditions, replaceby = 0)
x |
magpie object |
conditions |
vector of conditions for values, that should be removed e.g. "is.na()", "< 0" (order matters) |
replaceby |
value which should be used instead (can be a vector of same length as conditions as well) |
return changed input data
Kristine Karstens
Function which converts mapping files between formats
toolConvertMapping(name, format = "rds", type = NULL, where = "mappingfolder")
toolConvertMapping(name, format = "rds", type = NULL, where = "mappingfolder")
name |
File name of the mapping file. Supported file types are currently csv (, or ; separated), rds and rda (which needs to have the data stored with the object name "data"!). |
format |
format it should be converted to. Available is "csv", "rds" or "rda". |
type |
Mapping type (e.g. "regional", "cell", or "sectoral"). Can be set to NULL if file is not stored in a type specific subfolder |
where |
location to look for the mapping, either "mappingfolder" or the name of a package which contains the mapping |
Jan Philipp Dietrich
calcOutput
, toolConvertMapping
Function used to convert country names from the long name to the ISO 3166-1 alpha 3 country code
toolCountry2isocode( country, warn = TRUE, ignoreCountries = NULL, type = NULL, mapping = NULL )
toolCountry2isocode( country, warn = TRUE, ignoreCountries = NULL, type = NULL, mapping = NULL )
country |
A vector of country names |
warn |
whether warnings should be printed now or in the end of the whole process as notes |
ignoreCountries |
A vector of country names/codes that exist in the data and that should be removed but without creating a warning (they will be removed in any case). You should use that argument if you are certain that the given entries should be actually removed from the data. |
type |
deprecated and will be removed soon! |
mapping |
additional mappings as a names vector |
the ISO 3166-1 alpha 3 country code
Jan Philipp Dietrich, Anastasis Giannousakis
toolCountry2isocode("Germany") toolCountry2isocode(c("Germany","Fantasyland"),mapping=c("Fantasyland"="BLA"))
toolCountry2isocode("Germany") toolCountry2isocode(c("Germany","Fantasyland"),mapping=c("Fantasyland"="BLA"))
This function expects a MAgPIE object with ISO country codes in the spatial dimension. These ISO codes are compared with the official ISO code country list (stored as supplementary data in the madrat package). If there is an ISO code in the data but not in the official list this entry is removed, if an entry of the official list is missing in the data this entry is added and set to the value of the argument fill.
toolCountryFill( x, fill = NA, no_remove_warning = NULL, overwrite = FALSE, verbosity = 1, countrylist = NULL, ... )
toolCountryFill( x, fill = NA, no_remove_warning = NULL, overwrite = FALSE, verbosity = 1, countrylist = NULL, ... )
x |
MAgPIE object with ISO country codes in the spatial dimension |
fill |
Number which should be used for filling the gaps of missing countries. |
no_remove_warning |
A vector of non-ISO country codes that exist in the data and that should be removed by CountryFill but without creating a warning (they will be removed in any case). You should use that argument if you are certain that the given entries should be actually removed from the data. |
overwrite |
logical deciding whether existing data should be overwritten, if there is a specific mapping provided for that country, or not |
verbosity |
verbosity for information about filling important countries. 0 = warning will show up (recommended if filling of important countries is not expected), 1 = note will show up in reduced log file (default), 2 = info will show up in extended log file (recommended if filling of important countries is not critical and desired). |
countrylist |
character vector of official country names (if other than ISO) |
... |
Mappings between countries for which the data is missing and countries from which the data should be used instead for these countries (e.g. "HKG"="CHN" if Hong Kong should receive the value of China). This replacement usually only makes sense for intensive values. Can be also provided as a argument called "map" which contains a named vector of these mappings. |
A MAgPIE object with spatial entries for each country of the official ISO code country list.
Jan Philipp Dietrich
library(magclass) x <- new.magpie("DEU", 1994, "bla", 0) y <- toolCountryFill(x, 99)
library(magclass) x <- new.magpie("DEU", 1994, "bla", 0) y <- toolCountryFill(x, 99)
This function writes a process end message and performs some diagnostics. It is always called after a corresponding
call to toolstartmessage
.
toolendmessage(startdata, level = NULL)
toolendmessage(startdata, level = NULL)
startdata |
a list containing diagnostic information provided by |
level |
This argument allows to establish a hierarchy of print statements. The hierarchy is preserved for the next vcat executions. Currently this setting can have 4 states: NULL (nothing will be changed), 0 (reset hierarchies), "+" (increase hierarchy level by 1) and "-" (decrease hierarchy level by 1). |
Jan Philipp Dietrich
This function fills missing values for countries with the (weighted) average of the respective region. The average is computed separately for every timestep. Currently only inputs with one data dimension are allowed as inputs. (If the filling should be performed over multiple data dimensions, call this function multiple times and bind the results together with magclass::mbind.)
toolFillWithRegionAvg( x, valueToReplace = NA, weight = NULL, callToolCountryFill = FALSE, regionmapping = NULL, verbose = TRUE, warningThreshold = 0.5, noteThreshold = 1 )
toolFillWithRegionAvg( x, valueToReplace = NA, weight = NULL, callToolCountryFill = FALSE, regionmapping = NULL, verbose = TRUE, warningThreshold = 0.5, noteThreshold = 1 )
x |
MAgPIE object with country codes in the first and time steps in the second dimension. |
valueToReplace |
value that denotes missing data. Defaults to NA. |
weight |
MAgPIE object with weights for the weighted average. Must contain at least all the countries and years present in x. If no weights are specified, an unweighted average is performed. |
callToolCountryFill |
Boolean variable indicating whether the list of countries should first be filled to the official ISO code country list. Subsequently the newly added and previously missing values are filled with the region average. |
regionmapping |
Data frame containing the mapping between countries and regions. Expects column names CountryCode and RegionCode. Uses the currently set mapping if no mapping is specified. |
verbose |
Boolean variable indicating if the function should print out what it is doing. Can generate a lot of output for a large object. |
warningThreshold |
If more than this fraction of the countries in a given region and timestep have a missing value, throw a warning. |
noteThreshold |
If more than this fraction of the countries in a given region and timestep have a missing value, a note will be written. |
toolFillWithRegionAvg can be used in conjunction with toolCountryFill() to first fill up the list of countries to the official ISO code country list, and then fill values with the regional average (see callToolCountryFill Option).
A MAgPIE object with the missing values filled.
Bjoern Soergel, Lavinia Baumstark, Jan Philipp Dietrich
x <- magclass::new.magpie(cells_and_regions = c("A", "B", "C", "D"), years = c(2000, 2005), fill = c(1, NA, 3, 4, 5, 6, NA, 8)) rel <- data.frame(CountryCode = c("A", "B", "C", "D"), RegionCode = c("R1", "R1", "R1", "R2")) xfilled <- toolFillWithRegionAvg(x, regionmapping = rel)
x <- magclass::new.magpie(cells_and_regions = c("A", "B", "C", "D"), years = c(2000, 2005), fill = c(1, NA, 3, 4, 5, 6, NA, 8)) rel <- data.frame(CountryCode = c("A", "B", "C", "D"), RegionCode = c("R1", "R1", "R1", "R2")) xfilled <- toolFillWithRegionAvg(x, regionmapping = rel)
Inter- and extrapolates a historical dataset for a given time period.
toolFillYears(x, years)
toolFillYears(x, years)
x |
MAgPIE object to be continued. |
years |
vector of years as digits or in mag year format |
MAgPIE object with completed time dimensionality.
Kristine Karstens
Function which retrieves a mapping file
toolGetMapping( name, type = NULL, where = NULL, error.missing = TRUE, returnPathOnly = FALSE, activecalc = NULL )
toolGetMapping( name, type = NULL, where = NULL, error.missing = TRUE, returnPathOnly = FALSE, activecalc = NULL )
name |
File name of the mapping file. Supported file types are currently csv (, or ; separated), rds
and rda (which needs to have the data stored with the object name "data"!). Use |
type |
Mapping type (e.g. "regional", "cell", or "sectoral"). Can be set to NULL if file is not stored in a type specific subfolder |
where |
location to look for the mapping, either "mappingfolder", "local" (if the path is relative to your
current directory) or the name of a package which contains the mapping. If set to NULL it will first try "local",
then "mappingfolder" and afterwards scan all packages currently listed in |
error.missing |
Boolean which decides whether an error is returned if the mapping file does not exist or not. |
returnPathOnly |
If set to TRUE only the file path is returned |
activecalc |
If set, this argument helps to define the first package within which the mapping has to be sought for. This happens via finding in which package the active calc function is located. |
the mapping as a data frame
Jan Philipp Dietrich
calcOutput
, toolConvertMapping
head(toolGetMapping("regionmappingH12.csv", where = "madrat"))
head(toolGetMapping("regionmappingH12.csv", where = "madrat"))
This function expects a MAgPIE object with ISO country codes in the spatial dimension. For this MAgPIE object the time of transition is calculated and for each the historic time filled by using the mapping stored as supplementary data in the madrat package. If you want to use a different mapping please specify it in the argument mapping
toolISOhistorical( m, mapping = NULL, additional_mapping = NULL, overwrite = FALSE, additional_weight = NULL )
toolISOhistorical( m, mapping = NULL, additional_mapping = NULL, overwrite = FALSE, additional_weight = NULL )
m |
MAgPIE object with ISO country codes in the spatial dimension |
mapping |
mapping of historical ISO countries to the standard ISO country list. For the default setting (mapping=NULL) the mapping stored as supplementary data in the madrat package is used. If provided as file the mapping needs to contain three columns "fromISO", "toISO" and "lastYear". |
additional_mapping |
vector or list of vectors to provide some specific mapping, first the old country code, second the new country code and last the last year of the old country, e.g. additional_mapping = c("TTT","TTX","y1111") or additional_mapping = list(c("TTT","TTX","y1111"),c("TTT","TTY","y1111")) |
overwrite |
if there are already historical data in the data source for years that are calculated in this function they will not be overwritten by default. To overwrite all data (e.g. if there are meaningless "0") choose overwrite=TRUE |
additional_weight |
optional weight to be used for regional disaggregation, if not provided, the values of m in the "lastYear" are used as weight |
A MAgPIE object with spatial entries for each country of the official ISO code country list. Historical time is filled up, old countries deleted
Lavinia Baumstark
Support tool for the creation of download functions in cases where a fully automated data download is not an option (e.g. due to a missing API). The function can be used to print a step-by-step guide for the user how to manually retrieve the data and then asks for a (local) path where the data can be copied from.
toolManualDownload( instructions, intro = "Data must be downloaded manually", request = "Enter full path to the downloaded data:" )
toolManualDownload( instructions, intro = "Data must be downloaded manually", request = "Enter full path to the downloaded data:" )
instructions |
Download instructions in form of a character vector describing how to manually retrieve the data. |
intro |
Introductory sentence to be shown first. Will not show up if set to NULL. |
request |
A prompt which should show up after the instructions to ask for the local download location. |
Jan Philipp Dietrich
## Not run: toolManualDownload(c("Log into website ABC", "Download the data set XYZ")) ## End(Not run)
## Not run: toolManualDownload(c("Log into website ABC", "Download the data set XYZ")) ## End(Not run)
Functions removes NAs, NaNs and infinite values in x and weight
toolNAreplace(x, weight = NULL, replaceby = 0, val.rm = NULL)
toolNAreplace(x, weight = NULL, replaceby = 0, val.rm = NULL)
x |
data |
weight |
aggregation weight |
replaceby |
value which should be used instead of NA. Either a single value or a MAgPIE object which can be expanded to the size of x (either same size or with lower dimensionality). |
val.rm |
vector of values that should in addition be removed in x |
a list containing x and weight
Benjamin Bodirsky, Jan Philipp Dietrich
reorder numbered spatial units (cells, clusters) by number. Function will return the unmodified object, if the given subdimension does not exist or does not contain cell information.
toolOrderCells(x, dim = 1.2, na.rm = FALSE)
toolOrderCells(x, dim = 1.2, na.rm = FALSE)
x |
magclass object that should be ordered |
dim |
subdimension which contains the cell information |
na.rm |
boolean deciding how to deal with non-integer information in cellular column. If FALSE, non-integer values will lead to a return of the unsorted object, if TRUE non-integer cells will be removed from the data set and the rest will get sorted |
ordered data in magclass format
Kristine Karstens, Jan Philipp Dietrich
This function can split a subtype string into smaller entities based on a given separator and check whether these entities exist in a reference list
toolSplitSubtype(subtype, components, sep = ":")
toolSplitSubtype(subtype, components, sep = ":")
subtype |
A character string which can be split with the given separator into smaller entities |
components |
A named list with the same length as the subtype has entities. Names of the list are used as names of the entities while the content of each list element represents the allowed values of that given entity. If all values are allowed use NULL as entry. |
sep |
separator to be used for splitting |
A named list with the different entities of the given subtype
Jan Philipp Dietrich
toolSplitSubtype("mymodel:myversion:myworld", list(model=c("mymodel","notmymodel"), version=c("myversion","42"), world="myworld"))
toolSplitSubtype("mymodel:myversion:myworld", list(model=c("mymodel","notmymodel"), version=c("myversion","42"), world="myworld"))
This function writes a process start message (what function was called with which arguments) and stores the current
time, so the corresponding call to toolendmessage
can calculate the elapsed time.
toolstartmessage(functionCallString, level = NULL)
toolstartmessage(functionCallString, level = NULL)
functionCallString |
A string representing the function call that should be logged |
level |
This argument allows to establish a hierarchy of print statements. The hierarchy is preserved for the next vcat executions. Currently this setting can have 4 states: NULL (nothing will be changed), 0 (reset hierarchies), "+" (increase hierarchy level by 1) and "-" (decrease hierarchy level by 1). |
A list containing diagnostic information required by toolendmessage
.
Jan Philipp Dietrich, Pascal Sauer
innerFunction <- function() { startinfo <- madrat:::toolstartmessage("innerFunction(argumentsToPrint = 123)", "+") vcat(1, "inner") madrat:::toolendmessage(startinfo, "-") } outerFunction <- function() { startinfo <- madrat:::toolstartmessage("outerFunction()", "+") vcat(1, "outer") innerFunction() madrat:::toolendmessage(startinfo, "-") } outerFunction()
innerFunction <- function() { startinfo <- madrat:::toolstartmessage("innerFunction(argumentsToPrint = 123)", "+") vcat(1, "inner") madrat:::toolendmessage(startinfo, "-") } outerFunction <- function() { startinfo <- madrat:::toolstartmessage("outerFunction()", "+") vcat(1, "outer") innerFunction() madrat:::toolendmessage(startinfo, "-") } outerFunction()
This function is a support function for the selection of a subtype in a readX function. In addition to the subtype selection it also performs some consistency checks.
toolSubtypeSelect(subtype, files)
toolSubtypeSelect(subtype, files)
subtype |
A chosen subtype (character) |
files |
A named vector or list. The names of the vector correspond to the allowed subtypes and the content of the vector are the corresponding file names. |
The file name corresponding to the given subtype
Jan Philipp Dietrich
files <- c(protection="protection.csv", production="production.csv", extent="forest_extent.csv") toolSubtypeSelect("extent",files)
files <- c(protection="protection.csv", production="production.csv", extent="forest_extent.csv") toolSubtypeSelect("extent",files)
average over time given an averaging range. Only works for data with equidistant time steps!
toolTimeAverage(x, averaging_range = NULL, cut = TRUE)
toolTimeAverage(x, averaging_range = NULL, cut = TRUE)
x |
magclass object that should be averaged with equidistant time steps |
averaging_range |
number of time steps to average |
cut |
if TRUE, all time steps at the start and end that can not be averaged correctly, will be removed if FALSE, time steps at the start and end will be averaged with high weights for start and end points |
the averaged data in magclass format
Kristine Karstens, Jan Philipp Dietrich
Smoothing a data set by replacing its values by its spline approximation using the given degrees of freedom.
toolTimeSpline(x, dof = NULL)
toolTimeSpline(x, dof = NULL)
x |
magclass object that should be smoothed via a spline approximation |
dof |
degrees of freedom per 100 years (similiar to an average range), is a proxy for the smoothness of the spline (smaller values = smoother) |
approximated data in magclass format
Kristine Karstens, Felicitas Beier
Selects the countries with the highest values in a magpie object
toolXlargest(x, range = 1:20, years = NULL, elements = NULL, ...)
toolXlargest(x, range = 1:20, years = NULL, elements = NULL, ...)
x |
magclass object that shall be used for ranking |
range |
the position of the countries in the top X which should be returned. |
years |
range of years that shall be summed for ranking. If NULL, the sum of all years is used. |
elements |
range of elements that shall be summed for ranking. If NULL, all elements are used. |
... |
further parameters will be handed on to calcOutput function type. |
vector with ISO country codes
Benjamin Leon Bodirsky, Jan Philipp Dietrich
toolXlargest(magclass::maxample("pop"), range = 1:3)
toolXlargest(magclass::maxample("pop"), range = 1:3)
Function which returns information based on the verbosity setting
vcat( verbosity, ..., level = NULL, fill = TRUE, show_prefix = TRUE, logOnly = FALSE )
vcat( verbosity, ..., level = NULL, fill = TRUE, show_prefix = TRUE, logOnly = FALSE )
verbosity |
The lowest verbosity level for which this message should be shown (verbosity = -1 means no information at all, 0 = only warnings, 1 = warnings and execution information, 2 = full information). If the verbosity is set to 0 the message is written as warning, if the verbosity is set higher than 0 it is written as a normal cat message. |
... |
The message to be shown |
level |
This argument allows to establish a hierarchy of print statements. The hierarchy is preserved for the next vcat executions. Currently this setting can have 4 states: NULL (nothing will be changed), 0 (reset hierarchies), "+" (increase hierarchy level by 1) and "-" (decrease hierarchy level by 1). |
fill |
a logical or (positive) numeric controlling how the output is broken into successive lines. If FALSE (default), only newlines created explicitly by "\n" are printed. Otherwise, the output is broken into lines with print width equal to the option width if fill is TRUE, or the value of fill if this is numeric. Non-positive fill values are ignored, with a warning. |
show_prefix |
a logical defining whether a content specific prefix (e.g. "NOTE") should be shown in front of the message or not. If prefix is not shown it will also not show up in official statistics. |
logOnly |
option to only log warnings and error message without creating warnings or errors (expert use only). |
Jan Philipp Dietrich
## Not run: vcat(2, "Hello world!") ## End(Not run)
## Not run: vcat(2, "Hello world!") ## End(Not run)
Creates a graphical visualization of dependencies between functions in the mr-universe.
visualizeDependencies( ..., direction = "both", order = 2, filter = NULL, packages = getConfig("packages"), filename = NULL )
visualizeDependencies( ..., direction = "both", order = 2, filter = NULL, packages = getConfig("packages"), filename = NULL )
... |
function(s) to be analyzed |
direction |
Character string, either “in”, “out” or "both". If “in” all sources feeding into the function are listed. If “out” consumer of the function are listed. If “both” the union of "in" and "out" is returned. |
order |
order of dependencies. Order 1 would be only functions directly called from (in case of direction "in") or directly calling (in case of direction "out") are shown. Order 2 will also show direct dependencies of the order 1 dependencies, order 3 also the direct dependencies from order 2 dependencies, etc. |
filter |
regular expression to describe elements which should be excluded from visualization (e.g. "^tool" to exclude all tool functions) |
packages |
packages to use when searching dependencies |
filename |
If a filename is provided, the resulting graph will be saved |
Debbora Leip, Jan Philipp Dietrich
getDependencies
, getMadratGraph
, getMadratInfo
Function will activate madrat logging facilities for all code provided
to this function. This means that message
, warning
and
stop
calls will also report to the madrat log output
withMadratLogging(expr)
withMadratLogging(expr)
expr |
expression to be evaluated. |
Jan Philipp Dietrich
## Not run: madrat:::withMadratLogging(message("Hello world!")) ## End(Not run)
## Not run: madrat:::withMadratLogging(message("Hello world!")) ## End(Not run)