This disclosure generally relates to load (demand) side power grid control.
The power generation industry is transitioning from being mostly based on a small number of large centralized power plants to a diversified network that combines conventional power plants, renewable power generation (e.g., solar, wind and the like), energy storage and microgrids. Traditionally, power grids have been designed to accommodate variable load demand, in which central-station power plants at a transmission level provide services down to the industrial, commercial and residential end users at a distribution level.
As renewable energy is becoming a major contributor in meeting demand, the grid control system needs to provide more flexibility for power systems to compensate for the volatility of renewable energy. More particularly, due to uncertainties in renewable energy resource availability, renewable power generation cannot be accurately forecast.
To facilitate the penetration of renewable power generation (such as wind turbines and solar panels) into the power grid, load-side control is used. In general, the purpose of load-side control is to attempt to optimize the collective power consumption of the loads (such as buildings), including to accommodate uncertainties in the renewable power generation
This Summary is provided to introduce a selection of representative concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used in any way that would limit the scope of the claimed subject matter.
Briefly, one or more aspects of the technology described herein are directed towards receiving respective condensed datasets representative of respective load-specific information received from respective load controllers, wherein the respective load controllers are coupled to control a power-consuming load that obtains power from a power grid, and wherein the respective condensed datasets are smaller in size than respective full datasets associated with the respective load controllers. Described herein is determining a global value and a step size based on the respective condensed datasets and a specified aggregated power level. Aspects comprise sending the global value and the step size to the respective load controllers for use in adjusting respective local power consumptions of the respective load controllers and adjusting local control variables to satisfy the specified aggregated power level, receiving respective updated condensed datasets from the respective load controllers that update the respective condensed datasets, wherein the respective updated condensed datasets are based on the respective load-specific information associated with the power-consuming load of the respective load controllers after the adjusting of the respective local power consumptions and local control variables in respective step directions determined by the respective load controllers, and determining, from the respective updated condensed datasets, whether the respective load controllers have satisfied the specified aggregated power level to a defined extent, and in response to determining that the specified aggregated power level has not been satisfied to the defined extent. Other aspects comprise determining an updated global value and an updated step size based on the respective updated condensed datasets and the specified aggregated power level, and sending the updated global value and the updated step size to the respective load controllers for use in further adjusting the respective local power consumptions to satisfy the specified aggregated power level.
Other advantages may become apparent from the following detailed description when taken in conjunction with the drawings.
The technology described herein is illustrated by way of example and not limited in the accompanying figures in which like reference numerals indicate similar elements and in which:
Various aspects of the technology described herein are generally directed towards distributed load-side power control. In one or more aspects, the technology comprises a distributed optimization approach for control of an aggregation of distributed flexibility resources (DFRs, which may be referred to as nodes), such that a commanded power profile (e.g., specified by an independent service operator) is produced by aggregated loads. In general, and as will be understood, the technology is based on a distributed iterative solution to solve a network utility maximization problem.
In general, each distributed flexibility resource node solves a local optimization problem with its own local constraints (e.g., limits on temperature of a building) and states. However, the cost function incorporates a global (that is, shared by all nodes) Lagrange multiplier to augment information from the full set of distributed nodes, to track the need for additional power (via a reserve request signal) as an aggregate entity. To this end, the global Lagrange multiplier is calculated at an aggregation level using information that is gathered from each node, with the newly calculated global Lagrange multiplier, associated with the constraint that requests that aggregated power needs to equal the command power generated by an independent service operator, broadcast to each node. The operations are iterative; each node uses the received Lagrange multiplier to perform one iteration of an optimization algorithm that calculates the search direction using the given Lagrange multiplier and sends updated information to an aggregator, which then recalculates a new Lagrange multiplier from the updated information, broadcasts the new Lagrange multiplier to the nodes for a next optimization iteration, and so on, until the aggregator determines that a sufficient level (some defined level) of convergence is reached. This procedure is performed at each sample time and once convergence occurs, loads apply the computed optimal control.
The technology described herein solves the network optimization problem of power tracking of aggregated loads in a distributed fashion. More particularly, solving a large scale optimization problem arising from the optimization of (on the order of) hundreds of thousands or even millions of loads in a centralized way is computationally infeasible, whereby traditional approaches are not able to handle local constraints of the loads and achieve aggregated power tracking performance. The technology described herein provides an iterative, distributed way of computing optimization that makes solving such a large scale optimization problem tractable.
It should be understood that any of the examples herein are non-limiting. As such, the technology described herein is not limited to any particular implementations, embodiments, aspects, concepts, structures, functionalities or examples described herein. Rather, any of the implementations, embodiments, aspects, concepts, structures, functionalities or examples described herein are non-limiting, and the technology may be used in various ways that provide benefits and advantages in power control concepts in general.
In general and as represented in
The represented nodes 102(1)-102(N), comprise controllers 104(1)-104(N) having model predictive control algorithms 106(1)-106(N) and information matrixes 108(1)-108(N) that describe the local states and constraints of the node. One example state is the local weather forecast obtained from a source 114 such as the National Oceanic and Atmospheric Administration (NOAA), as the weather influences renewable power source output as well as corresponds to how much power a node is likely to need for heating or cooling, for example. Other state that may be maintained may be room temperatures, zone temperatures, heating and cooling characteristics, time of day, day of week and so on.
The exemplified nodes 102(1)-102(N) are also represented in
The nodes 102(1)-102(N) are coupled via their respective controllers 104(1)-104(N) to an aggregator 116. In general and as described herein, the aggregator 116 receives a commanded power profile from an independent service operator (ISO) 118, and uses that information along with local load-specific information received from each controller 104(1)-104(N) to compute a global Lagrange multiplier 120 mathematically represented by ρk (at iteration k). The global Lagrange multiplier 120 computed by the aggregator 116 is sent to the controllers 104(1)-104(N), for use by each controller in solving its local optimization problem.
To summarize thus far, the technology is directed towards attempting to more optimally control distributed flexibility resource nodes, such that the aggregated power tracks a commanded power profile that comes from the independent service operator 118. The optimization problem is solved in a distributed way, where each distributed flexibility resource node exchanges data with the aggregator and performs one optimization iteration according to the distributed optimization scheme described herein to solve the global model predictive control optimization problem in a tractable fashion.
In one or more implementations, the modified local cost function is the sum of a local cost (local utility function) and a Lagrange multiplier times the power consumed (supplied) by the distributed flexibility resource. The value of the Lagrange multiplier 120 that is shared among the nodes 102(1)-102(N) is calculated at the aggregator level. At the aggregator 116, the Lagrange multiplier is a function of the commanded power profile and the local data that are sent to the aggregator 116 at each iteration of optimization. The recalculated Lagrange multiplier is send back to the nodes to be used in the cost for next iteration, and so on. As the nodes iterate synchronously, they converge towards an acceptable solution (that is, to a defined/predetermined convergence threshold) to the network/global Model Predictive Control optimization problem through the aforementioned iterative distributed computation scheme.
As represented in
Once initialized, the communications represented by labeled arrows three (3) and four (4) in
At the aggregator, at operation 310, using the data collected from the nodes and the commanded power profile from the independent service operator, the shared Lagrange multiplier is calculated, along with a step size. If convergence to the desired, defined level is not yet achieved (operation 312), the Lagrange multiplier and step size is sent to the nodes (arrow four (3) in
Using the new value of the Lagrange multiplier, a new search direction and an updated dataset is calculated by iteratively returning to step 306. The updated dataset is sent from the controller to the aggregator (arrow three (3) in
Turning to additional details, in one or more implementations, the distributed optimal control technology uses an algorithm based on a distributed computation of the Newton iteration, which provides faster convergence relative to other methods (such as alternating direction method of multipliers or sub-gradient methods). As will be understood, the distributed optimal control technology exploits a structure of the problem to calculate an exact Newton step as opposed to inexact versions that require iterations to calculate the Newton direction. The technology described herein coordinates loads and distributed energy resources, and exploits their flexibilities such that the aggregated energy follows the profile commanded by the ancillary services, where ancillary services are basically those functionalities provided by the power grid that support a continuous flow of power and work to guarantee that supply will meet demand.
For each load, an optimization problem is defined essentially as a local model predictive control formulation. The cost represents local objectives, and constraints are determined by dynamics and other operational and quality of service (QoS) constraint or constraints on states and inputs of the systems; e.g., temperate comfort interval may be a QoS constraint. The power tracking constraint is generally the only system-level constraint that couples the local subsystem-level optimization problems. Hence, it leads to a global optimization problem whose solution meets local objectives and constraints, and at the same time provides total power that follows the power profile demanded by the ancillary services.
Defined herein is a global optimization problem, along with an algorithm that is scalable and can efficiently solve the problem in a distributed manner. The solution calculates Newton steps (e.g., exact Newton steps) and step size in a distributed fashion in the sense that at the load, load-level information related to the step size is calculated and sent to the aggregator, and at the aggregator level, the step size is calculated using that information, so that while the solution enjoys fast convergence of Newton primal iterations, it is also scalable to a large number of loads
Consider a network of loads and differential algebraic equations as represented by a set ={L1, . . . , LN}. For each load there are states and inputs that define the dynamic of the load that are usually defined by a set of differential algebraic equations. Differential algebraic equations are converted to discrete time equations to construct equality constraints for numerical optimization. Constraints on inputs or state form another set of equality and inequality constraints. The local optimization problem that formulates model predictive control for the load Li ∈ is characterized as
where Xi is the vector containing states, inputs and algebraic variables over the prediction horizon, fi is the local cost function of the optimization problem, hi and gi are the functions characterizing equality constraint containing discrete-time dynamics and other constraints imposed due to physics or stability of the load. Pi is the vector representing the power dispatched over the prediction horizon and mi is the map from Xi to Pi. The power tracking constraint
is imposed to make the aggregated power follow the target power Pd, where Pd is the vector containing the desired power profile over the prediction horizon. Local optimization problems subject to the global constraint construct the following optimization problem:
The optimization problem defines a global model predictive control framework where the problem is solved iteratively to determine an optimal control sequence for each load such that the control sequence optimizes the local objective subject to local dynamics and constraints, while the aggregated dispatched power by the loads track the desired power profile determined by any ancillary services. The first element of the optimal control sequence for each load is implemented at each sample time.
As described herein, an assumption is that the functions gi, hi and mi are linear and the functions fi are self-concordant. The problem may be reformulated to one with only an equality constraint by introducing a non-negative slack vector Si0 such that gi(Xi,)+Si=0, and logarithmic barrier functions of slack variables. Then define Yi:=[XiT, SiT]T, E(Yi):=[(gi(Xi)+Si)T], (hi(Xi))t, Mi(Yi):=mi(Xi) and Fi(Yi,μ):=fi(Xi)+μ(br(Si)) where the barrier function of the vector Si, br(Si), is defined as br(Si)=Σj=1|S
An assumption is that the matrix [AiT, CiT]T is full row rank; it is straightforward to prove that this holds for large class of systems, if in the subsystem Li, the power is an input of the system and (eq. 3c) represents the linear dynamic of the system.
Moreover, let J(Y):=ΣiFi(Yi) where J denotes the objective function and Y is the concatenation of Yi, i=1, . . . , N. The matrices and vectors A, b, C and d are defined with appropriate dimensions such that AY−b and Pd=CY+d represent the equality constraints.
Therefore, the optimization problem may be written as
Described herein is a distributed optimization scheme to solve the above optimization problem. The scheme is based on the equality constrained Newton method, where the Newton direction and step size are calculated in a distributed fashion using data communication between an aggregator and the loads.
Define {Yk} as the sequence of primal vectors and {λk} the sequence of dual variables associated with constraints (eq. 5b), and {ρk} the sequence of dual variables associated with the power balance constraint (eq. 5c), generated by Newton iterations. The algorithm updates the sequence of primal vectors by
Y
k+1
=Y
k+αkΔYk (6)
where 0≤αk≤1 and ΔYk is the Newton search direction given by
H
k
ΔY
k
+A
T
λ+C
Tρ=−∇YJ(Yk)
AΔY=0
CΔY=0 (7)
where Hk:=∇2J(Yk). It is desired to solve (eq. 7) in a distributed fashion that is scalable such that it can be deployed for very large number of loads. To this end, described herein is exploiting the special sparsity of the problem to explicitly calculate the search direction. The following theorem enables the development of a distributed iterative algorithm to the calculate Newton search direction.
Assume the optimization problem set forth above is strictly feasible. Given primal vectors Yy, i=1, . . . , N, the Lagrange multiplier associated with the power tracking constraint (5c) is set forth in (7) is given by
ρk=Γk−1rρk (8)
where
is the local KKT (Karush-Kuhn-Tucker) matrix. Moreover, ΔYik and λik are calculated as
where the matrix and vector 0 are with appropriate dimensions.
As proof, (7) may be written in the following form:
From (eq. 12a), (eq. 12b), and the definition of the local KKT matrix Kik, (eq. 11) results.
From (eq. 12c) and (eq. 11), Γkρk+rpk=0. According to the above assumption that the matrix [AiT, CiT]T is full row rank, the matrix [AT, CT]T is full row rank. Moreover, since Hk is strictly positive definite, and the functions gi, hi and mi are linear and the functions fi are self-concordant, (eq. 7) has a unique solution. Hence, Γk has to be invertible, otherwise no or infinite values for ρk exist that satisfy (eq. 7) along with their corresponding vectors ΔYk and λk. Therefore (eq. 8) holds.
To be able to implement primal vector update (eq. 6), the value of αk needs to be calculated. The step size is determined by the Newton decrement (ND), defined as
ND(Yk):=√{square root over (ΔYkTHkΔYk)}. (13)
ND can be written in terms of local information Yik as
The step size αk then is calculated as a function of ND as follows:
Because the cost function J(Y) is self-concordant and the constraints are linear, the step size calculated according to (eq. 15) provides linear and then quadratic convergence to the optimal solution in two stages. Described herein is having the Newton direction Yk and step size αk calculated in a distributed fashion at the aggregator using the data gathered by communication between the aggregator and loads.
The initialization phase may, in one or more implementations, be started by the aggregator initializing itself and requesting that each controller provide power feasible information (operation 402 of
For each load Li ∈, a range (interval) [Pmini, pmaxi] is assumed which defines the feasible values for power consumption. Hence, each of the loads sends its respective upper and lower limit of the power feasible range to the aggregator (operation 604 of
Operations 404, 406 and 408 of
where rj is the j-th element of r. The value of r is then sent to the controllers, which may differ per controller. Note that the value of r corresponds to the target power obtained from the independent service operator, (operation 410), which may be obtained independently at any suitable time before the ratios are computed and sent (operations 412 and 414).
When the ratio vector is received by a controller (operation 606 of
It can be easily shown that the sequence {Pi} provides feasible power vectors for the loads Li ∈ and it satisfies the constraint 5c.
The optimization phase is described herein with reference to the example flow diagrams of
Each controller starts with its own initial feasible primal Y0 (e.g., operation 700 of
At each load Li, operation 704 is performed, which calculates the step direction and also generates the scalars that represent the information matrix in condensed for, e.g., Γik, rρ,ik, αik=ΔYi,ρk
These per-node dependent values are sent to the aggregator by each controller at operation 706 of
The aggregator, as represented by operation 512 of
At each controller, if ρk and αk are received (operations 708 and 710 of
Turning to another aspect, some loads have discrete power consumption, that is, are either on or off (in contrast to loads that accept continuous values for power control). Described herein is an algorithm that can handle loads that only accept boundary values of the power feasible interval (assuming the interval is the range from minimum to maximum). Thus, the power only accepts discrete values, e.g., pi ∈ {pmini, pmaxi} for the loads Li ∈ d⊂ . A general goal here is to avoid mixed-integer programming, which is often not suitable for real time optimization, especially for large scale problems.
To this end, the optimization problem is first solved according to the algorithm assuming all the loads accept continuous values for power within the feasible interval. Let {
Via operations 802, 806 and 808, for each element j, which represents the j-th step in the prediction horizon, operation 804 sorts the sequence
and denotes it by {{circumflex over (P)}ij}. Also, operation 804 denotes the corresponding sequence of the load numbers by I.
Operation 810 finds the maximum value of nj such that Σi=1n
Combining the continuous load optimization with the above-described discrete load post-processing allows the technology to handle any mixture of continuous and discrete loads. The effectiveness of the proposed distributed optimal control scheme may be shown via a numerical simulation, e.g., considering 100 buildings as the distributed loads. Each building is individually controlled by its own HAVC control system. Each building may have single or multiple Roof Top Units (RTUs) managed by a single controller, or multiple controllers through a Building Management System (BMS). Each building communicates with the aggregator, e.g., via a controller as described herein. As described herein, a main job of the distributed optimal controller is to compute power set points to each building such that the sum of powers consumed by the buildings track the power set point commanded by the grid independent service operator (ISO), while keeping each building temperature within the defined comfort zone to the extent possible. The thermal dynamics of the i-th building may be modeled using an equivalent RC circuit, as:
where Pi is the input power, τi0 is the ambient temperature [80 °F.], Ri is the thermal resistance [2.5° C./kW ], Ci is the thermal capacitance [1.5 kW h/° C.] and Pmax
The above parameters represent a nominal load model. The load parameters may be stochastically perturbed to account for model uncertainties in different buildings. At the abstraction level from the aggregator's perspective, this RC model captures the building dynamics well, while keeping the computations tractable for a larger number of loads. It can be reasonably assumed that the dynamics of the heating, ventilation and air conditioning (HVAC) controller is much faster than the thermal dynamics of the building, and can be neglected in this context. Further, assume the loads are of the same dynamic time scale and that the communication delays between loads and the aggregator are negligible. While older buildings have ON-OFF HVAC controllers, thus making them a discrete load, most newer buildings are equipped with either variable air volume (VAV) handling, or electronic expansion valves in the HVAC refrigeration cycle, making them a continuously controllable load. For continuous loads, the power set point at each instant can be any number between 0 and Pmax. For discrete loads, the power at each instant is either 0 (OFF mode) or Pmax (ON mode), and there is also a hysteresis mechanism, such as with the minimum on and off times as follows:
At each time step, an interior point optimization problem is solved in a distributed fashion as described herein. In each iteration of the optimization, the aggregator waits until it receives information from all loads, computes p and broadcasts back to all loads. The potential time differences between each load to complete one iteration of the optimization is negligible compared to the time scale of the load dynamics. Thus, during the potential wait time of the aggregator, the load temperatures remain almost constant. To put this into context, one iteration of the optimization problem may take a fraction of a second, while the thermal time constant of a building is typically several minutes up to a few hours.
The power tracking requirement in this case is that the total sum of building powers tracks the power command as closely as possible without exceeding the power command. In this example, at each sampling time, first assign the power of discrete loads that are not active, and subtract the sum of power of such subset of loads from the overall power command to get the sum of powers that need to be matched by the active loads (which itself is a mixture of continuous and discrete loads).
After solving the optimization problem, the discrete active loads are post-processed using the algorithm described in with reference to
In terms of convergence performance, in graph 1010 of
As can be seen, the technology provides an optimization algorithm for cooperation of distributed flexible power resources to provide regulation and ramping reserve as an ancillary service. This may facilitate the penetration of renewable energies. The distributed iterative operations make real-time distributed optimization feasible, with the target aggregated power being achieved while not significantly impacting the local operation of the distributed flexible power resources. The scalable optimal flexibility control distributes the computational burden of large scale optimization among loads/nodes while they communicate with the aggregator. The technology is highly efficient and can be implemented at the commercial aggregator level with a very large number of loads.
One or more aspects are directed towards a load controller of distributed load controllers, the load controller coupled to manage a power-consuming load that consumes power supplied via a consumer supply device of a power grid, wherein the load controller manages the load to satisfy the load's quality of service constraint or constraints, and wherein the load controller is communicatively coupled to an aggregator that aggregates data sent by the load controller and received from one or more other distributed load controllers of the distributed load controllers, the data comprising initial data that comprises a power range. In one or more aspects, the load controller is configured to receive an initial ratio value from the aggregator, wherein the initial ratio value is based on the power range and other power range data from the one or more other distributed load controllers of the distributed load controllers, and wherein the load controller is further configured to use the initial ratio value to set a local power level to an initial level, and use load-specific information of the power-consuming load to determine condensed information comprising one or more scalar values that represent the load-specific information in a more compact form than the load-specific information, and to communicate the condensed information to the aggregator, wherein the local power level is local to the load controller. In one or more aspects, the load controller is further configured to perform iterations based on communication with the aggregator to modify the local power level to approach a specified aggregated load power consumption level until the aggregator determines that the iterations have satisfied a defined condition, and wherein the iterations are performed to receive a step size value and a global value from the aggregator, wherein the step size value and the global value are based on the condensed information and other condensed information from the one or more other distributed load controllers of the distributed load controllers, determine a step direction, control the power-consuming load with an adjustment based on the step size value and the step direction to approach the specified aggregated load power consumption level, re-determine updated condensed information that updates the condensed information and comprises one or more updated scalar values that represent the load-specific information after the adjustment, and communicate the updated condensed information to the aggregator.
One or more aspects are directed towards receiving, by a system comprising a processor, respective condensed datasets representative of respective load-specific information received from respective load controllers, wherein the respective load controllers are coupled to control a power-consuming load that obtains power from a power grid, and wherein the respective condensed datasets are smaller in size than respective full datasets associated with the respective load controllers, and determining a global value and a step size based on the respective condensed datasets and a specified aggregated power level. Aspects comprise sending the global value and the step size to the respective load controllers for use in adjusting respective local power consumptions of the respective load controllers to satisfy the specified aggregated power level, receiving respective updated condensed datasets from the respective load controllers that update the respective condensed datasets, wherein the respective updated condensed datasets are based on the respective load-specific information associated with the power-consuming load of the respective load controllers after the adjusting of the respective local power consumptions in respective step directions determined by the respective load controllers, and determining, from the respective updated condensed datasets, whether the respective load controllers have satisfied the specified aggregated power level to a defined extent, and in response to determining that the specified aggregated power level has not been satisfied to the defined extent. Other aspects comprise determining an updated global value and an updated step size based on the respective updated condensed datasets and the specified aggregated power level, and sending the updated global value and the updated step size to the respective load controllers for use in further adjusting the respective local power consumptions to satisfy the specified aggregated power level.
One or more aspects are directed towards communicating load-related power range data to an aggregator, wherein the load-related power range data from the load controller and other load-related power range data from one or more other load controllers of the group of distributed load controllers are usable by the aggregator to determine initialization data that is to be received by the load controller in response to the communicating of the load-related power range data, and is to be sent to the one or more other load controllers. Further described herein is receiving the initialization data from the aggregator, determining condensed load-specific information of a power-consuming load managed by the load controller based at least in part on the initialization data and communicating the condensed load-specific information to the aggregator, wherein the condensed load-specific information from the load controller and other condensed load-specific information from the one or more other load controllers are usable by the aggregator to determine a step size and a global multiplier value that are to be received by the load controller in response to the communicating of the condensed load-specific information and are to be sent to the one or more other load controllers. One or more aspects comprise receiving the step size and the global multiplier value from the aggregator; based on the step size and the global multiplier value from the aggregator, determining a step direction, adjusting the load power consumption in the step direction, determining current condensed load-specific information after the adjusting of the load power consumption, and communicating the current condensed load-specific information to the aggregator, wherein the current condensed load-specific information from the load controller and other current condensed load-specific information from the one or more other load controllers are usable by the aggregator to evaluate whether aggregated power levels of the group of distributed load controllers have converged to a defined convergence level, and in response to the aggregated power levels being determined not to have converged to the defined convergence level, determining a new step size that replaces the step size and a new global multiplier value that replaces the global multiplier value based on the current condensed load-specific information and the other current load-specific information, and wherein the new step size and the new global multiplier value are to be received by the load controller and sent to the other load controllers. One or more other aspects may comprise receiving the new step size and the new global multiplier value, and in response to the aggregated power levels being determined to have converged to the defined convergence level, ending the operations until a later time.
While the invention is susceptible to various modifications and alternative constructions, certain illustrated implementations thereof are shown in the drawings and have been described above in detail. It should be understood, however, that there is no intention to limit the invention to the specific forms disclosed, but on the contrary, the intention is to cover all modifications, alternative constructions, and equivalents falling within the spirit and scope of the invention.
In addition to the various implementations described herein, it is to be understood that other similar implementations can be used or modifications and additions can be made to the described implementation(s) for performing the same or equivalent function of the corresponding implementation(s) without deviating therefrom. Accordingly, the invention is not to be limited to any single implementation, but rather is to be construed in breadth, spirit and scope in accordance with the appended claims.