Package 'brick'

Title: Building sector model with heterogeneous renovation and construction of the stock
Description: This building stock model represents residential and commercial buildings at customisable regional and temporal resolution. The building stock is quantified in floor area and distinguished by building type (SFH/MFH) and location (rural/urban). In each building category, construction cohorts are tracked explicitly. This allows to characterise buildings specifically for each subset of buildings. The evolution of the building stock follows from the flows of constructed, renovated and demolished buildings and is optimised under cost minimisation with a benefit for heterogeneity in the choice of construction and renovation alternatives. This benefit captures heterogeneity in the preferences of the agents and the building structure.
Authors: Robin Hasse [aut, cre] , Ricarda Rosemann [aut]
Maintainer: Robin Hasse <[email protected]>
License: LGPL-3
Version: 0.6.2
Built: 2025-03-20 06:33:23 UTC
Source: https://github.com/pik-piam/brick

Help Index


brick: Building sector model with heterogeneous renovation and construction of the stock

Description

logo

This building stock model represents residential and commercial buildings at customisable regional and temporal resolution. The building stock is quantified in floor area and distinguished by building type (SFH/MFH) and location (rural/urban). In each building category, construction cohorts are tracked explicitly. This allows to characterise buildings specifically for each subset of buildings. The evolution of the building stock follows from the flows of constructed, renovated and demolished buildings and is optimised under cost minimisation with a benefit for heterogeneity in the choice of construction and renovation alternatives. This benefit captures heterogeneity in the preferences of the agents and the building structure.

Author(s)

Maintainer: Robin Hasse [email protected] (ORCID)

Authors:

See Also

Useful links:


Write the specific costs to the input.gdx

Description

Write the specific costs to the input.gdx

Usage

.addSpecCostToInput(
  m,
  path,
  optimVarCon,
  optimVarRen,
  xinitCon,
  xinitRen,
  tcalib,
  varName = "x"
)

Arguments

m

Gams transfer container with previous input data

path

character, path to this run

optimVarCon

data frame with optimization variables of construction

optimVarRen

data frame with optimization variables of renovation

xinitCon

data frame with initial specific intangible costs of construction

xinitRen

data frame with initial specific intangible costs of renovation

tcalib

numeric, calibration time steps

varName

character, optimization variable to calculate specific costs from. Needs to be a column of optimVarCon and optimVarRen, should be one of 'x', 'xA' or 'xMin'.


Add the calibration targets to the input gdx

Description

Add the calibration targets to the input gdx

Usage

.addTargetsToInput(mInput, path, calibTarget)

Arguments

mInput

gamstransfer container of the input gdx

path

character, path to output folder of this run

calibTarget

list of data frames of calibration targets


Check if the Armijo condition holds. Return only data combinations for which it does not hold.

Description

Check if the Armijo condition holds. Return only data combinations for which it does not hold.

Usage

.checkArmijoStep(
  prevStep,
  stepSizeParams,
  outerObjective,
  sensitivityArmijo,
  varName = "fA",
  factorMin = 1
)

Arguments

prevStep

data frame with data combinations that did not satisfy the Armijo condition in the previous step

stepSizeParams

data frame with step size and related parameters

outerObjective

data frame containing the value of the outer objective function. Needs to contain the column f and the column specified by varName.

sensitivityArmijo

numeric, parameter of the Armijo condition specifying how strict the condition is

varName

character, outer objective variable to test the Armijo condition on

factorMin

numeric, additional factor to modify the Armijo condition


Check if the condition of the heuristic step size adaptation holds: Check if the outer objective does not increase. Return only data combinations for which the condition does not hold, i.e. the outer objective increases

Description

Check if the condition of the heuristic step size adaptation holds: Check if the outer objective does not increase. Return only data combinations for which the condition does not hold, i.e. the outer objective increases

Usage

.checkHeuristicStep(prevStep, outerObjective)

Arguments

prevStep

data frame with data combinations that did not satisfy the heuristic condition in the previous step

outerObjective

data frame containing the value of the outer objective function. Needs to contain the columns f and fA.


Read in brick results and compute the total outer objective function by combining resuls from construction and renovation.

Description

Read in brick results and compute the total outer objective function by combining resuls from construction and renovation.

Usage

.combineOuterObjective(
  m,
  outerObjective,
  p_constructionCalibTarget,
  p_renovationCalibTarget,
  tcalib,
  varName = "f"
)

Arguments

m

Gams transfer container to read brick results from

outerObjective

data frame to write the outer objective to

p_constructionCalibTarget

data frame with historic construction flows

p_renovationCalibTarget

data frame with historic renovation flows

tcalib

numeric, calibration time steps

varName

character, column name in outerObjective to write the result to. Should be one of 'f', 'fA', 'fMin'.


Combine the step size paramters delta and phi-derivative from construction and renovation flows

Description

Combine the step size paramters delta and phi-derivative from construction and renovation flows

Usage

.combineStepSizeParams(paramsCon, paramsRen)

Arguments

paramsCon

data frame with step size parameters from construction

paramsRen

data frame with step size parameters from renovation


Compute the descent direction from Brick results

Description

Read in objective function values for slightly shifted optimization variables and compute the gradient of the objective function. Set the adjustment term d to the negative of the gradient.

Usage

.computeDescentDirection(
  m,
  dims,
  tcalib,
  flow = c("construction", "renovation")
)

Arguments

m

Gams transfer container with current Brick results

dims

character, dimensions of the desired result object

tcalib

numeric, time steps to calibrate on

flow

character, either 'construction' or 'renovation'


Compute the deviation between historic data and Brick results. Then compute the adjustment term for the calibration d

Description

Compute the deviation between historic data and Brick results. Then compute the adjustment term for the calibration d

Usage

.computeDeviation(
  m,
  target,
  dims,
  tcalib,
  flow = c("construction", "renovation"),
  renAllowed = NULL
)

Arguments

m

Gams transfer container with current Brick results

target

data frame of historical data

dims

character, dimensions of historic data and Brick results

tcalib

numeric, time steps to calibrate on

flow

character, either 'construction' or 'renovation'

renAllowed

data frame with allowed renovation transitions


Evaluate the outer objective function.

Description

In case of the logit calibration, this outer objective function is virtual: We are not actually performing an optimization algorithm on this function, but only use it for the step size adaptation.

Usage

.computeOuterObjective(m, gamsVar, target, dims, tcalib)

Arguments

m

Gams transfer container object to read set values from

gamsVar

data frame with brick results for the given variable

target

data frame with historic data

dims

character, dimensions of data

tcalib

numeric, calibration time steps


Evaluate the outer objective function for the stock

Description

Evaluate the outer objective function for the stock

Usage

.computeOuterObjectiveStock(
  m,
  outerObjective,
  p_stockCalibTarget,
  tcalib,
  varName = "f"
)

Arguments

m

Gams transfer object to read the stock variable from

outerObjective

data frame to write the outer objective to

p_stockCalibTarget

data frame with historic stock

tcalib

numeric, calibration time steps

varName

character, column name in outerObjective to write the result to. Should be one of 'f', 'fA', 'fMin'.


Compute the step size adaptation paramters delta and phi-derivative

Description

Compute the step size adaptation paramters delta and phi-derivative

Usage

.computeStepSizeParams(deviation)

Arguments

deviation

data frame with deviation and adjustment term 'd'


crop gdx parameters to historic periods

Description

remove all records of temporal parameters that are outside of thist and make zero values explicit by filling with EPS.

Usage

.cropParamsToThist(gdx, thist)

Arguments

gdx

character, file path to gdx

thist

numeric vector of historic periods


Assemble specific costs from initial specific costs and the optimization variable

Description

Assemble specific costs from initial specific costs and the optimization variable

Usage

.determineSpecCost(optimVar, xinit, dims, tcalib, varName = "x")

Arguments

optimVar

data frame with the optimization variable 'x' and optionally 'xMin' and 'xA'

xinit

data frame with initial specific intangible costs

dims

character, dimensions of the optimization variable

tcalib

numeric, calibration time steps

varName

character, optimization variable to calculate specific costs from. Should be one of 'x', 'xA' or 'xMin'.


Make zeros explicit

Description

Replace zeros in value column with the gams special value EPS. This way, the value is saved in gdx files by gams.

Usage

.explicitZero(x, value = "value")

Arguments

x

data.frame

value

character, name of value column

Value

data.frame with explicit zeros in value column

Author(s)

Robin Hasse


Filter data frame rows with reference data frames

Description

Performs successive semi_joins with passed data frames by all common columns. Useful to filter allowed renovations or vintages that exist.

Usage

.filter(x, ...)

Arguments

x

data.frame

...

data frames that only have columns existing also in x

Value

filtered data frame

Author(s)

Robin Hasse


filter rows with specified entry in column

Description

used to select a specifc level or scenario from a data frame with alternative values.

Usage

.filterLevel(df, lvl, switchName = "", lvlCol = "level")

Arguments

df

data.frame

lvl

value used to select rows

switchName

character, corresponding BRICK switch name (only used for more informative error message)

lvlCol

character, colname containing lvl

Value

data.frame with selected rows without lvlCol


Find config file path

Description

Search for config file in multiple steps. The file is found if * config is a full file path already * config is the name of a file in the config folder * there is exactly one file in configFolder matching the pattern passed via config

Usage

.findCfg(config, configFolder, isFinalCfg)

Arguments

config

character, config file, either a path to a yaml file or the name of the file in 'inst/config/'

configFolder

character, directory to search for configs. If NULL, the BRICK-internal config folder is used.

isFinalCfg

logical, is this the final config and not an intermediate?

Value

file path to config


find origin gdx file

Description

Depending on what is passed via originGDX, this function returns the file path if it exists, looks for recognised file names in the given directory if it exists or looks for the latest run with the given name in the outputFolder.

Usage

.findOriginGdxFile(originGdx, outputFolder)

Arguments

originGdx

character, file path to run or gdx file used as historical or scenario name

outputFolder

directory of output folder, only required if originGDX is a scenario name

Value

file path to origin gdx file


Get dimension names from calibration targets

Description

Gives the column names of a list of data frames except the first and the last one, i.e. qty and value.

Usage

.getDims(calibTarget)

Arguments

calibTarget

list, calibration targets


Initialize the data frame for the optimization variable of construction

Description

Initialize the data frame for the optimization variable of construction

Usage

.initOptimVarCon(mInput, tcalib)

Arguments

mInput

Gamstransfer container with the input data

tcalib

numeric, calibration time periods


Initialize the data frame for the optimization variable of renovation

Description

Initialize the data frame for the optimization variable of renovation

Usage

.initOptimVarRen(mInput, tcalib, renAllowed)

Arguments

mInput

Gamstransfer container with the input data

tcalib

numeric, calibration time periods

renAllowed

data frame with allowed renovation transitions


Initialize the data frame for the objective function value

Description

Initialize the data frame for the objective function value

Usage

.initOuterObjective(mInput, tcalib)

Arguments

mInput

Gamstransfer container with the input data

tcalib

numeric, calibration time periods


Compute the initial step size of the step size iteration algorithm

Description

Compute the initial step size of the step size iteration algorithm

Usage

.initStepSize(i, stepSizeParams, outerObjective, stepSizeInit)

Arguments

i

numeric, iteration number of overall calibration procedure

stepSizeParams

data frame with parameters for the step size adaptation

outerObjective

data frame with previous and current values of outer objective function; needs to contain the columns fPrev and f

stepSizeInit

numeric, lower bound for the initial step size


Calculate log-Likelihood of historical values

Description

Calculate log-Likelihood of historical values

Usage

.logLikelihood(res, target)

Arguments

res

numeric, result values

target

numeric, historic values


Check if gamstransfer is available

Description

Just a check to get a helpful error if gamstransfer is missing. Once the package is available on GitHub, it should be listed as a dependency and this file can be removed. The check is disabled during contiunous integration (CI) i.a. GitHub actions and during devtools:check which is called by lucode2::buildLibrary.

Usage

.onLoad(libname, pkgname)

Arguments

libname

not used

pkgname

not used

Author(s)

Robin Hasse


Overwrite list with another list

Description

Overwrite a named list with another named list. The result corresponds to the overwritten list unless a value is overwritten by the overwriting list.

Usage

.overwriteList(x, y, isFinalCfg, defaultCfgPath)

Arguments

x

named list, provides the structure and default values that can be overwritten by y.

y

named list, overwrites x wherever it has values different from NULL. Cannot have keys that are not specified in x.

isFinalCfg

logical, is this the final config and not an intermediate?

defaultCfgPath

character, path to default config. Only used for more helpful error message.

Details

This function is called recursively until the default config is reached. Therefor, the list structure will always correspond to the default config. No config based directly or indirectly on the default can have list keys that the default config doesn't have.

Value

named list with the structure of x that is (partly) overwritten by y.


Read calibration targets from input folder

Description

Read calibration targets from input folder

Usage

.readCalibTarget()

Read config file

Description

Read yaml file from given path, check minimum requirement (title exists) and save the file path as a attribute.

Usage

.readCfg(file)

Arguments

file

character, path to config file

Value

named list with config parameters


Read the outer objective from a gams calibration run.

Description

Only applicable for optimization calibration.

Usage

.readOuterObjectiveOptim(m, outerObjective, varName = "f")

Arguments

m

Gams transfer container to read brick results from

outerObjective

data frame to write the outer objective to

varName

character, column name in outerObjective to write the result to. Should be one of 'f', 'fA', 'fMin'.


Calculate sum of squared differences between results and historic values

Description

Calculate sum of squared differences between results and historic values

Usage

.sumSquare(res, target)

Arguments

res

numeric, result values

target

numeric, historic values


Update the step size for the selected combinations

Description

Update the step size for the selected combinations

Usage

.updateStepSize(totalStep, stepSizeParams, stepReduction)

Arguments

totalStep

data frame with combinations to perform the adjustment ot the step size on

stepSizeParams

data frame with the parameters of the step size adjustment algorithm

stepReduction

numeric, factor applied to stepSize to reduce the step size. Should be < 1.


Update the optimization variable 'x'

Description

Adjust 'x' by adding the adjustment term 'd' multiplied by the step size

Usage

.updateX(
  optimVar,
  deviation,
  stepSizeParams,
  dims,
  nameTo = "x",
  factorMin = 1
)

Arguments

optimVar

data frame with the optimization variable 'x' and optionally 'xMin' and 'xA'

deviation

data frame with deviation and adjustment term 'd'

stepSizeParams

data frame with parameters of step size adaptation, including step size 'stepSize'

dims

character, dimensions of the optimization variable

nameTo

character, optimization variable to write the result to

factorMin

numeric, additional factor to multiply the adjustment term with


Update the optimization variable 'x' for selected combinations only

Description

Update the optimization variable 'x' for selected combinations only

Usage

.updateXSelect(
  totalStep,
  optimVar,
  deviation,
  stepSizeParams,
  dims,
  nameTo = "x"
)

Arguments

totalStep

data frame with combinations to perform the adjustment of 'x' on

optimVar

data frame with the optimization variables

deviation

data frame with the deviation from historic data and the adjustment parameter 'd'

stepSizeParams

data frame with the parameters of the step size adaptatation procedure

dims

character, dimensions of the optimization variable

nameTo

character, column name to write the updated optimization variable to. Should be one of 'x', 'xA', 'xMin'.


Write the intangible costs to a .csv file

Description

Write the intangible costs to a .csv file

Usage

.writeCostIntang(file, optimVar, xinit, dims, tcalib)

Arguments

file

character, path to file to which results should be written

optimVar

data frame with optimization variable, needs to contain column 'x'

xinit

data frame with initial intangible specific costs

dims

character, dimensions of the optimization variable

tcalib

numeric, calibration time steps


Add assumed intangible costs

Description

Add assumed intangible costs

Usage

addAssump(df, assumpFile)

Arguments

df

data.frame for the cost of construction or renovation

assumpFile

character, file path to assumption file

Value

data frame with added intangible cost

Author(s)

Robin Hasse


Aggregate matching run results for calibration

Description

Temporary function that prepares historic stock and flows for calibration

Usage

aggregateMatching(path, config, overwrite = FALSE)

Arguments

path

character, path to calibration run

config

named list, configuration of calibration run

overwrite

logical, should existing data be overwritten?

Details

This functionality will migrate to mredgebuidlings but this infrastructure requires more time to be developed.

Author(s)

Robin Hasse


Find the full file names of files in BRICK

Description

This is meant to work with the installed package BRICK but also when loading the package via devtools::load_all("path/to/brick")

Usage

brick.file(..., mustWork = TRUE)

Arguments

...

character vectors, specifying subdirectory and files within brick

mustWork

if TRUE, an error is given if there are no matching files

Value

A character vector of positive length, containing the file paths that matched ... in BRICK.

Author(s)

Robin Hasse


Check whether Gams finished successfully

Description

Check which output file was written and derive state of Gams run

Usage

checkGamsSuccess(path)

Arguments

path

character, path to search for gams output files

Details

If output.gdx was written, give success message. If abort.gdx was written or no output file exists, stop with error message.

Author(s)

Ricarda Rosemann


Copy gams scripts to output folder

Description

Copy gams scripts to output folder

Usage

copyGamsFiles(path, overwrite = FALSE)

Arguments

path

character vector with folders to write input data into

overwrite

logical, should existing input.gdx be overwritten?

Author(s)

Robin Hasse


Copy history gdx to output folder

Description

Copy history gdx to output folder

Usage

copyHistoryGdx(
  path,
  outputFolder = NULL,
  config,
  overwrite = FALSE,
  thistOnly = TRUE
)

Arguments

path

character vector with folders to write input data into

outputFolder

directory of output folder

config

named list with run configuration

overwrite

logical, should existing input.gdx be overwritten?

thistOnly

logical, crop temporal parameters to historic periods

Author(s)

Robin Hasse


Copy initial gdx to output folder

Description

Copy initial gdx to output folder

Usage

copyInitialGdx(path, config, overwrite = FALSE)

Arguments

path

character vector with folders to write input data into

config

named list with run configuration

overwrite

logical, should existing input.gdx be overwritten?

Author(s)

Robin Hasse


Create input data

Description

Create a complete set of input data for the gams optimisation.

Usage

createInputData(path, config, overwrite = FALSE)

Arguments

path

character vector with folders to write input data into

config

named list with run configuration

overwrite

logical, should existing input.gdx be overwritten?

Details

This function reads static input data according to the input data revision in the config and creates all required sets and parameters for the gams optimisation depending on the switches in the config.

Author(s)

Robin Hasse


Create data for reference matching

Description

Create data for reference matching

Usage

createMatchingData(path, config, overwrite = FALSE)

Arguments

path

character vector with folders to run the model in

config

run configurations

overwrite

logical, should existing data be overwritten?

Author(s)

Robin Hasse


Create parameters

Description

Add all parameters to gams container based on config

Usage

createParameters(m, config, inputDir)

Arguments

m

gams Container, central object to store all data for input.gdx

config

named list with run configuration

inputDir

directory of input folder

Value

gams Container with parameters added

Author(s)

Robin Hasse


Create new run folder

Description

Create a folder for the model to run in and copy required gams files there.

Usage

createRunFolder(
  path,
  config = NULL,
  overwrite = FALSE,
  recursive = FALSE,
  showWarnings = TRUE
)

Arguments

path

character vector, containing

config

list with run configuration

overwrite

logical; Should exiting folders be overwritten?

recursive

logical; Should exiting folders be overwritten?

showWarnings

logical; Should exiting folders be overwritten?

Author(s)

Robin Hasse


Create sets

Description

Add all sets to gams container based on config

Usage

createSets(m, config)

Arguments

m

gams Container, central object to store all data for input.gdx

config

named list with run configuration

Value

gams Container with sets added

Author(s)

Robin Hasse


Expand set values to data frame

Description

Create a data frame that has a column for each set and the full crossing of all set entries as rows

Usage

expandSets(..., .m = NULL)

Arguments

...

gams sets

.m

gams Container with sets referenced in ....

Value

data.frame with full crossing of set entries

Author(s)

Robin Hasse


Determine the latest path of a run

Description

Search the given output folder for the run with the most recent time stamp and return the path to this run. If the output folder contains only one run, return its path, also if it does not contain a time stamp.

Usage

findLastRun(outputFolder)

Arguments

outputFolder

character, output folder to search in

Author(s)

Ricarda Rosemann


Retrieve mapping file from BRICK

Description

Retrieve mapping file from BRICK

Usage

getBrickMapping(
  name,
  type = "sectoral",
  error.missing = TRUE,
  returnPathOnly = FALSE
)

Arguments

name

character, file name of the mapping file

type

character, Mapping type (e.g. "regional", or "sectoral")

error.missing

logical, return error if the file does not exist

returnPathOnly

logical, file name of the mapping file

Author(s)

Robin Hasse


guess column names based on column values

Description

guess column names based on column values

Usage

guessColnames(x, m)

Arguments

x

data.frame with unknown column names

m

gams Conatiner with sets

Value

data.frame with guessed column names

Author(s)

Robin Hasse


Initialize the model:

Description

Preparations of a model run, send the model to SLURM if desired

Usage

initModel(
  config = NULL,
  path = NULL,
  configFolder = NULL,
  outputFolder = "output",
  references = NULL,
  restart = FALSE,
  runReporting = TRUE,
  sendToSlurm = NULL,
  slurmQOS = NULL,
  tasksPerNode = NULL,
  timeLimit = NULL,
  tasks32 = FALSE
)

Arguments

config

run configurations

path

character vector with folders to run the model in

configFolder

character, directory to search for configs. If NULL, the BRICK-internal config folder is used.

outputFolder

directory of output folder

references

named character vector of matching references

restart

logical or character vector of elements to be restarted. If FALSE (default), then no restart is initiated. If TRUE, then the run in the given path or the latest run is restarted with default settings. Allowed elements of the character vector are:

  • "copyGams" to recopy the Gams scripts (necessary if changes were made in Gams code)

  • "createInput" to recreate the input data

  • "createMatching" to recreate the matching data

  • "useAsStart" to use the run from which we restart as the starting point

  • "none" (or any other string) to do none of the above

runReporting

logical, whether to run the reporting, i.e. write the mif

sendToSlurm

boolean whether or not the run should be started via SLURM

slurmQOS

character, slurm QOS to be used

tasksPerNode

numeric, number of tasks per node to be requested

timeLimit

character, time limit of the slurm job given in the format hh:mm:ss

tasks32

boolean whether or not the SLURM run should be with 32 tasks

Details

This function creates the run folder with the necessary config and gams files. It then either calls the function to start the model directly or passes the model to SLURM.

Value

path (invisible)

Author(s)

Ricarda Rosemann


Is Slurm Avaiable

Description

Checks whether slurm is available so that jobs can be submitted, e.g., via sbatch ....

Usage

isSlurmAvailable()

Value

logical(1). Whether slurm is available.


Convert nested named list to long data.frame

Description

Convert nested named list to long data.frame

Usage

listToDf(x, n = 1)

Arguments

x

named list with identical depth on each branch

n

Integer, number of nested function calls, leave default

Value

data.frame with column for each level of the named list

Author(s)

Robin Hasse


Load Input data from mredgebuildings

Description

Load Input data from mredgebuildings

Usage

loadMadratData(config)

Arguments

config

named list with run configuration

Value

directory of input folder

Author(s)

Robin Hasse


Named list to handle string

Description

Helper function to turn a named list into a string appended to the gams command line call

Usage

makeHandle(lst, type = c("gams", "model"))

Arguments

lst

named list of flags

type

character, type of flags (either '"gams"' or '"model')

Details

Gams parameters are lower case flags and follow one minus '-'. Model switches are upper case flags and follow two minuses '–'.

Value

character of flags

Author(s)

Robin Hasse


get Period from config

Description

extract different periods from a given BRICK config

Usage

periodFromConfig(config, periodType)

Arguments

config

named list with run configuration

periodType

type of period(s)

Value

numeric vector with periods

Author(s)

Robin Hasse


Plot heat map of reference deviation

Description

Plot heat map of reference deviation

Usage

plotRefDeviation(path)

Arguments

path

character; directory of output folder

Author(s)

Robin Hasse


Plot Summary of a run

Description

Plot an overview of the stock and flows

Usage

plotSummary(path, facet = "typ", showHistStock = FALSE, splitRen = FALSE)

Arguments

path

character, path to the run

facet

character, dimension to resolve as facets

showHistStock

logical, show given historic next to the modeled stock

splitRen

logical, plot renovation with identical replacement semi-transparent

Author(s)

Robin Hasse


Read config file

Description

Read config file in yaml format

Usage

readConfig(config = NULL, configFolder = NULL, readDirect = FALSE)

Arguments

config

character, config file, either a path to a yaml file or the name of the file in configFolder

configFolder

character, directory to search for configs. If NULL, the BRICK-internal config folder is used.

readDirect

logical, specify whether config is a valid path to a config file that should be read directly.

Details

If no argument is given, the default config is used.

Value

named list with run config

Author(s)

Robin Hasse


Read madrat input files from input folder

Description

Read madrat input files from input folder

Usage

readInput(filename, dims, inputDir = NULL)

Arguments

filename

character, filename

dims

character vector, column names

inputDir

character, directory of input folder

Value

data.frame with data of the given input file

Author(s)

Robin Hasse


Read symbol from gams container

Description

Read symbol from gams container

Usage

readSymbol(x, symbol = NULL, selectArea = TRUE, stringAsFactor = TRUE)

Arguments

x

gams Container, Parameter, Variable or Set

symbol

character, name of gams object if x is a Container else NULL

selectArea

logical, select area quantity and remove this dimension

stringAsFactor

logical, keep default factors from gams

Author(s)

Robin Hasse


Create mif file for model run

Description

The mif file contains reporting variables for the given model run.

Usage

reportMif(path, file = NULL, tmpl = NULL)

Arguments

path

character, path to the run

file

character, path of mif file. If NULL, default file name in run folder will be used. If FALSE, no file is written and the mif data is returned instead.

tmpl

character, BRICK reporting template. There has to be a brickSets mapping named with the same suffix: brickSets_<tmpl>.yaml. If NNULL, the config setting is used.

Author(s)

Robin Hasse


Run the brick calibration

Description

Two methods for the Brick calibration are available: The logit calibration and the optimization calibration.

Usage

runCalibration(
  path,
  parameters,
  tcalib,
  gamsOptions = NULL,
  switches = NULL,
  fileName = "main.gms",
  gamsCall = "gams"
)

Arguments

path

character vector with folders to run gams in

parameters

named list of calibration parameters

tcalib

numeric, time periods to calibrate on

gamsOptions

named list of GAMS options

switches

named list of model switches

fileName

character vector with gams file names

gamsCall

system command to call gams

Details

The general procedure is as follows: We aim to minimize the deviation between historic values and Brick results. An intangible component of the specific construction and renovation costs is iteratively adjusted to achieve this. Thus the intangible costs serve as the optimization variable x and a functional evaluation of the deviation represents the objective function f.

Brick is run iteratively and from each run, an adjustment term d is computed. The optimization variable is adjusted according to x = x + stepSize * d, where the step size is determined according to the Armijo step size adaptation algorithm.

The implementation is centered around the following objects:

  • The optimization variable x and its variant(s) required in the step size adaptation are gathered in the data frame optimVarCon for construction and optimVarRen for renovation.

  • The objective function value f and its variant(s) are gathered in the data frame outerObjective

  • The adjustment term d and related variables if applicable are gathered in the data frame deviationCon for construction and deviationRen for renovation.

  • The step size stepSize and related parameters required for the step size adaptation algorithm are gathered in the data frame stepSizeParams.

Author(s)

Ricarda Rosemann


Call the logit brick calibration

Description

The adjustment term is computed as if Brick were a pure logit model: d = log(<brick result>/<historic value>).

Usage

runCalibrationLogit(
  path,
  parameters,
  tcalib,
  calibTarget,
  gamsOptions = NULL,
  switches = NULL,
  fileName = "main.gms",
  gamsCall = "gams"
)

Arguments

path

character vector with folders to run gams in

parameters

named list of calibration parameters

tcalib

numeric, time periods to calibrate on

calibTarget

list of data frames of calibration targets

gamsOptions

named list of GAMS options

switches

named list of model switches

fileName

character vector with gams file names

gamsCall

system command to call gams

Details

Here the armijo step size algorithm may not be applicable; if this is the case, a heuristic step size adaptation is applied.


Call the optimization brick calibration

Description

This implements a gradient descent method to perform the minimization of the deviation. The adjustment term is computed as the negative of the gradient of the objective function.

Usage

runCalibrationOptim(
  path,
  parameters,
  tcalib,
  calibTarget,
  gamsOptions = NULL,
  switches = NULL,
  fileName = "main.gms",
  gamsCall = "gams"
)

Arguments

path

character vector with folders to run gams in

parameters

named list of calibration parameters

tcalib

numeric, time periods to calibrate on

calibTarget

list of data frames of calibration targets

gamsOptions

named list of GAMS options

switches

named list of model switches

fileName

character vector with gams file names

gamsCall

system command to call gams


Run gams optimisation

Description

Run the gams model in a given directory.

Usage

runGams(
  path,
  gamsOptions = NULL,
  switches = NULL,
  fileName = "main.gms",
  gamsCall = "gams"
)

Arguments

path

character vector with folders to run gams in

gamsOptions

named list of GAMS options

switches

named list of model switches

fileName

character vector with gams file names

gamsCall

system command to call gams

Details

The file 'input.gdx' has to exist in the given directory.

Author(s)

Robin Hasse


Set the SLURM configuration

Description

Based on user input, construct the SLURM configuration string.

Usage

setSlurmConfig(slurmQOS, tasksPerNode = 16, tasks32 = FALSE, timeLimit = NULL)

Arguments

slurmQOS

string, name of the desired QOS (Quality of Service)

tasksPerNode

numeric, number of tasks per node to be requested

tasks32

boolean, specify whether a node with 32 tasks should be requested

timeLimit

character, time limit of the slurm job given in the format hh:mm:ss

Details

Check if SLURM configuration is admissible.

Value

string with SLURM configuration

Author(s)

Ricarda Rosemann


Start the model

Description

Run the model with given configuration.

Usage

startModel(path, runReporting = TRUE)

Arguments

path

character vector with folders to run the model in

runReporting

logical, whether to run the reporting, i.e. write the mif

Details

This function creates a run folder with necessary gams files if missing. It then computes the input data and finally runs the optimisation.

Author(s)

Robin Hasse


interpolate and filter to get model resolution

Description

Missing periods are interpolated linearly and extrapolated constantly, additional periods are removed and all other dimensions are filtered to the elements dined in the model sets.

Usage

toModelResolution(x, m, value = "value")

Arguments

x

data.frame with temporal dimension

m

gams Container with sets as known dimensions

value

character, name of value column

Value

data.frame with temporal resolution according to model

Author(s)

Robin Hasse