Note

This page is generated from inline documentation in MESSAGE/model_core.gms.

MESSAGE core formulation

The MESSAGEix systems-optimization model minimizes total costs while satisfying given demand levels for commodities/services and considering a broad range of technical/engineering constraints and societal restrictions (e.g. bounds on greenhouse gas emissions, pollutants, system reliability). Demand levels are static (i.e. non-elastic), but the demand response can be integrated by linking MESSAGEix to the single sector general-economy MACRO model included in this framework.

For the complete list of sets, mappings and parameters, refer to the auto-documentation page Sets and mappings and Parameter definition. The mathematical notation that is used to represent sets and mappings in the equations below can also be found in the tables in Sets and mappings.

Variable definitions

Decision variables

Variable

Explanatory text

\(\text{OBJ} \in \mathbb{R}\)

Objective value of the optimization program

\(\text{EXT}_{n,c,g,y} \in \mathbb{R}_+\)

Extraction of non-renewable/exhaustible resources from reserves

\(\text{STOCK}_{n,c,l,y} \in \mathbb{R}_+\)

Quantity in stock (storage) at start of period \(y\)

\(\text{STOCK_CHG}_{n,c,l,y,h} \in \mathbb{R}\)

Input or output quantity into intertemporal commodity stock (storage)

\(\text{COST_NODAL}_{n,y} \in \mathbb{R}\)

System costs at the node level over time

\(\text{REN}_{n,t,c,g,y,h} \in \mathbb{R}_+\)

Activity of renewable technologies per grade

\(\text{CAP_NEW}_{n,t,y} \in \mathbb{R}_+\)

Newly installed capacity (yearly average over period duration)

\(\text{CAP}_{n,t,y^V,y} \in \mathbb{R}_+\)

Maintained capacity in year \(y\) of vintage \(y^V\)

\(\text{CAP_FIRM}_{n,t,c,l,y,q} \in \mathbb{R}_+\)

Capacity counting towards firm (dispatchable)

\(\text{ACT}_{n,t,y^V,y,m,h} \in \mathbb{R}\)

Activity of a technology (by vintage, mode, subannual time)

\(\text{ACT_RATING}_{n,t,y^V,y,c,l,h,q} \in \mathbb{R}_+\)

Auxiliary variable for activity attributed to a particular rating bin [1]

\(\text{CAP_NEW_UP}_{n,t,y} \in \mathbb{R}_+\)

Relaxation of upper dynamic constraint on new capacity

\(\text{CAP_NEW_LO}_{n,t,y} \in \mathbb{R}_+\)

Relaxation of lower dynamic constraint on new capacity

\(\text{ACT_UP}_{n,t,y,h} \in \mathbb{R}_+\)

Relaxation of upper dynamic constraint on activity [2]

\(\text{ACT_LO}_{n,t,y,h} \in \mathbb{R}_+\)

Relaxation of lower dynamic constraint on activity [2]

\(\text{LAND}_{n,s,y} \in [0,1]\)

Relative share of land-use scenario (for land-use model emulator)

\(\text{EMISS}_{n,e,\widehat{t},y} \in \mathbb{R}\)

Auxiliary variable for aggregate emissions by technology type

\(\text{REL}_{r,n,y} \in \mathbb{R}\)

Auxiliary variable for left-hand side of relations (linear constraints)

\(\text{COMMODITY_USE}_{n,c,l,y} \in \mathbb{R}\)

Auxiliary variable for amount of commodity used at specific level

\(\text{COMMODITY_BALANCE}_{n,c,l,y,h} \in \mathbb{R}\)

Auxiliary variable for right-hand side of Auxiliary COMMODITY_BALANCE

\(\text{STORAGE}_{n,t,m,l,c,y,h} \in \mathbb{R}\)

State of charge or content of storage at each sub-annual time slice

\(\text{STORAGE_CHARGE}_{n,t,m,l,c,y,h} \in \mathbb{R}\)

Charging of storage in each sub-annual time slice (negative for discharging)

The index \(y^V\) is the year of construction (vintage) wherever it is necessary to clearly distinguish between year of construction and the year of operation.

All decision variables are by year, not by (multi-year) period, except \(\text{STOCK}_{n,c,l,y}\). In particular, the new capacity variable \(\text{CAP_NEW}_{n,t,y}\) has to be multiplied by the number of years in a period \(|y| = \text{duration_period}_{y}\) to determine the available capacity \(\text{CAP}_{n,t,y^V,y}\) in subsequent periods (assuming the newly build capacity is not immediately decommissioned):

\(\text{CAP}_{n,t,y^V,y} = \text{CAP_NEW}_{n,t,y} \cdot \text{duration_period}_{y}\)

\(\text{CAP_NEW}_{n,t,y}\) is therefore the amount of newly installed capacity in one year and \(\text{CAP}_{n,t,y^V,y}\) the amount, which is installed at the end of a (usually multi-year) period. This formulation gives more flexibility when it comes to using periods of different duration (more intuitive comparison across different periods).

The current model framework allows both input or output normalized formulation. This will affect the parametrization, see Section Efficiency - output- vs. input defined technologies for more details.

Auxiliary variables

Variable

Explanatory text

\(\text{DEMAND}_{n,c,l,y,h} \in \mathbb{R}\)

Demand level (in equilibrium with MACRO integration)

\(\text{PRICE_COMMODITY}_{n,c,l,y,h} \in \mathbb{R}\)

Commodity price (undiscounted marginals of Equation COMMODITY_BALANCE_GT and Equation COMMODITY_BALANCE_LT)

\(\text{PRICE_EMISSION}_{n,\widehat{e},\widehat{t},y} \in \mathbb{R}\)

Emission price (undiscounted marginals of Equation EMISSION_CONSTRAINT)

\(\text{COST_NODAL_NET}_{n,y} \in \mathbb{R}\)

System costs at the node level net of energy trade revenues/cost

\(\text{GDP}_{n,y} \in \mathbb{R}\)

Gross domestic product (GDP) in market exchange rates for MACRO reporting

Warning

Please be aware that transitioning from one period length to another for consecutive periods may result in false values of \(\text{PRICE_EMISSION}\). Please see this issue for further information. We are currently working on a fix.

Objective function

The objective function of the MESSAGEix core model

Equation OBJECTIVE

The objective function (of the core model) minimizes total discounted systems costs including costs for emissions, relaxations of dynamic constraints

\[\text{OBJ} = \sum_{n,y \in Y^{M}} \text{df_period}_{y} \cdot \text{COST_NODAL}_{n,y}\]

Regional system cost accounting function

Accounting of regional system costs over time

Equation COST_ACCOUNTING_NODAL

Accounting of regional systems costs over time as well as costs for emissions (taxes), land use (from the model land-use model emulator), relaxations of dynamic constraints, and linear relations.

\[\begin{split}\text{COST_NODAL}_{n,y} & = \sum_{c,g} \ \text{resource_cost}_{n,c,g,y} \cdot \text{EXT}_{n,c,g,y} \\ & + \sum_{t} \ \bigg( \text{inv_cost}_{n,t,y} \cdot \text{construction_time_factor}_{n,t,y} \\ & \quad \quad \quad \cdot \text{end_of_horizon_factor}_{n,t,y} \cdot \text{CAP_NEW}_{n,t,y} \\[4 pt] & \quad \quad + \sum_{y^V \leq y} \ \text{fix_cost}_{n,t,y^V,y} \cdot \text{CAP}_{n,t,y^V,y} \\ & \quad \quad + \sum_{\substack{y^V \leq y \\ m,h}} \ \text{var_cost}_{n,t,y^V,y,m,h} \cdot \text{ACT}_{n,t,y^V,y,m,h} \\ & \quad \quad + \Big( \text{abs_cost_new_capacity_soft_up}_{n,t,y} \\ & \quad \quad \quad + \text{level_cost_new_capacity_soft_up}_{n,t,y} \cdot\ \text{inv_cost}_{n,t,y} \Big) \cdot \text{CAP_NEW_UP}_{n,t,y} \\[4pt] & \quad \quad + \Big( \text{abs_cost_new_capacity_soft_lo}_{n,t,y} \\ & \quad \quad \quad + \text{level_cost_new_capacity_soft_lo}_{n,t,y} \cdot\ \text{inv_cost}_{n,t,y} \Big) \cdot \text{CAP_NEW_LO}_{n,t,y} \\[4pt] & \quad \quad + \sum_{m,h} \ \Big( \text{abs_cost_activity_soft_up}_{n,t,y,m,h} \\ & \quad \quad \quad + \text{level_cost_activity_soft_up}_{n,t,y,m,h} \cdot\ \text{levelized_cost}_{n,t,y,m,h} \Big) \cdot \text{ACT_UP}_{n,t,y,h} \\ & \quad \quad + \sum_{m,h} \ \Big( \text{abs_cost_activity_soft_lo}_{n,t,y,m,h} \\ & \quad \quad \quad + \text{level_cost_activity_soft_lo}_{n,t,y,m,h} \cdot\ \text{levelized_cost}_{n,t,y,m,h} \Big) \cdot \text{ACT_LO}_{n,t,y,h} \bigg) \\ & + \sum_{\substack{\widehat{e},\widehat{t} \\ e \in E(\widehat{e})}} \text{emission_scaling}_{\widehat{e},e} \cdot \ \text{emission_tax}_{n,\widehat{e},\widehat{t},y} \cdot \text{EMISS}_{n,e,\widehat{t},y} \\ & + \sum_{s} \text{land_cost}_{n,s,y} \cdot \text{LAND}_{n,s,y} \\ & + \sum_{r} \text{relation_cost}_{r,n,y} \cdot \text{REL}_{r,n,y}\end{split}\]

Here, \(n^L \in N(n)\) are all nodes \(n^L\) that are sub-nodes of node \(n\). The subset of technologies \(t \in T(\widehat{t})\) are all tecs that belong to category \(\widehat{t}\), and similar notation is used for emissions \(e \in E\).

Resource and commodity section

Constraints on resource extraction

Equation EXTRACTION_EQUIVALENCE

This constraint translates the quantity of resources extracted (summed over all grades) to the input used by all technologies (drawing from that node). It is introduced to simplify subsequent notation in input/output relations and nodal balance constraints.

\[\begin{split}\sum_{g} \text{EXT}_{n,c,g,y} = \sum_{\substack{n^L,t,m,h,h^{\text{OD}} \\ y^V \leq y \\ \ l \in L^{\text{RES}} \subseteq L }} \text{input}_{n^L,t,y^V,y,m,n,c,l,h,h^{\text{OD}}} \cdot \text{ACT}_{n^L,t,m,y,h}\end{split}\]

The set \(L^{\text{RES}} \subseteq L\) denotes all levels for which the detailed representation of resources applies.

Equation EXTRACTION_BOUND_UP

This constraint specifies an upper bound on resource extraction by grade.

\[\text{EXT}_{n,c,g,y} \leq \text{bound_extraction_up}_{n,c,g,y}\]

Equation RESOURCE_CONSTRAINT

This constraint restricts that resource extraction in a year guarantees the “remaining resources” constraint, i.e., only a given fraction of remaining resources can be extracted per year.

\[\begin{split}\text{EXT}_{n,c,g,y} \leq \text{resource_remaining}_{n,c,g,y} \cdot \Big( & \text{resource_volume}_{n,c,g} \\ & - \sum_{y' < y} \text{duration_period}_{y'} \cdot \text{EXT}_{n,c,g,y'} \Big)\end{split}\]

Equation RESOURCE_HORIZON

This constraint ensures that total resource extraction over the model horizon does not exceed the available resources.

\[\sum_{y} \text{duration_period}_{y} \cdot \text{EXT}_{n,c,g,y} \leq \text{resource_volume}_{n,c,g}\]

Constraints on commodities and stocks

Auxiliary COMMODITY_BALANCE

For the commodity balance constraints below, we introduce an auxiliary variable called \(\text{COMMODITY_BALANCE}\). This is implemented as a GAMS $macro function.

\[\begin{split}\sum_{\substack{n^L,t,m,h^A \\ y^V \leq y}} \text{output}_{n^L,t,y^V,y,m,n,c,l,h^A,h} \cdot \text{duration_time_rel}_{h,h^A} \cdot \text{ACT}_{n^L,t,y^V,y,m,h^A} & \\ - \sum_{\substack{n^L,t,m,h^A \\ y^V \leq y}} \text{input}_{n^L,t,y^V,y,m,n,c,l,h^A,h} \cdot \text{duration_time_rel}_{h,h^A} \cdot \text{ACT}_{n^L,t,m,y,h^A} & \\ + \ \text{STOCK_CHG}_{n,c,l,y,h} + \ \sum_s \Big( \text{land_output}_{n,s,y,c,l,h} - \text{land_input}_{n,s,y,c,l,h} \Big) \cdot & \text{LAND}_{n,s,y} \\[4pt] - \ \text{demand_fixed}_{n,c,l,y,h} = \text{COMMODITY_BALANCE}_{n,c,l,y,h} \quad \forall \ l \notin (L^{\text{RES}}, & L^{\text{REN}}, L^{\text{STOR}} \subseteq L)\end{split}\]

The commodity balance constraint at the resource level is included in the Equation RESOURCE_CONSTRAINT, while at the renewable level, it is included in the Equation RENEWABLES_EQUIVALENCE, and at the storage level, it is included in the Equation STORAGE_BALANCE.

Equation COMMODITY_BALANCE_GT

This constraint ensures that supply is greater or equal than demand for every commodity-level combination.

\[\text{COMMODITY_BALANCE}_{n,c,l,y,h} \geq 0\]

Equation COMMODITY_BALANCE_LT

This constraint ensures that the supply is smaller than or equal to the demand for all commodity-level combinations given in the \(\text{balance_equality}_{c,l}\). In combination with the constraint above, it ensures that supply is (exactly) equal to demand.

\[\text{COMMODITY_BALANCE}_{n,c,l,y,h} \leq 0\]

Equation STOCKS_BALANCE

This constraint ensures the inter-temporal balance of commodity stocks. The parameter \(\text{commodity_stocks}_{n,c,l}\) can be used to model exogenous additions to the stock

\[\begin{split}\text{STOCK}_{n,c,l,y} + \text{commodity_stock}_{n,c,l,y} = \text{duration_period}_{y} \cdot & \sum_{h} \text{STOCK_CHG}_{n,c,l,y,h} \\ & + \text{STOCK}_{n,c,l,y+1}\end{split}\]

Technology section

Technical and engineering constraints

The first set of constraints concern technologies that have explicit investment decisions and where installed/maintained capacity is relevant for operational decisions. The set where \(T^{\text{INV}} \subseteq T\) is the set of all these technologies.

Equation CAPACITY_CONSTRAINT

This constraint ensures that the actual activity of a technology at a node cannot exceed available (maintained) capacity summed over all vintages, including the technology capacity factor \(\text{capacity_factor}_{n,t,y,t}\).

\[\sum_{m} \text{ACT}_{n,t,y^V,y,m,h} \leq \text{duration_time}_{h} \cdot \text{capacity_factor}_{n,t,y^V,y,h} \cdot \text{CAP}_{n,t,y^V,y} \quad \forall \ t \ \in \ T^{\text{INV}}\]

Equation CAPACITY_MAINTENANCE_HIST

The following three constraints implement technology capacity maintenance over time to allow early retirment. The optimization problem determines the optimal timing of retirement, when fixed operation-and-maintenance costs exceed the benefit in the objective function.

The first constraint ensures that historical capacity (built prior to the model horizon) is available as installed capacity in the first model period.

\[\begin{split}\text{CAP}_{n,t,y^V,\text{'first_period'}} & \leq \text{remaining_capacity}_{n,t,y^V,\text{'first_period'}} \cdot \text{duration_period}_{y^V} \cdot \text{historical_new_capacity}_{n,t,y^V} \\ & \text{if } y^V < \text{'first_period'} \text{ and } |y| - |y^V| < \text{technical_lifetime}_{n,t,y^V} \quad \forall \ t \in T^{\text{INV}}\end{split}\]

Equation CAPACITY_MAINTENANCE_NEW

The second constraint ensures that capacity is fully maintained throughout the model period in which it was constructed (no early retirement in the period of construction).

\[\text{CAP}_{n,t,y^V,y^V} = \text{remaining_capacity}_{n,t,y^V,y^V} \cdot \text{duration_period}_{y^V} \cdot \text{CAP_NEW}_{n,t,y^V} \quad \forall \ t \in T^{\text{INV}}\]

The current formulation does not account for construction time in the constraints, but only adds a mark-up to the investment costs in the objective function.

Equation CAPACITY_MAINTENANCE

The third constraint implements the dynamics of capacity maintenance throughout the model horizon. Installed capacity can be maintained over time until decommissioning, which is irreversible.

\[\begin{split}\text{CAP}_{n,t,y^V,y} & \leq \text{remaining_capacity}_{n,t,y^V,y} \cdot \text{CAP}_{n,t,y^V,y-1} \\ \quad & \text{if } y > y^V \text{ and } y^V > \text{'first_period'} \text{ and } |y| - |y^V| < \text{technical_lifetime}_{n,t,y^V} \quad \forall \ t \in T^{\text{INV}}\end{split}\]

Equation OPERATION_CONSTRAINT

This constraint provides an upper bound on the total operation of installed capacity over a year. It can be used to represent reuqired scheduled unavailability of installed capacity.

\[\sum_{m,h} \text{ACT}_{n,t,y^V,y,m,h} \leq \text{operation_factor}_{n,t,y^V,y} \cdot \text{capacity_factor}_{n,t,y^V,y,m,\text{'year'}} \cdot \text{CAP}_{n,t,y^V,y} \quad \forall \ t \in T^{\text{INV}}\]

This constraint is only active if \(\text{operation_factor}_{n,t,y^V,y} < 1\).

Equation MIN_UTILIZATION_CONSTRAINT

This constraint provides a lower bound on the total utilization of installed capacity over a year.

\[\sum_{m,h} \text{ACT}_{n,t,y^V,y,m,h} \geq \text{min_utilization_factor}_{n,t,y^V,y} \cdot \text{CAP}_{n,t,y^V,y} \quad \forall \ t \in T^{\text{INV}}\]

This constraint is only active if \(\text{min_utilization_factor}_{n,t,y^V,y}\) is defined.

Constraints representing renewable integration

Equation RENEWABLES_EQUIVALENCE

This constraint defines the auxiliary variables \(\text{REN}\) to be equal to the output of renewable technologies (summed over grades).

\[\begin{split}\sum_{g} \text{REN}_{n,t,c,g,y,h} \leq \sum_{\substack{n,t,m,l,h,h^{\text{OD}} \\ y^V \leq y \\ \ l \in L^{\text{REN}} \subseteq L }} \text{input}_{n^L,t,y^V,y,m,n,c,l,h,h^{\text{OD}}} \cdot \text{ACT}_{n^L,t,m,y,h}\end{split}\]

The set \(L^{\text{REN}} \subseteq L\) denotes all levels for which the detailed representation of renewables applies.

Equation RENEWABLES_POTENTIAL_CONSTRAINT

This constraint sets the potential potential by grade as the upper bound for the auxiliary variable \(REN\).

\[\begin{split}\sum_{\substack{t,h \\ \ t \in T^{R} \subseteq t }} \text{REN}_{n,t,c,g,y,h} \leq \sum_{\substack{l \\ l \in L^{R} \subseteq L }} \text{renewable_potential}_{n,c,g,l,y}\end{split}\]

Equation RENEWABLES_CAPACITY_REQUIREMENT

This constraint connects the capacity factor of a renewable grade to the installed capacity of a technology. It sets the lower limit for the capacity of a renewable technology to the summed activity over all grades (REN) devided by the capactiy factor of this grade. It represents the fact that different renewable grades require different installed capacities to provide their full potential.

\[\begin{split}\sum_{y^V, h} & \text{CAP}_{n,t,y^V,y} \cdot \text{operation_factor}_{n,t,y^V,y} \cdot \text{capacity_factor}_{n,t,y^V,y,h} \\ & \quad \geq \sum_{g,h,l} \frac{1}{\text{renewable_capacity_factor}_{n,c,g,l,y}} \cdot \text{REN}_{n,t,c,g,y,h}\end{split}\]

This constraint is only active if \(\text{renewable_capacity_factor}_{n,c,g,l,y}\) is defined.

Constraints for addon technologies

Equation ADDON_ACTIVITY_UP

This constraint provides an upper bound on the activity of an addon technology that can only be operated jointly with a parent technology (e.g., abatement option, SO2 scrubber, power plant cooling technology).

\[\begin{split}\sum_{\substack{t^a, y^V \leq y}} \text{ACT}_{n,t^a,y^V,y,m,h} \leq \sum_{\substack{t, y^V \leq y}} & \text{addon_up}_{n,t,y,m,h,\widehat{t^a}} \cdot \text{addon_conversion}_{n,t,y^V,y,m,h,\widehat{t^a}} \\ & \cdot \text{ACT}_{n,t,y^V,y,m,h} \quad \forall \ t^a \in T^{A}\end{split}\]

Equation ADDON_ACTIVITY_LO

This constraint provides a lower bound on the activity of an addon technology that has to be operated jointly with a parent technology (e.g., power plant cooling technology). The parameter addon_lo allows to define a minimum level of operation of addon technologies relative to the activity of the parent technology. If addon_lo = 1, this means that it is mandatory to operate the addon technology at the same level as the parent technology (i.e., full mitigation).

\[\begin{split}\sum_{\substack{t^a, y^V \leq y}} \text{ACT}_{n,t^a,y^V,y,m,h} \geq \sum_{\substack{t, y^V \leq y}} & \text{addon_lo}_{n,t,y,m,h,\widehat{t^a}} \cdot \text{addon_conversion}_{n,t,y^V,y,m,h,\widehat{t^a}} \\ & \cdot \text{ACT}_{n,t,y^V,y,m,h} \quad \forall \ t^a \in T^{A}\end{split}\]

System reliability and flexibility requirements

This section followi allows to include system-wide reliability and flexility considerations. The current formulation is based on Sullivan et al., 2013 [11].

Aggregate use of a commodity

The system reliability and flexibility constraints are implemented using an auxiliary variable representing the total use (i.e., input of each commodity per level).

Equation COMMODITY_USE_LEVEL

This constraint defines the auxiliary variable \(\text{COMMODITY_USE}_{n,c,l,y}\), which is used to define the rating bins and the peak-load that needs to be offset with firm (dispatchable) capacity.

\[\begin{split}\text{COMMODITY_USE}_{n,c,l,y} = & \sum_{n^L,t,y^V,m,h} \text{input}_{n^L,t,y^V,y,m,n,c,l,h,h} \\ & \quad \cdot \text{duration_time_rel}_{h,h} \cdot \text{ACT}_{n^L,t,y^V,y,m,h}\end{split}\]

This constraint and the auxiliary variable is only active if \(\text{peak_load_factor}_{n,c,l,y,h}\) or \(\text{flexibility_factor}_{n,t,y^V,y,m,c,l,h,r}\) is defined.

Auxilary variables for technology activity by “rating bins”

The capacity and activity of certain (usually non-dispatchable) technologies can be assumed to only partially contribute to the system reliability and flexibility requirements.

Equation ACTIVITY_RATING_BIN

The auxiliary variable for rating-specific activity of each technology cannot exceed the share of the rating bin in relation to the total commodity use.

\[\text{ACT_RATING}_{n,t,y^V,y,c,l,h,q} \leq \text{rating_bin}_{n,t,y,c,l,h,q} \cdot \text{COMMODITY_USE}_{n,c,l,y}\]

Equation ACTIVITY_SHARE_TOTAL

The sum of the auxiliary rating-specific activity variables need to equal the total input and/or output of the technology.

\[\begin{split}\sum_q \text{ACT_RATING}_{n,t,y^V,y,c,l,h,q} = \sum_{\substack{n^L,t,m,h^A \\ y^V \leq y}} & ( \text{input}_{n^L,t,y^V,y,m,n,c,l,h^A,h} + \text{output}_{n^L,t,y^V,y,m,n,c,l,h^A,h} ) \\ & \quad \cdot \text{duration_time_rel}_{h,h^A} \cdot \text{ACT}_{n^L,t,y^V,y,m,h^A} \\\end{split}\]

Reliability of installed capacity

The “firm capacity” that a technology can contribute to system reliability depends on its dispatch characteristics. For dispatchable technologies, the total installed capacity counts toward the firm capacity constraint. This is active if the parameter is defined over \(\text{reliability_factor}_{n,t,y,c,l,h,\text{'firm'}}\). For non-dispatchable technologies, or those that do not have explicit investment decisions, the contribution to system reliability is calculated by using the auxiliary variable \(\text{ACT_RATING}_{n,t,y^V,y,c,l,h,q}\) as a proxy, with the \(\text{reliability_factor}_{n,t,y,c,l,h,q}\) defined per rating bin \(q\).

Equation FIRM_CAPACITY_PROVISION

Technologies where the reliability factor is defined with the rating firm have an auxiliary variable \(\text{CAP_FIRM}_{n,t,c,l,y}\), defined in terms of output.

\[\begin{split}\text{CAP_FIRM}_{n,t,c,l,y} = \sum_{y^V \leq y} & \text{output}_{n^L,t,y^V,y,m,n,c,l,h^A,h} \cdot \text{duration_time}_h \\ & \quad \cdot \text{capacity_factor}_{n,t,y^V,y,h} \cdot \text{CAP}_{n,t,y^Y,y} \quad \forall \ t \in T^{\text{INV}}\end{split}\]

Equation SYSTEM_RELIABILITY_CONSTRAINT

This constraint ensures that there is sufficient firm (dispatchable) capacity in each period. The formulation is based on Sullivan et al., 2013 [11].

\[\begin{split}\sum_{t, q \substack{t \in T^{\text{INV}} \\ y^V \leq y} } & \text{reliability_factor}_{n,t,y,c,l,h,\text{'firm'}} \cdot \text{CAP_FIRM}_{n,t,c,l,y} \\ + \sum_{t,q,y^V \leq y} & \text{reliability_factor}_{n,t,y,c,l,h,q} \cdot \text{ACT_RATING}_{n,t,y^V,y,c,l,h,q} \\ & \quad \geq \text{peak_load_factor}_{n,c,l,y,h} \cdot \text{COMMODITY_USE}_{n,c,l,y}\end{split}\]

This constraint is only active if \(\text{peak_load_factor}_{n,c,l,y,h}\) is defined.

Equation SYSTEM_FLEXIBILITY_CONSTRAINT

This constraint ensures that, in each sub-annual time slice, there is a sufficient contribution from flexible technologies to ensure smooth system operation.

\[\begin{split}\sum_{\substack{n^L,t,m,h^A \\ y^V \leq y}} & \text{flexibility_factor}_{n^L,t,y^V,y,m,c,l,h,\text{'unrated'}} \\ & \quad \cdot ( \text{output}_{n^L,t,y^V,y,m,n,c,l,h^A,h} + \text{input}_{n^L,t,y^V,y,m,n,c,l,h^A,h} ) \\ & \quad \cdot \text{duration_time_rel}_{h,h^A} \cdot \text{ACT}_{n,t,y^V,y,m,h} \\ + \sum_{\substack{n^L,t,m,h^A \\ y^V \leq y}} & \text{flexibility_factor}_{n^L,t,y^V,y,m,c,l,h,1} \\ & \quad \cdot ( \text{output}_{n^L,t,y^V,y,m,n,c,l,h^A,h} + \text{input}_{n^L,t,y^V,y,m,n,c,l,h^A,h} ) \\ & \quad \cdot \text{duration_time_rel}_{h,h^A} \cdot \text{ACT_RATING}_{n,t,y^V,y,c,l,h,q} \geq 0\end{split}\]

Bounds on capacity and activity

Equation NEW_CAPACITY_BOUND_UP

This constraint provides upper bounds on new capacity installation.

\[\text{CAP_NEW}_{n,t,y} \leq \text{bound_new_capacity_up}_{n,t,y} \quad \forall \ t \ \in \ T^{\text{INV}}\]

Equation NEW_CAPACITY_BOUND_LO

This constraint provides lower bounds on new capacity installation.

\[\text{CAP_NEW}_{n,t,y} \geq \text{bound_new_capacity_lo}_{n,t,y} \quad \forall \ t \ \in \ T^{\text{INV}}\]

Equation TOTAL_CAPACITY_BOUND_UP

This constraint gives upper bounds on the total installed capacity of a technology in a specific year of operation summed over all vintages.

\[\sum_{y^V \leq y} \text{CAP}_{n,t,y,y^V} \leq \text{bound_total_capacity_up}_{n,t,y} \quad \forall \ t \ \in \ T^{\text{INV}}\]

Equation TOTAL_CAPACITY_BOUND_LO

This constraint gives lower bounds on the total installed capacity of a technology.

\[\sum_{y^V \leq y} \text{CAP}_{n,t,y,y^V} \geq \text{bound_total_capacity_lo}_{n,t,y} \quad \forall \ t \ \in \ T^{\text{INV}}\]

Equation ACTIVITY_BOUND_UP

This constraint provides upper bounds by mode of a technology activity, summed over all vintages.

\[\sum_{y^V \leq y} \text{ACT}_{n,t,y^V,y,m,h} \leq \text{bound_activity_up}_{n,t,m,y,h}\]

Equation ACTIVITY_BOUND_ALL_MODES_UP

This constraint provides upper bounds of a technology activity across all modes and vintages.

\[\sum_{y^V \leq y, m} \text{ACT}_{n,t,y^V,y,m,h} \leq \text{bound_activity_up}_{n,t,y,'all',h}\]

Equation ACTIVITY_BOUND_LO

This constraint provides lower bounds by mode of a technology activity, summed over all vintages.

\[\sum_{y^V \leq y} \text{ACT}_{n,t,y^V,y,m,h} \geq \text{bound_activity_lo}_{n,t,y,m,h}\]

We assume that \(\text{bound_activity_lo}_{n,t,y,m,h} = 0\) unless explicitly stated otherwise.

Equation ACTIVITY_BOUND_ALL_MODES_LO

This constraint provides lower bounds of a technology activity across all modes and vintages.

\[\sum_{y^V \leq y, m} \text{ACT}_{n,t,y^V,y,m,h} \geq \text{bound_activity_lo}_{n,t,y,'all',h}\]

We assume that \(\text{bound_activity_lo}_{n,t,y,'all',h} = 0\) unless explicitly stated otherwise.

Constraints on shares of technologies and commodities

This section allows to include upper and lower bounds on the shares of modes used by a technology or the shares of commodities produced or consumed by groups of technologies.

Share constraints on activity by mode

Equation SHARES_MODE_UP

This constraint provides upper bounds of the share of the activity of one mode of a technology. For example, it could limit the share of heat that can be produced in a combined heat and electricity power plant.

\[\text{ACT}_{n^L,t,y^V,y,m,h^A} \leq \text{share_mode_up}_{p,n,t,y,m,h} \cdot \sum_{m'} \text{ACT}_{n^L,t,y^V,y,m',h^A}\]

Equation SHARES_MODE_LO

This constraint provides lower bounds of the share of the activity of one mode of a technology.

\[\text{ACT}_{n^L,t,y^V,y,m,h^A} \geq \text{share_mode_lo}_{p,n,t,y,m,h} \cdot \sum_{m'} \text{ACT}_{n^L,t,y^V,y,m',h^A}\]

Share constraints on commodities

These constraints allow to set upper and lower bound on the quantity of commodities produced or consumed by a group of technologies relative to the commodities produced or consumed by another group.

The implementation is generic and flexible, so that any combination of commodities, levels, technologies and nodes can be put in relation to any other combination.

The notation \(P^{\text{share}}\) represents the mapping set map_shares_commodity_share denoting all technology types, nodes, commodities and levels to be included in the numerator, and \(P^{\text{total}}\) is the equivalent mapping set map_shares_commodity_total for the denominator.

Equation SHARE_CONSTRAINT_COMMODITY_UP

\[\begin{split}& \sum_{\substack{n^L,t,m,h^A \\ y^V \leq y, (n,\widehat{t},m,c,l) \sim P^{\text{share}}}} ( \text{output}_{n^L,t,y^V,y,m,n,c,l,h^A,h} + \text{input}_{n^L,t,y^V,y,m,n,c,l,h^A,h} ) \\ & \quad \cdot \text{duration_time_rel}_{h,h^A} \cdot \text{ACT}_{n^L,t,y^V,y,m,h^A} \\ & \geq \text{share_commodity_up}_{p,n,y,h} \cdot \sum_{\substack{n^L,t,m,h^A \\ y^V \leq y, (n,\widehat{t},m,c,l) \sim P^{\text{total}}}} ( \text{output}_{n^L,t,y^V,y,m,n,c,l,h^A,h} + \text{input}_{n^L,t,y^V,y,m,n,c,l,h^A,h} ) \\ & \quad \cdot \text{duration_time_rel}_{h,h^A} \cdot \text{ACT}_{n^L,t,y^V,y,m,h^A}\end{split}\]

This constraint is only active if \(\text{share_commodity_up}_{p,n,y,h}\) is defined.

Equation SHARE_CONSTRAINT_COMMODITY_LO

\[\begin{split}& \sum_{\substack{n^L,t,m,h^A \\ y^V \leq y, (n,\widehat{t},m,c,l) \sim P^{\text{share}}}} ( \text{output}_{n^L,t,y^V,y,m,n,c,l,h^A,h} + \text{input}_{n^L,t,y^V,y,m,n,c,l,h^A,h} ) \\ & \quad \cdot \text{duration_time_rel}_{h,h^A} \cdot \text{ACT}_{n^L,t,y^V,y,m,h^A} \\ & \leq \text{share_commodity_lo}_{p,n,y,h} \cdot \sum_{\substack{n^L,t,m,h^A \\ y^V \leq y, (n,\widehat{t},m,c,l) \sim P^{\text{total}}}} ( \text{output}_{n^L,t,y^V,y,m,n,c,l,h^A,h} + \text{input}_{n^L,t,y^V,y,m,n,c,l,h^A,h} ) \\ & \quad \cdot \text{duration_time_rel}_{h,h^A} \cdot \text{ACT}_{n^L,t,y^V,y,m,h^A}\end{split}\]

This constraint is only active if \(\text{share_commodity_lo}_{p,n,y,h}\) is defined.

Dynamic constraints on new capacity and activity

The constraints in this section specify dynamic upper and lower bounds on new capacity and activity. These can be used to model limits on market penetration and/or rates of expansion or phase-out of a technology.

The formulation directly includes the option for ‘soft’ relaxations of dynamic constraints (cf. Keppo and Strubegger, 2010 [5]).

See also the corresponding parameter definitions.

Equation NEW_CAPACITY_CONSTRAINT_UP

The level of new capacity additions cannot be greater than an initial value (compounded over the period duration), annual growth of the existing ‘capital stock’, and a “soft” relaxation of the upper bound.

\[\begin{split}\text{CAP_NEW}_{n,t,y} \leq & \Bigg(~ \text{initial_new_capacity_up}_{n,t,y} \cdot \frac{ \Big( 1 + \text{growth_new_capacity_up}_{n,t,y} \Big)^{|y|} - 1 } { \text{growth_new_capacity_up}_{n,t,y} } \\ & + \Big( \text{CAP_NEW}_{n,t,y-1} + \text{historical_new_capacity}_{n,t,y-1} \Big) \\ & \hspace{2 cm} \cdot \Big( 1 + \text{growth_new_capacity_up}_{n,t,y} \Big)^{|y|} \\ & + \text{CAP_NEW_UP}_{n,t,y} \cdot \Bigg( \Big( 1 + \text{soft_new_capacity_up}_{n,t,y}\Big)^{|y|} - 1 \Bigg)\Bigg) \\ & * \frac{|y-1|}{|y|} \\ & \quad \forall \ t \ \in \ T^{\text{INV}}\end{split}\]

Here, \(|y|\) is the number of years in period \(y\), i.e., \(\text{duration_period}_{y}\).

Equation NEW_CAPACITY_SOFT_CONSTRAINT_UP

This constraint ensures that the relaxation of the dynamic constraint on new capacity (investment) does not exceed the level of the investment in the previous period (cf. Keppo and Strubegger, 2010 [5]).

\[\begin{split}\text{CAP_NEW_UP}_{n,t,y} \leq \sum_{y-1} \text{CAP_NEW}_{n^L,t,y-1} & \text{if } y \neq \text{'first_period'} \\ + \sum_{y-1} \text{historical_new_capacity}_{n^L,t,y-1} & \text{if } y = \text{'first_period'} \\ \quad \forall \ t \ \in \ T^{\text{INV}}\end{split}\]

Equation NEW_CAPACITY_CONSTRAINT_LO

This constraint gives dynamic lower bounds on new capacity.

\[\begin{split}\text{CAP_NEW}_{n,t,y} \geq & \Bigg(- \text{initial_new_capacity_lo}_{n,t,y} \cdot \frac{ \Big( 1 + \text{growth_new_capacity_lo}_{n,t,y} \Big)^{|y|} } { \text{growth_new_capacity_lo}_{n,t,y} } \\ & + \Big( \text{CAP_NEW}_{n,t,y-1} + \text{historical_new_capacity}_{n,t,y-1} \Big) \\ & \hspace{2 cm} \cdot \Big( 1 + \text{growth_new_capacity_lo}_{n,t,y} \Big)^{|y|} \\ & - \text{CAP_NEW_LO}_{n,t,y} \cdot \Bigg( \Big( 1 + \text{soft_new_capacity_lo}_{n,t,y}\Big)^{|y|} - 1 \Bigg)\Bigg) \\ & * \frac{|y-1|}{|y|} \\ & \quad \forall \ t \ \in \ T^{\text{INV}}\end{split}\]

Equation NEW_CAPACITY_SOFT_CONSTRAINT_LO

This constraint ensures that the relaxation of the dynamic constraint on new capacity does not exceed level of the investment in the previous year.

\[\begin{split}\text{CAP_NEW_LO}_{n,t,y} \leq \sum_{y-1} \text{CAP_NEW}_{n^L,t,y-1} & \text{if } y \neq \text{'first_period'} \\ + \sum_{y-1} \text{historical_new_capacity}_{n^L,t,y-1} & \text{if } y = \text{'first_period'} \\ \quad \forall \ t \ \in \ T^{\text{INV}}\end{split}\]

Equation ACTIVITY_CONSTRAINT_UP

This constraint gives dynamic upper bounds on the market penetration of a technology activity.

\[\begin{split}\sum_{y^V \leq y,m} \text{ACT}_{n,t,y^V,y,m,h} \leq & ~ \text{initial_activity_up}_{n,t,y,h} \cdot \frac{ \Big( 1 + \text{growth_activity_up}_{n,t,y,h} \Big)^{|y|} - 1 } { \text{growth_activity_up}_{n,t,y,h} } \\ & + \bigg( \sum_{y^V \leq y-1,m} \text{ACT}_{n,t,y^V,y-1,m,h} + \sum_{m} \text{historical_activity}_{n,t,y-1,m,h} \bigg) \\ & \hspace{2 cm} \cdot \Big( 1 + \text{growth_activity_up}_{n,t,y,h} \Big)^{|y|} \\ & + \text{ACT_UP}_{n,t,y,h} \cdot \Bigg( \Big( 1 + \text{soft_activity_up}_{n,t,y,h} \Big)^{|y|} - 1 \Bigg)\end{split}\]

Equation ACTIVITY_SOFT_CONSTRAINT_UP

This constraint ensures that the relaxation of the dynamic activity constraint does not exceed the level of the activity in the previous period.

\[\begin{split}\text{ACT_UP}_{n,t,y,h} \leq \sum_{y^V \leq y,m,y-1} \text{ACT}_{n^L,t,y^V,y-1,m,h} & \text{if } y \neq \text{'first_period'} \\ + \sum_{m,y-1} \text{historical_activity}_{n^L,t,y-1,m,h} & \text{if } y = \text{'first_period'}\end{split}\]

Equation ACTIVITY_CONSTRAINT_LO

This constraint gives dynamic lower bounds on the market penetration of a technology activity.

\[\begin{split}\sum_{y^V \leq y,m} \text{ACT}_{n,t,y^V,y,m,h} \geq & - \text{initial_activity_lo}_{n,t,y,h} \cdot \frac{ \Big( 1 + \text{growth_activity_lo}_{n,t,y,h} \Big)^{|y|} - 1 } { \text{growth_activity_lo}_{n,t,y,h} } \\ & + \bigg( \sum_{y^V \leq y-1,m} \text{ACT}_{n,t,y^V,y-1,m,h} + \sum_{m} \text{historical_activity}_{n,t,y-1,m,h} \bigg) \\ & \hspace{2 cm} \cdot \Big( 1 + \text{growth_activity_lo}_{n,t,y,h} \Big)^{|y|} \\ & - \text{ACT_LO}_{n,t,y,h} \cdot \Bigg( \Big( 1 + \text{soft_activity_lo}_{n,t,y,h} \Big)^{|y|} - 1 \Bigg)\end{split}\]

Equation ACTIVITY_SOFT_CONSTRAINT_LO

This constraint ensures that the relaxation of the dynamic activity constraint does not exceed the level of the activity in the previous period.

\[\begin{split}\text{ACT_LO}_{n,t,y,h} \leq \sum_{y^V \leq y,m,y-1} \text{ACT}_{n^L,t,y^V,y-1,m,h} & \text{if } y \neq \text{'first_period'} \\ + \sum_{m,y-1} \text{historical_activity}_{n^L,t,y-1,m,h} & \text{if } y = \text{'first_period'}\end{split}\]

Emission section

Auxiliary variable for aggregate emissions

Equation EMISSION_EQUIVALENCE

This constraint simplifies the notation of emissions aggregated over different technology types and the land-use model emulator. The formulation includes emissions from all sub-nodes \(n^L\) of \(n\).

\[\begin{split}\text{EMISS}_{n,e,\widehat{t},y} = \sum_{n^L \in N(n)} \Bigg( \sum_{t \in T(\widehat{t}),y^V \leq y,m,h } \text{emission_factor}_{n^L,t,y^V,y,m,e} \cdot \text{ACT}_{n^L,t,y^V,y,m,h} \\ + \sum_{s} \ \text{land_emission}_{n^L,s,y,e} \cdot \text{LAND}_{n^L,s,y} \text{ if } \widehat{t} \in \widehat{T}^{LAND} \Bigg)\end{split}\]

Bound on emissions

Equation EMISSION_CONSTRAINT

This constraint enforces upper bounds on emissions (by emission type). For all bounds that include multiple periods, the parameter \(\text{bound_emission}_{n,\widehat{e},\widehat{t},\widehat{y}}\) is scaled to represent average annual emissions over all years included in the year-set \(\widehat{y}\).

The formulation includes historical emissions and allows to model constraints ranging over both the model horizon and historical periods.

\[\begin{split}\frac{ \sum_{y' \in Y(\widehat{y}), e \in E(\widehat{e})} \begin{array}{l} \text{duration_period}_{y'} \cdot \text{emission_scaling}_{\widehat{e},e} \cdot \\ \Big( \text{EMISS}_{n,e,\widehat{t},y'} + \sum_{m} \text{historical_emission}_{n,e,\widehat{t},y'} \Big) \end{array} } { \sum_{y' \in Y(\widehat{y})} \text{duration_period}_{y'} } \leq \text{bound_emission}_{n,\widehat{e},\widehat{t},\widehat{y}}\end{split}\]

Land-use model emulator section

Bounds on total land use

Equation LAND_CONSTRAINT

This constraint enforces a meaningful result of the land-use model emulator, in particular a bound on the total land used in MESSAGEix. The linear combination of land scenarios must be equal to 1.

\[\sum_{s \in S} \text{LAND}_{n,s,y} = 1\]

Dynamic constraints on land use

These constraints enforces upper and lower bounds on the change rate per land scenario.

Equation DYNAMIC_LAND_SCEN_CONSTRAINT_UP

\[\begin{split}\text{LAND}_{n,s,y} \leq & \text{initial_land_scen_up}_{n,s,y} \cdot \frac{ \Big( 1 + \text{growth_land_scen_up}_{n,s,y} \Big)^{|y|} - 1 } { \text{growth_land_scen_up}_{n,s,y} } \\ & + \big( \text{LAND}_{n,s,y-1} + \text{historical_land}_{n,s,y-1} \big) \cdot \Big( 1 + \text{growth_land_scen_up}_{n,s,y} \Big)^{|y|}\end{split}\]

Equation DYNAMIC_LAND_SCEN_CONSTRAINT_LO

\[\begin{split}\text{LAND}_{n,s,y} \geq & - \text{initial_land_scen_lo}_{n,s,y} \cdot \frac{ \Big( 1 + \text{growth_land_scen_lo}_{n,s,y} \Big)^{|y|} - 1 } { \text{growth_land_scen_lo}_{n,s,y} } \\ & + \big( \text{LAND}_{n,s,y-1} + \text{historical_land}_{n,s,y-1} \big) \cdot \Big( 1 + \text{growth_land_scen_lo}_{n,s,y} \Big)^{|y|}\end{split}\]

These constraints enforces upper and lower bounds on the change rate per land type determined as a linear combination of land use scenarios.

Equation DYNAMIC_LAND_TYPE_CONSTRAINT_UP

\[\begin{split}\sum_{s \in S} \text{land_use}_{n,s,y,u} &\cdot \text{LAND}_{n,s,y} \leq \text{initial_land_up}_{n,y,u} \cdot \frac{ \Big( 1 + \text{growth_land_up}_{n,y,u} \Big)^{|y|} - 1 } { \text{growth_land_up}_{n,y,u} } \\ & + \Big( \sum_{s \in S} \big( \text{land_use}_{n,s,y-1,u} + \text{dynamic_land_up}_{n,s,y-1,u} \big) \\ & \quad \quad \cdot \big( \text{LAND}_{n,s,y-1} + \text{historical_land}_{n,s,y-1} \big) \Big) \\ & \quad \cdot \Big( 1 + \text{growth_land_up}_{n,y,u} \Big)^{|y|}\end{split}\]

Equation DYNAMIC_LAND_TYPE_CONSTRAINT_LO

\[\begin{split}\sum_{s \in S} \text{land_use}_{n,s,y,u} &\cdot \text{LAND}_{n,s,y} \geq - \text{initial_land_lo}_{n,y,u} \cdot \frac{ \Big( 1 + \text{growth_land_lo}_{n,y,u} \Big)^{|y|} - 1 } { \text{growth_land_lo}_{n,y,u} } \\ & + \Big( \sum_{s \in S} \big( \text{land_use}_{n,s,y-1,u} + \text{dynamic_land_lo}_{n,s,y-1,u} \big) \\ & \quad \quad \cdot \big( \text{LAND}_{n,s,y-1} + \text{historical_land}_{n,s,y-1} \big) \Big) \\ & \quad \cdot \Big( 1 + \text{growth_land_lo}_{n,y,u} \Big)^{|y|}\end{split}\]

Section of generic relations (linear constraints)

This feature is intended for development and testing only - all new features should be implemented as specific new mathematical formulations and associated sets & parameters!

Auxiliary variable for left-hand side

Equation RELATION_EQUIVALENCE

\[\begin{split}\text{REL}_{r,n,y} = \sum_{t} \Bigg( & \ \text{relation_new_capacity}_{r,n,y,t} \cdot \text{CAP_NEW}_{n,t,y} \\[4 pt] & + \text{relation_total_capacity}_{r,n,y,t} \cdot \sum_{y^V \leq y} \ \text{CAP}_{n,t,y^V,y} \\ & + \sum_{n^L,y',m,h} \ \text{relation_activity}_{r,n,y,n^L,t,y',m} \\ & \quad \quad \cdot \Big( \sum_{y^V \leq y'} \text{ACT}_{n^L,t,y^V,y',m,h} + \text{historical_activity}_{n^L,t,y',m,h} \Big) \Bigg)\end{split}\]

The parameter \(\text{historical_new_capacity}_{r,n,y}\) is not included here, because relations can only be active in periods included in the model horizon and there is no “writing” of capacity relation factors across periods.

Upper and lower bounds on user-defined relations

Equation RELATION_CONSTRAINT_UP

\[\text{REL}_{r,n,y} \leq \text{relation_upper}_{r,n,y}\]

Equation RELATION_CONSTRAINT_LO

\[\text{REL}_{r,n,y} \geq \text{relation_lower}_{r,n,y}\]

Storage section

MESSAGEix offers a set of equations to represent a wide range of storage solutions flexibly. Storage solutions are modeled as “technologies” that can be used to store a “commodity” (e.g., water, heat, electricity, etc.) and shift it over sub-annual time slices within one model period. The storage solution presented here has three distinct parts: (i) Charger: a technology for charging a commodity to the storage container, for example, a pump in a pumped hydropower storage (PHS) plant. (ii) Discharger: a technology to convert the stored commodity to the output commodity, e.g., a turbine in PHS. (iii) Storage container: a device for storing a commodity over time, such as a water reservoir in PHS. If desired, the user can combine charger and discharger parts into one technology, using two different “modes” of operation for that technology like turbo-machinery in PHS. This way the capacity related information, like investment cost, lifetime, capacity factor, etc., will be defined only for one technology (i.e., charger-discharger), as opposed to modeling these two parts separately.

../../_images/storage.png

Storage equations

The content of storage device depends on three factors: charge or discharge in one time slice (represented by Equation STORAGE_CHANGE), linked to the state of charge in the previous time slice and storage losses between these two consecutive time slices (represented by Equation STORAGE_BALANCE). Moreover, the storage device can be optionally filled with an initial value as percentage of its capacity (see more details under Equation STORAGE_BALANCE_INIT). Another option is to link a commodity for maintaining the operation of storage device over time (see Equation STORAGE_INPUT).

Equation STORAGE_CHANGE

This equation shows the change in the content of the storage container in each sub-annual time slice. This change is based on the activity of charger and discharger technologies connected to that storage container. The notation \(S^{\text{storage}}\) represents the mapping set map_tec_storage denoting charger-discharger technologies connected to a specific storage container in a specific node and storage level. Where:

  • \(t^{C}\) is a charging technology and \(t^{D}\) is the corresponding discharger.

  • \(h-1\) is the time slice prior to \(h\).

  • \(l^{T}\) is lvl_temporal, i.e., the temporal level at which storage is operating

  • \(m^{S}\) is mode of operation for storage container technology

    \[\begin{split}\text{STORAGE_CHARGE}_{n,t,m^s,l,c,y,h} = \sum_{\substack{n^L,m,h-1 \\ y^V \leq y, (n,t^C,t,l,y) \sim S^{\text{storage}}}} \text{output}_{n^L,t^C,y^V,y,m,n,c,l,h-1,h} \cdot & \text{ACT}_{n^L,t^C,y^V,y,m,h-1} \\ - \sum_{\substack{n^L,m,c,h-1 \\ y^V \leq y, (n,t^D,t,l,y) \sim S^{\text{storage}}}} \text{input}_{n^L,t^D,y^V,y,m,n,c,l,h-1,h} \cdot \text{ACT}_{n^L,t^D,y^V,y,m,h-1} \quad \forall \ t \in T^{\text{STOR}}, & \forall \ l \in L^{\text{STOR}}\end{split}\]

Equation STORAGE_BALANCE

This equation ensures the commodity balance of storage technologies, where the commodity is shifted between sub-annual time slices within a model period. If the state of charge of storage is set exogenously in one time slice through \(\storageinitial_{ntlcyh}\), the content from the previous time slice is not carried over to this time slice.

\[\begin{split}\STORAGE_{ntmlcyh} =\ & \STORAGECHARGE_{ntmlcyh} \\ & + \STORAGE_{ntmlcy(h-1)} \cdot (1 - \storageselfdischarge_{ntmly(h-1)}) \\ \forall\ & t \in T^{\text{STOR}}, l \in L^{\text{STOR}}, \storageinitial_{ntmlcyh} = 0\end{split}\]

Equation STORAGE_BALANCE_INIT

Where \(\storageinitial_{ntlyh}\) has a non-zero value, this equation ensures that the amount of commodity stored at the end of a sub-annual time slice is equal or greater than the initialized content of storage in the following time slice. The values in parameter \(\storageinitial_{ntlyh}\) are percentages showing a fraction of installed capacity of storage device (container) that can be filled initially.

\[\begin{split}\STORAGE_{ntmlcy(h-1)} \geq & \storageinitial_{ntmlcyh} \cdot \text{duration_time}_{h} \cdot \text{capacity_factor}_{n,t,y^V,y,h} \cdot \text{CAP}_{n,t,y^V,y} \\ \quad \forall \ t \ \in \ T^{\text{INV}}, \forall\ & \storageinitial_{ntmlcyh} \neq 0\end{split}\]

Equation STORAGE_INPUT

This equation links \(\STORAGE\) to an input commodity to maintain the activity (\(\ACT\)) of each active storage container technology \(t\). This input commodity is distinct from the stored commodity. For example, in a pumped hydro storage solution, a user can link heating for keeping the stored water warm. In this case, the input commodity is not a function of charge or discharge, but the amount of stored media in the container over time. Therefore, the input commodity specified here is distinct from the one stored and discharged by (dis)charge technologies \(t^C,t^D\) appearing in Equation STORAGE_CHANGE.

\[\begin{split}\STORAGE_{ntmlcy^Ah} =\ & \sum_{\{n^Ly^Vh^O \vert K\}} \durationtimerel_{hh^O} \cdot \ACT_{n^Lty^Vy^Amh^O} \\ \forall\ & n,t,l,c,m,y^A,h \vert t \in T^{\text{STOR}} \\ K:\ & \\text{input}_{n^Lty^Vy^Amn^Oclhh^O} \neq 0\end{split}\]