To enable the representation of units with a high level of technical detail, the ramping ability of units can be constrained in SpineOpt. This means that the user has the freedom to impose restrictions on the change in output of units between consecutive timesteps, for online (spinning) units, units starting up and units shutting down. In this section, the concept of ramps in SpineOpt will be introduced. Furthermore, the use of reserves will be explained.
Everything that is related to ramping is defined in parameters of either the unit__to_node, unit__from_node, or unit__to_node_group relationship. Generally speaking, the ramping constraints will impose restrictions on the change in the unit_flow variable between two consecutive timesteps.
All parameters that limit the ramping abilities of a unit are expressed as a fraction of the unit capacity. This means that a value of 1 indicates the full capacity of a unit.
The discussion here will be kept conceptual, for the mathematical formulation the reader is referred to the Ramping and reserve constraints
The general principle of the Spine modelling ramping constraints is that all of these parameters can be defined separately for each unit. This allows the user to incorporate different units (which can either represent a single unit or a technology type) with different flexibility characteristics.
It should be noted that it is perfectly possible to omit all of the constraining parameters mentioned above. However, once either of the ramping parameters is defined, it is necessary to also assign values to the other parameters. E.g. if a user only wants to restrict the spinning ramp up capability of a unit, one also has to assign values to the max_startup_ramp
, min_Shutdown_Ramp
etc.
When none of the ramping parameters mentioned above are defined, the unit is considered to have full ramping flexibility. This means that in any given timestep, its output can be any value between 0 and its capacity, regardless of what the output of the unit was in the previous timestep, and regardless of the on- or offline status or the unit in the previous timestep. Provided that this does not conflict with the Unit commitment restrictions that are defined for this unit. Parameter values for a unit__node
relationship are illustratively given below.
max_shutdown_ramp
: 1min_shutdown_ramp
: 0max_start_up_ramp
: 1min_start_up_ramp
: 0ramp_up_limit
: 1ramp_down_limit
: 1unit_capacity
: 200
A unit which is only restricted in spinning ramping can be created by changing the ramp_up/down_limit
parameters:
ramp_up_limit
: 0.2ramp_down_limit
: 0.4
This parameter choice implies that the unit's output between two consecutive timesteps can change with no more than $0.2 * 200$ and no less than $0.4 * 200$. For example, when the unit is running at an output of $100$ in some timestep $t$, its output for the next timestep must be somewhere in the interval $[20,140]$. Unless it shuts down completely.
By changing the parameter max_shutdown_ramp
in the previous example, an additional restriction is imposed on the maximum output of the unit from which it can go offline.
max_shutdown_ramp
: 0.5min_shutdown_ramp
: 0.3
When this unit goes offline in a given timestep $t+1$, the output of the unit must be below $0.5*200 = 100$ in the timestep $t$ before that. Similarly, the parameter min_shutdown_ramp
can be used to impose a minimum output value in the timestep before a shutdown. For example, a value of $0.3$ in this example would mean that the unit can not be running below an output of $60$ in timestep $t$.
The startup restrictions are very similar to the shutdown restrictions, but of course apply to units that are starting up. Consider for example the same unit as in the example above, but now with a max_start_up_ramp
equal to $0.4$ and min_start_up_ramp
equal to $0.2$:
max_start_up_ramp
: 0.4min_start_up_ramp
: 0.2
When the unit is offline in timestep $t$ and comes online in timestep $t+1$, its output in timestep $t+1$ will be restricted to the interval $[40,80]$.
To include a requirement of reserve provision in a model, SpineOpt offers the possibility of creating reserve nodes. Of course reserve provision is different from regular operation, because the reserved capacity does not actually get activated. In this section, we will take a look at the things that are particular for a reserve node.
To define a reserve node, the following parameters have to be defined for the relevant node:
- is_reserve_node : this boolean parameter indicates that this node is a reserve node.
- upward_reserve : this boolean parameter indicates that the demand for reserve provision of this node concerns upward reserves.
- downward_reserve : this boolean parameter indicates that the demand for reserve provision of this node concerns downward reserves.
- reserve_procurement_cost: (optional) this parameter indicates the procurement cost of a unit for a certain reserve product and can be define on a unit__to_node or unit__from_node relationship.
SpineOpt allows the user to constrain ramping abilities of units that are linked to multiple nodes by defining node groups. This is especially relevant for reserve provision because a unit that provides reserves is linked to a regular, as well as a reserve node. It is then possible to constrain the unit's ramping for the combination of regular operation and reserve provision.
Since reserve provision in fact literally reserves part of the capacity of a unit, the demand of the reserve node will be subtracted from the part that is available for regular operation. The section below will discuss how this works in SpineOpt by means of an example.
Since the demand of the nodes is defined on the individual node level (and the node group has no demand), the balance type of the group node should be set to balance_type_none
.
Let's assume that we have one unit and two nodes in a model, one for reserves and one for regular demand. The unit is then linked by the unit__to_node
relationships to each node individually, and on top of that, it is linked to a node group containing both nodes.
The ramping of the unit can now be constrained by defining the same parameters as before, but now for the node group. As before, the simplest case is a unit that is only restricted by its capacity:
max_shutdown_ramp
: 1min_shutdown_ramp
: 0max_start_up_ramp
: 1min_start_up_ramp
: 0ramp_up_limit
: 1ramp_down_limit
: 1unit_capacity
: 200
The capacity restriction now implies that the sum of the reserve demand and regular demand cannot exceed the capacity of the unit. For example: when the reserve node has a demand of 10
in timestep t
, the unit_flow
variable to the regular node must be smaller than or equal to 190
.
The unit can be restricted only in spinning ramping, as in the previous example, by defining the ramp_up/down_limit
parameters in the unit__to_node
relationship for the node group:
ramp_up_limit
: 0.2ramp_down_limit
: 0.4
This parameter choice implies that the unit's flow to the regular demand node between two consecutive timesteps can change with no more than $0.2 * 200 - upward\_reserve\_demand$ and no less than $0.4 * 200 - downward\_reserve\_demand$. For example, when the unit is running at an output of $100$ in some timestep $t$, and there is an upward reserve demand of 10
its output for the next timestep must be somewhere in the interval $[20,130]$.
It can be seen in this example that the demand for reserves is subtracted from both the generation capacity, and the ramping capacity of the unit that is available for regular operation. This stems from the fact that in providing reserve capacity, the unit is expected to be able to provide the demanded reserve within one timestep.
Units can also be allowed to provide non-spinning reserves, through shutdowns and startups. This can be done by using the following parameters in the unit__to_node
relationship for the reserve node :
max_res_startup_ramp
min_res_startup_ramp
max_res_shutdown_ramp
min_res_shutdown_ramp
unit_capacity
These parameters are constraining reserve provision in exactly the same way as their equivalents for regular operation. Note that it is now necessary to define a capacity of the unit with respect to the reserve node. The ramping parameters will then be interpreted as fractions of this specific capacity. The unit's overall capacity can be different than its capacity for reserve provision.
A unit which can provide both spinning and non-spinning reserves can be defined as follows:
Parameters to be defined for unit to node group relationship
max_shutdown_ramp
: 1min_shutdown_ramp
: 0max_start_up_ramp
: 1min_start_up_ramp
: 0ramp_up_limit
: 0.2ramp_down_limit
: 0.4unit_capacity
: 200
Parameters to be defined for unit to reserve node relationship
max_res_startup_ramp
: 0.5min_res_startup_ramp
: 0.1unit_capacity
: 150
The spinning reserve and ramping restrictions now remain the same as above, but on top of that the unit is able to provide non-spinning upward reserves when it is offline. In this particular example, the contribution of the offline unit to upward reserves can be anything in the interval [15,75]
.
It can be seen from the example above that when a node group is defined, ramping restrictions can be imposed both on the group level (thus for the unit as a whole) as well as for the individual nodes. If, for example a ramp-up-limit
is defined for the node group, the sum of upward ramping of the two nodes will be restricted by this parameter, but it is still possible to limit the individual flows to the nodes as well. We will now discuss an example of this for the ramp_up_limit
, but this also holds for other parameters.
Let's continue with the example above, where an online unit is capable of ramping up by 20% of its capacity and down by 40%. We might want to impose tighter restrictions for upward reserve provision than the ramping in overall operation (e.g. because the reserved capacity has to be available in a shorter time than the duration_unit). One can then simply define an additional parameter for the unit to reserve node relationship as follows.
Which now restricts the spinning upward ramping provision of the unit to 15% of its capacity, as defined for the reserve node. In this case, the change in the unit's flow to the regular demand node between two consecutive timesteps is still limited to the interval $[0.2 * 200 - upward\_reserve\_demand, 0.4 * 200 - downward\_reserve\_demand]$. But the upward reserves that it can provide has an upper bound of `$150 * 0.15$.