The present invention relates generally to the field of electricity-producing wind farms.
Alternative energy sources, such as wind power, provide an attractive solution to today's growing demand for energy. Wind power is a readily available and renewable resource in many areas of the world. In addition, wind power is also a clean source of energy because the harvesting of wind power does not release chemical byproducts, such as greenhouse gasses, into the atmosphere.
Wind turbines are used to convert harvested wind energy into electricity. Wind power is used to turn the rotor of the turbine and the rotor drives a generator, which converts the captured mechanical energy into electricity. Modern turbines also include various controls for adjusting rotor speed, blade pitch, and orientation (e.g., rotor axis direction) relative to the direction of the wind.
Turbines are often positioned in relatively close geographic proximity of one another, in order to increase the amount of wind power harvested in a particularly windy area. Such wind farms are becoming more common. One challenge in the wind farms is that a downstream turbine that is in the wake of another turbine experiences different wind dynamics than that of the upstream turbine. Optimizing the power generation by a wind farm to account for downstream wind dynamics is challenging and difficult.
One embodiment of the invention relates to a method for controlling turbines in a wind farm turbine array. The method includes using a cascade of self-optimizing controllers to in an attempt to maximize the power generated by at least a portion of the wind farm turbine array. At least one of the self-optimizing controllers for an upstream turbine is configured to control the upstream turbine in an attempt to maximize the combined total of (a) the power output of the upstream turbine and (b) the power output of at least one downstream turbine. In some exemplary embodiments, the self-optimizing controllers are extremum seeking controllers.
Another embodiment relates to a control system for use with a wind farm turbine array. The control system includes a plurality of self-optimizing controllers, at least one self-optimizing controller for each turbine of the wind farm turbine array. At least one of the self-optimizing controllers is configured to seek an operating parameter that maximize the combined power generated by the controller's turbine and at least one turbine downstream from the controller's turbine. At least one of the self-optimizing controllers may be an extremum seeking controller. The operating parameter may be or include a pitch angle or rotor speed for the upstream turbine. Tip speed ratio (or torque or angular velocity) can be adopted in place of turbine rotor speed.
Yet another embodiment of the invention relates to non-transitory computer-readable media with computer-executable instructions embodied thereon that when executed by a computing system perform a method for improving power generation by a wind farm. The media includes instructions for providing self-optimizing control of an upstream turbine that optimizes the power output of the upstream turbine based on the combined power output of the upstream turbine and on the power output of at least one downstream turbine. The instructions may implement an extremum-seeking control strategy configured to seek a turbine operating parameter that maximizes the combined power output of the upstream turbine and the downstream turbine. The media may further include instructions for identifying the downstream turbine as being downstream from the upstream turbine.
Alternative exemplary embodiments relate to other features and combinations of features as may be generally recited in the claims.
The disclosure will become more fully understood from the following detailed description, taken in conjunction with the accompanying figures, wherein like reference numerals refer to like elements, in which:
Before turning to the figures, which illustrate the exemplary embodiments in detail, it should be understood that the disclosure is not limited to the details or methodology set forth in the description or illustrated in the figures. It should also be understood that the terminology is for the purpose of description only and should not be regarded as limiting.
Embodiments of the present disclosure include a computer system for a wind farm that has been configured to maximize power generation by utilizing a cascade of self-optimizing controllers. Each self-optimizing controller attempts to optimize itself based on the power output of the turbine with which it is associated and, when there is at least one downstream turbine, on the power output of the downstream turbine(s). Utilizing a cascade of self-optimizing controllers is intended to improve overall power generation by the wind farm without the use of computationally expensive turbine wake models. Self-optimizing control strategies, such as extremum-seeking control, allow for a controller to find (i.e., “seek”) the optimum operating parameters of a turbine, without knowledge of the actual wake interactions.
Referring now to
Wind 102 approaches wind farm turbine array 100 at a velocity (Vw) along wind direction 103. As wind 102 reaches turbines 104, 108, 112, 116, 120, and 124, it causes the rotors of the turbines to rotate, thereby capturing wind power as mechanical energy. In turn, turbines 104, 108, 112, 116, 120, and 124 each include a generator coupled (e.g., mechanically linked) to their rotors, allowing the captured mechanical energy to be converted into electricity.
As shown, turbines 104, 108, 112, 116, 120, and 124 in wind farm turbine array 100 face wind 102, i.e., their rotor disks are normal or approximately normal to wind direction 103. Facing wind 102 allows turbines 104, 108, 112, 116, 120, and 124 to generate more electricity than from other orientations. Some or all of turbines 104, 108, 112, 116, 120, and 124 in wind farm turbine array 100 are able to adjust their positions (e.g., axis of rotation) when wind direction 103 changes. Doing so allows wind farm turbine array 100 to increase its power output. In some alternative embodiments, some or all of the turbines of a wind farm are fixed relative to an expected wind direction.
In addition to (or as an alternative to) adapting to new wind directions, each of turbines 104, 108, 112, 116, 120, and 124 may increase their individual power generation by regulating operating parameters such as torque and the pitch angle of their rotor blades. Regulating these parameters to maximize power generation by wind farm turbine array 100 conventionally requires knowledge of the wind dynamics arriving at each of the turbines in wind farm turbine array 100. Torque, for example, can be controlled to increase or decrease the speed of the rotor as a function of the speed of wind 102. However, because the wind dynamics experienced by each of turbines 104, 108, 112, 116, 120, and 124 differ due to wake, the optimal generator torque may be different from turbine to turbine.
As illustrated in
To accommodate for the influence of turbine wakes, some efforts have been made to model wake interactions. In general, these wake models may be broken up into two general categories: near-field wake and far-field wake. Near-field wake models attempt to model the interaction of closely-spaced turbines. Far-field wake models, in contrast, attempt to model the interaction of farther spaced turbines. Existing models typically rely on a number of assumptions that fail to precisely model the wake interactions. For example, some models assume a linearly expanding wake and uniform wind speeds. Non-linear approaches have been proposed, but often fail to account for some non-linear factors, such as uneven terrain. Even in situations where conventional model-based approaches have successfully modeled a wind farm for one period in time, model-based approaches often fail to account for changing conditions (e.g., changing mechanical conditions, changing climate conditions, etc.).
Some embodiments of the present invention advantageously avoid the use of wake models entirely by using a cascade of self-optimizing controllers for a plurality of turbines. A self-optimizing controller for an upstream turbine optimizes the power output of the upstream turbine based on the power output of the upstream turbine and on the power output from at least one downstream turbine.
Referring now to
Turbine 104 also includes tower 202, which supports nacelle 206. Nacelle 206 houses low-speed shaft 212, gears 214, high-speed shaft 218, brake 222, and generator 216. In some embodiments, turbine 104 also includes yaw motor 226 and yaw drive 228. In some embodiments, if the direction of wind 102 changes significantly in terms of ten-minute integration, yaw motor 226 may be controlled to apply force to yaw drive 228, in order to reposition rotor 208 to face the new wind direction.
Turbine 104 further includes processing circuit 224, which processes measurement data and provides control commands to the various components of turbine 104. For example, processing circuit 224 may receive wind speed data from anemometer 220 or wind direction data from wind vane 210. Processing circuit 224 may provide control commands to yaw motor 226 to regulate the yaw angle (e.g., a relative measure of the difference between the direction faced by the primary rotational axis of rotor 208 and the direction of wind 102). The yaw angle may be calculated based on wind direction data received from wind vane 210. For example, processing circuit 224 may provide a control command to yaw motor 226 to minimize the yaw angle of rotor 208. The processing circuit 224 may allow for some margin of error, refraining from making adjustments, e.g., unless the yaw angle exceeds an acceptable angle threshold (e.g., 5°, 10°, etc.). In this way, processing circuit 224 is able to keep rotor 104 facing the direction of wind 102, thereby increasing the power generation capabilities of turbine 104. In many cases, processing circuit 224 can increase the power generation capabilities of turbine 104 by intermittently making adjustments such that rotor 208 is caused to face the direction of the wind 102.
Processing circuit 224 may also or alternatively control other operating parameters of turbine 104 that affect power generation. For example, the blade pitch angle 230 of blades 204 and the rotor speed of blades 204 (or equivalently, the tip speed ratio or torque) may be regulated to further optimize the power generated by turbine 104. The blade pitch angle is the angle between the rotor plane and the chord line of blades 204. As the effective relative wind that hits an element of blades 204 is composition of the wind speed at the rotor disk and the local linear speed of the blade element, the actual angle of attack of the blade under wind 102 is determined by both the pitch angle, the wind speed and the rotor speed. The tip speed ratio of blades 204 refers to the ratio of the linear speed at the tip of blades 204 with respect to the velocity of wind 102. For each turbine, there are combinations of pitch and rotor speed (or tip-speed ratio) values that maximize the capture of energy from the wind. In some embodiments, for wind turbine control, the rotor speed can be better alternative than the tip-speed ratio if the wind measurement is inaccurate and/or unreliable.
According to an exemplary embodiment, optimizing the energy capture of a whole wind farm cannot be achieved by simply optimizing the operation of one single turbine. As the efficiency of power generation is determined by the axial induction factor or equivalently the wind speed deficit, maximizing the power generation of one turbine alone may also change the wind speed arriving at its downwind turbines, which leads to disadvantageous wind speed deficit for the downstream turbines. As consequence, the overall power generation by the wind farm turbine array can be potentially reduced.
In some embodiments, processing circuit 224 is configured using a self-optimizing controller to maximize the combined power output of turbine 104 and a downwind turbine (e.g., turbine 116 shown in
In general, extremum seeking control (ESC) refers to a class of self-optimizing control strategies that can dynamically search for the unknown and/or time-varying inputs of a system in order to optimize the system to a certain performance index. In some ways, ESC can be considered a dynamic realization of gradient searching through the use of dithering signals. The gradient of the system output with respect to the system input is typically obtained by slightly perturbing the system operation and applying a demodulation measure. Optimization of system performance can be obtained by driving the gradient towards zero by using an integrator in the closed-loop system. ESC is also a non-model based control strategy, meaning that a model for the controlled system is not necessary for ESC to optimize the system. In the embodiments described herein, an extremum seeking controller for a wind farm turbine uses controlled perturbations in one or more turbine characteristics (e.g., rotor direction) to seek a maximum power output of the turbine and one or more downwind turbines.
Referring now to
Transfer functions that correspond to the input and output dynamics of the plant (i.e., the controlled operating parameters of the turbine) are also utilized in ESC strategy 300. Input transfer function 330 represents the input dynamics of the plant and produces input parameter 302. Plant measurements may be taken by measurer 310 (e.g., one or more sensors, data analyzers, etc.), to provide output 306 of cost function 304, denoted y(t). Output 306 and may also contain a noise signal 308, denoted n(t). Output transfer function 312 represents the output dynamics of the plant.
In order to seek the optimal value for input 302, a dither signal 326 and a demodulation signal 316 are added to the system. For example, dither signal 326 may be of the form:
d
2(t)=[a1 sin(ω1t+α1) . . . am sin(ωmt+αm)]
where ωi (i=1, . . . , m) is the dithering frequency for the ith input channel, ai is the amplitude of the signal on the ith channel, and αi is the phase angle introduced intentionally between dither signal 326 and demodulation signal 316. Similarly, demodulation signal 316 may be of the form:
d
1(t)=[sin(ω1t) . . . sin(ωmt)]
Dither signal 326 contains perturbations, which allow for ESC strategy 300 to determine a gradient for cost function 304. High pass filter 314, demodulation signal 316, and low pass filter 318 operate to determine a signal proportional to the gradient,
where î denotes estimated control input 324 based on the gradient estimation. Integrator 320 may be used in ESC strategy 300 to reduce the gradient to zero, thereby always seeking out the value of input parameter 302 that maximizes or minimizes cost function 304 in the closed-loop system, depending on whether the gain of compensator 322 is negative or positive, respectively. Compensator 322 may additionally be employed to enhance transient performance by compensating input and output dynamics.
Integral windup is a source of potential error for ESC strategy 300 because of its use of integrator 320. If an actuator saturation condition exists, i.e., an actuator controlled by ESC strategy 300 cannot physically go beyond a certain limit, integral windup may occur, causing the error in the loop to continually increase. For example, the blade pitch angle and the rotor speed may both be physically limited, leading to an actuator saturation condition. Anti-windup techniques may be incorporated into ESC strategy 300, to mitigate the effects of integral windup. For example, a back calculation may be used at the input to integrator 322 that detects saturation conditions and disables ESC strategy 300 until the saturation condition is removed.
Another potential source of inefficiency in ESC strategy 300 is when an abrupt change occurs, shifting the optimal operating point of cost function 304. For example, the wind speed or direction may suddenly change, thereby changing the optimal operating conditions for power generation. In such a case, ESC strategy 300 may take longer to converge to the new extremum. One way to enhance the convergence would be to utilize a gradient detector that detects gradient changes that are above a specified threshold and resets the input to integrator 320 if the threshold is exceeded. Another way to enhance the convergence would be to use a step change detector and resetting logic at the input to high pass filter 314, in order to reset the input to high pass filter 314 if a step change is detected.
In the context of wind turbine applications, a multiple input extremum seeking control strategy may be used to converge the operating parameters of a turbine to maximize its power generation. For example, a two variable ESC loop that maximizes power generation of a turbine using pitch angle and torque as inputs is described in the article, “Maximizing Wind Turbine Energy Capture using Multivariable Extremum Seeking Control” by J. Creaby, Y. Li, and J. Seem, which is hereby incorporated by reference. In such a scheme, however, power generation is only maximized at the individual turbine level, meaning that the power generation at the array level may suffer due to the effects of turbine wakes. Various optimization techniques exist to optimize the parameters for a set of problems. For example, dynamic programming is one technique that affords a way to globally optimize sets of computational problems using recursion to minimize a cost function for sub-problems. Also known as a Bellman equation, optimization can be achieved by making choices in sequence that optimize the sub-problems. Using such techniques, a cascade of self-optimizing controllers may be utilized to optimize the power generation for an entire wind farm turbine array.
Referring now to
Each of turbines 404, 406, and 408 have operational parameters that may be used to optimize power generation. For example, pitch angle (βi) and rotor speed (Ωi) for the ith turbine may be used to optimize its power generation (Pi). Since the turbines in wind farm turbine array 400 are interrelated, optimization at the array level may be achieved by solving the following Bellman equation:
where βi* and Ωi* are the optimal pitch angles and rotor speeds of the ith turbine, respectively, and Pi is the corresponding power output. In other words, the goal of optimization at the array level is to find those operating parameters for each turbine that maximize the power generation of the entire array, not just for the individual turbines. In some embodiments, the tip-speed ratio (λi), may be used to optimize the power generation of the ith turbine. In the description of those embodiments, the notations of Ω (rotor speed) used herein are replaced by λ (tip-speed ratio).
In some embodiments, the operating parameters may be determined following Bellman's approach for optimization. As a starting condition for the optimization process, the most downwind turbine may be optimized first by finding the pitch angle and rotor speed that maximizes its power. In other words, the initial condition can be determined by solving:
where βn* and Ωn* are the optimal pitch angles and rotor speeds of turbine 408 (e.g., the nth turbine of wind farm turbine array 400), respectively, and Pn is the power output of the turbine.
A self-optimizing controller may be used to solve for the optimal parameters, according to some embodiments. For example, a two-input ESC can be used to determine the optimal pitch angle and rotor speed that maximize the power generation by the most downwind turbine in wind farm turbine array 400. The ESC, using a model-free control strategy, allows the power generation by the most downwind turbine to be maximized without using a model of the wakes of the turbines that are upstream from it.
A turbine that is upstream from turbine 408 may be optimized such that the combined power generation of the upstream turbine and any of its downstream turbines is maximized. For example, the optimization problem for the (n−1)th turbine may be viewed as follows:
where βn-1* and Ωn-1* are the optimal pitch angles and rotor speed (or equivalently the tip speed ratio) of the turbine directly upstream from turbine 408, respectively, and Pn-1 is the power output of the upstream turbine. In some embodiments, the search for βn-1* and Ωn-1* can be performed any time during the operation, i.e., even before the search for βn* and Ωn* for the downstream turbine is settled. In some embodiments, the search for βn-1* and Ωn-1* would be settled only after the search for the optimal operating parameter of the downstream (i.e., βn* and Ωn*) is settled. In this way, the optimal parameters for the upstream may be determined such that they maximize the combined power generation of both the upstream turbine and the downstream turbine.
According to embodiments of the present invention, a self-optimizing controller is used to determine the optimal operating parameters for an upstream turbine. For example, a two-input ESC can again be used to determine the optimal parameters for an upstream turbine, such that the combined power generation of the upstream turbine and any downstream turbines from it is maximized. In such a case, dithering frequencies used in the ESC (e.g., ωβ,i and ωΩ,i) may be different between adjacent turbines. In some embodiments, for sufficiently spaced turbines, any perturbations from the upstream dither signal will have vanished before reaching the downstream turbine due to turbulent diffusion. Therefore, the dither action in an upstream turbine would not lead to dithered wind speed at its downstream peers.
Farther upstream turbines may be optimized in a similar manner as the (n−1)th turbine, i.e., by determining its optimal operating parameters such that the combined power generation of it and all downstream turbines is maximized. In general, the kth upstream turbine may be optimized as follows:
where βk* and Ωk* are the optimal pitch angles and rotor speeds of kth turbine and Pi is the power output of the upstream turbine or any of the turbines downstream from it. The search for the optimal solution for the kth turbine can proceed while all the downwind turbines are searching for their optimal solutions. The final optimal solution for the kth turbine may be achieved after all the downstream turbines are at their optimal solution.
Again, a self-optimizing controller may be used to solve for the ith upstream turbine, allowing the entire wind farm turbine array 400 to be optimized using a cascade approach. This decentralizes the optimization problem for the array into many lower-dimensional problems, allowing for their computations to also be decentralized for faster processing. For example, the array optimization problem may be solved at a supervisory server that oversees the operation of multiple turbines, at the individual turbine controllers, or any combination thereof.
Since a cascade of self-optimizing controllers is a self-adapting control approach, it is also able to maximize the power generation of wind farm turbine array 400, even if a turbine is malfunctioning. Model-based approaches make assumptions as to the wake dynamics of upstream turbines. However, if an upstream turbine is malfunctioning, these assumptions may no longer be valid, leading to lower power generation by the array. In contrast, a cascade of self-optimizing controllers is able to adapt in the event of a turbine malfunction. For example, if turbine 406 is malfunctioning such that its power generation is zero, the self-optimizing controller for turbine 404 will still optimize its operating parameters to maximize the combined power generation of the turbines in wind farm turbine array 400.
Referring now to
Hierarchy 500 may be used as part of a cascade approach to optimizing wind farm turbine array 100. Since turbines 112, 120, and 124 are all terminal downwind turbines (i.e., their wakes do not affect other turbines), self-optimizing controllers may be used to determine the operating parameters that maximize the power generation of each of turbines 112, 120, and 124, individually. For example, a two-input ESC may be used to determine the pitch angle and rotor speed parameters that maximizes power generation in each of turbines 112, 120, and 124.
The wake of turbine 116 affects both turbines 120 and 124, which are downstream from turbine 116. Therefore, the optimal operating parameters of turbine 116 are those that maximize the combined power generation of turbines 116, 120, and 124. Similarly, the optimal parameters of turbine 108 are those that maximize the combined power generation of turbines 108 and 112 and the optimal parameters of turbine 104 are those that maximize the combined power generation of turbines 104, 112, 116, 120, and 124. A self-optimizing controller can again be used to determine the optimal operating parameters that maximize the combined power outputs. In this way, a cascade of self-optimizing controllers is able to maximize power generation by the wind farm turbine array.
Hierarchy 500 may be constructed in any number of different ways. In one embodiment, hierarchy 500 may be represented using a table or other data structure stored in a memory. For example, hierarchy 500 may be constructed based on wind direction 103. If the turbines in wind farm turbine array 100 are able to adjust their positions to face the wind, the corresponding hierarchy information may retrieved from a table relating different wind positions to different hierarchy information, in order to determine a hierarchy for use by the self-optimizing controllers of the wind farm. Similarly, a table or other data structure relating hierarchy information to the actual turbine positions (e.g., angles, compass directions, etc.) may be used to determine hierarchy 500.
In some embodiments, the hierarchy information used to determine hierarchy 500 may be predetermined, based on the design of wind farm turbine array 100. For example, the locations and spacing of the turbines in wind farm turbine array 100 may be used to determine hierarchy information based on wind direction or turbine position. In further embodiments, the hierarchy information may be determined using a self-learning approach that observes how changes in wind direction affect the individual turbines.
Referring now to
Processing circuit 224 is shown to include interface 608, which may provide data connections 610, 612, and 614 between processing circuit 224 and turbine sensors 616, turbine devices 618, and other computing devices 620, respectively. Data connections 610, 612, and 614 may be any combination of hardwired connections (e.g., via a cable, data bus, etc.) and/or wireless connections (e.g., cellular, radio frequency, WiFi, etc). For example, interface 610 may provide a wired connection between processing circuit 224 and turbine sensors 616 and a wireless connection between processing circuit 224 and other computing devices 620. In some embodiments, data connections 610, 612, and 614 may also include any number of intermediary circuits or devices. For example, data connection 614 may include any number of routers, gateways, servers, or other computing devices that relay communication data between processing circuit 224 and other computing devices 620.
Turbine sensors 616 may include any number of sensors that determine conditions related to the operation of turbine 104. For example, turbine sensors 616 may include any number of temperature sensors, pressure sensors, speed sensors, position sensors, flow rate sensors, anemometers, or wind vanes. Turbine devices 618 may include any number of non-sensor devices of the turbine that provide data to processing circuit 224 and/or receive control commands from processing circuit 224. For example, turbine devices 618 may include yaw motor 226, brake 222, generator 216, or another processing circuit that provides direct control over a turbine device. Other computing devices 620 may include any number of servers, computers, or processing circuits located remotely from the turbine. For example, other computing devices 620 may include one or more processing circuits located at another turbine or a supervisory server that oversees the operation of multiple turbines.
Memory device 604 is also shown to include measurement data 622. Measurement data 622 may include sensor data received from turbine sensors 616 via interface 606. Measurement data 622 may also include measurements from other turbines (e.g., received from other computing devices 620), and/or measurements derived from sensor data. For example, the tip speed of a turbine blade may be calculated using data indicative of the rotational speed of the blade and the wind velocity measured by an anemometer (e.g., anemometer 220, other computing devices 620, etc.). Other examples of measurements in measurement data 622 include wind direction, pitch angle, and turbine power generation.
Memory device 604 is further shown to include hierarchy analyzer 628. Hierarchy analyzer 628 generates hierarchy data, i.e., data indicative of which turbines are downstream from turbine 104. In some embodiments, hierarchy analyzer 628 may include one or more tables and/or data structures that relate turbine location data to directional data. Directional data may be, for example, a wind direction or a direction faced by rotor 208 of turbine 104. The directional and hierarchy data may be preloaded into memory device 604, based on the layout of the wind farm turbine array. In other embodiments, hierarchy analyzer 628 may utilize a self learning routine (e.g., a Bayesian network, an artificial neural network, etc.) to determine turbine location information. In further embodiments, hierarchy analyzer 628 may use location or other data from other computing devices 620 to determine which turbines are currently downstream from turbine 104.
Memory device 604 is further shown to include array optimizer 630. Array optimizer 630 receives hierarchy data from hierarchy analyzer 628 and uses the hierarchy data to determine cascade data, i.e., a set of turbine power outputs to be maximized. The set of turbine power outputs may include a single turbine, a sub-array of turbines, or the full array of turbines. For example, if the hierarchy data received from hierarchy analyzer 628 indicates that no other turbines are currently downstream from turbine 104, array optimizer 630 may determine that only the power output of turbine 104 needs to be maximized. However, if one or more turbines are currently downstream, array optimizer 630 may determine that the combined power generation by turbine 104 and the downstream turbines needs to be optimized. This determination may be provided to self-optimizing control module so that the self-optimizing control module can work to optimize the combined power generation.
Memory device 604 is also shown to include self-optimizing control module 626. Self-optimizing control module 626 uses a self-optimizing control algorithm to determine optimal operating parameters for the turbine primarily associated with processing circuit 224. The optimal operating parameters for the turbine can be selected by the self-optimizing control module 626 by seeking to maximizes the combined power generation of the turbine and its downstream turbines (e.g., as determined by hierarchy analyzer 628 and/or array optimizer 630).
In some embodiments, self-optimizing control module 626 may utilize an ESC strategy. For example, self-optimizing control module 626 may use a two-input ESC to determine an optimal pitch angle and rotor speed (or equivalently the tip-speed ratio) that maximize the power generation of the set of turbines from array optimizer 630. In other embodiments, self-optimizing control module 626 may also or alternatively determine optimize other operating parameters (e.g., torque, rotor speed, etc.) also associated with the power generation by a wind turbine. If self-optimizing control module 626 is used to optimize the combined power generation of turbine 104 and one or more downstream turbines, self-optimizing control module 626 may also use power measurements from the downstream turbines (e.g., as received from other computing devices) in the self-optimizing control strategy.
Memory device 604 is further shown to include control command generator 624. Control command generator 624 generates control commands for turbine devices 618 using the operating parameters from self-optimizing control module 626. For example, if pitch angle and rotor speed (or equivalently the tip-speed ratio) are used as inputs to self-optimizing control module 626, self-optimizing control module 626 may work in conjunction with control command generator 624 to control one or both of these parameters. If self-optimizing control module 626 determines that an adjustment is needed to the pitch angle, for example, the control command generator 624 may provide a control signal via interface 606 to a device in turbine devices 618 that regulates the blade pitch angle.
Control command generator 624 may also control other conditions of turbine 104, in addition to those used by self-optimizing control module 626. For example, control command generator 624 may send a control command to a yaw motor (e.g., in turbine devices 618), based on wind direction and rotor direction data stored in measurement data 622. In this case, the control command may cause yaw motor 226 to adjust the direction that rotor 208 faces, in order to adjust the position of turbine 104 to face the oncoming wind 102.
In some embodiments, measurement data 622, control command generator 624, self-optimizing control module 626, hierarchy analyzer 628, and array optimizer 630 may be located on a remote computing device (e.g., as part of other computing devices 620). By way of example, other computing devices 620 may include one or more servers that provide supervisory control over turbine 104. In such a case, array optimizer 620 may use hierarchy data from hierarchy analyzer 628 to generate a set of turbine measurement data for each turbine. A server may use a self-optimizing control loop as described above to generate control signals for each of the turbines. In either case, a cascade approach is taken, whether physically distributed or within a single server, to optimize the wind farm turbine array using a self-optimizing control strategy.
Referring now to
Process 700 also includes using a self-optimizing controller to maximize the power generation by a downstream turbine in the hierarchy (step 704). Based on the hierarchy, downstream turbines can be identified. In one embodiment, the self-optimizing controller is used to maximize the power generation of a terminal downstream turbine (e.g., a turbine that is influenced by the wake of one or more upstream turbines, but does not affect any downstream turbines). The self-optimizing controller may be, for example, an ESC loop that seeks out the turbine operating parameters that maximize the power generation of the downstream turbine. The operating parameters may be one or more variables associated with the turbine that can be controlled to maximize the turbine's power generation. For example, blade pitch angle, rotor speed, torque, tip speed ratio, and other parameters may be optimized.
Process 700 further includes using another self-optimizing controller to maximize the combined power generation by an upstream turbine and at least the downstream turbine (step 706). Rather than maximizing the power generation of the upstream turbine alone, a self-optimizing controller is used to maximize the combined power generation of a cluster of interrelated turbines (e.g., the upstream turbine and one or more downstream turbines from the upstream turbine). For example, an ESC strategy may be used to maximize the combined power generation by determining the optimal operating parameters for the upstream turbine. This results in optimization of the combined power generation for the hierarchy because maximizing the power output of an upstream turbine alone may result in decreasing the power output of a downstream turbine. In this way, the combined power generation by the turbines may be maximized using a cascaded approach.
Referring now to
Process 800 also includes using direction data to determine a turbine hierarchy (step 804). When the turbine array is adjusted to accommodate a change in wind direction, the set of turbines downstream from a given turbine may change. The direction data (e.g., the direction faced by the rotor of a turbine, the wind direction, etc.) may be used to determine the new turbine hierarchy. For example, if a turbine is oriented to face due west, it may have no downstream turbines. However, if the turbine is reoriented to face the northwest, it may have one or more downstream turbines.
Process 800 further includes using the hierarchy to determine a cascade of self-optimizing controllers (step 806). In an effort to maximize the power generation of the entire array, the operating parameters for an upstream turbine may be selected as calculated to maximize the combined power output of the upstream turbine and at least one turbine downstream from the upstream turbine. Terminal downstream turbines (i.e., those turbines that do not have downstream turbines) may be set to attempt to maximize their own power alone using a self-optimizing controller. Therefore, the hierarchy can be used to determine what power output each self-optimizing controller in the cascade is to attempt to maximize, whether it be for a single turbine or for a combination of turbines.
Process 808 additionally includes using the determined cascade of controllers to determine optimal turbine operating parameters that maximize power generation by the array (step 808). Operating parameters may be one or more controllable parameters that affect the power generation by the wind farm turbine array. For example, a two-input ESC strategy may be used to optimize the pitch angle and rotor speed (or equivalently the tip-speed ratio) of a turbine, based on the cascade information determined in step 806. If the turbine is upstream from other turbines, the ESC may be used to determine the pitch angle and rotor speed (or equivalently the tip-speed ratio) that maximize the power generation by the upstream turbine combined with the power generation of any downstream turbines from it. Otherwise, for terminal downstream turbines, an ESC may be used to optimize their power generation alone. In this way, the self-optimizing controllers for the turbines are cascaded to maximize the array's power output.
Process 800 further includes controlling the turbines in the array to the optimal turbine operating parameters (step 810). The turbine operating parameters used as inputs to the cascade of self-optimizing controllers may be controlled to approach their optimal values. For example, the pitch angle and rotor speed (or equivalently the tip-speed ratio) of a turbine may be adjusted via control commands. When the operating parameters for each turbine in the array approach their determined optimal values, power generation by the array approaches its maximum.
Referring to
Extremum seeking controller 906 of the east wind turbine 912 may determine the optimum parameters of east wind turbine 912. As shown in
Extremum seeking controller 904 of middle wind turbine 910 may determine the optimum parameters of middle wind turbine 910. As shown in
Extremum seeking controller 902 of the west wind turbine 908 may determine the optimum parameters of west wind turbine 908. As shown in
Referring to
As described above, a supervisory wake field controller is not necessary for effective implementation of a power maximization strategy using self-optimizing controllers. Effective de-centralized turbine management may be realized when each self-optimizing controller in a wind farm turbine array is configured to maximize the combined power generated by the upstream turbine and the downstream turbine(s) (i.e., the turbines affected by the upstream turbine's wake). However, a supervisory wake field controller may be advantageously utilized according to exemplary embodiments, such as those represented in
Referring to
Based on the turbine hierarchy, supervisory wake field controller 1002 may be configured to determine which power outputs are combined for maximization by extremum seeking controllers 1004, 1006. Because east wind turbine 1010 is not in the wake of west wind turbine 1008, supervisory wake field controller 1002 may open logic switch 1012 of extremum seeking controller 1004, as shown in
Referring to
Based on the turbine hierarchy, supervisory wake field controller 1102 determines which power outputs are combined for maximization by extremum seeking controllers 1104, 1106. Because west wind turbine 1108 is not in the wake of east wind turbine 1110, supervisory wake field controller 1102 may open logic switch 1114 of extremum seeking controller 1106, as shown in
Referring to
Based on the turbine hierarchy, supervisory wake field controller 1202 determines which power outputs are combined for maximization by extremum seeking controllers 1204, 1206. Because neither west wind turbine 1208 nor east wind turbine 1210 experience any wake effects, supervisory wake field controller 1202 may open logic switch 1212 of extremum seeking controller 1204 and logic switch 1214 of extremum seeking controller 1206, as shown in
According to an exemplary embodiment, the axial induction factor a can be used to maximize the power output of a turbine. For variable-pitch constant-speed turbines, the axial induction factor a is dependent upon the pitch. For variable-pitch variable-speed turbines, the axial induction factor a is dependent upon both the pitch angle of the blades and the rotation speed of the turbine. Thus, the axial induction factor may be optimized by a self-optimizing controller, similar to the optimization of power. In other words, axial induction factor a may be used as a proxy to maximize the power generated by one or more turbine in a wind farm turbine array. For example, the extremum seeking controllers represented in
The following text describes how optimizing axial induction factor a in a cascading system of extremum seeking controllers may provide for optimized power delivery of a wind farm where wakes from upstream controllers affect power production of downstream controllers. In an exemplary embodiment, maximization of the power extracted from one or more turbines in a wind farm can be determined using an actuator disc model and a momentum theory based on Bernoulli's equation. Referring to
U
d
=U
0(1−a) (1)
The air stream in the far wake is related to the free stream air velocity and the axial induction factor by
U
w
=U
0(1−2a) (2)
Equation 2 may be valid for an axial induction factor (a) between 0 and ½. If a is greater than ½, then the wind velocity in the far wake would be negative.
The power coefficient Cp is the ratio of the power extracted by the wind turbine to the power available in the wind far upstream of the turbine:
where Pt is the power generated by the wind turbine and Pw is the power in the wind far upstream of the turbine. The wind power Pw is determined from
P
w=½ρAU03 (4)
where A is the rotor area and ρ is the air density.
The power coefficient is related to the axial induction factor by
C
p=4a(1−a)2 (5)
Referring to
To determine the axial induction factor that maximizes the power output for a single turbine, the derivative of the power coefficient with respect to the axial induction factor is set to zero, and the axial induction factor is solved for. Taking the derivative of the power coefficient with respect to the axial induction factor gives
Setting the derivative of the power coefficient with respect to the axial induction actor to zero and solving for the axial induction factor yields the following two solutions: a=⅓ and a=1. a=⅓ is the valid solution. The second derivative of the power coefficient with respect to the axial induction factor at a=⅓ is
Since the second derivative is negative, the maximum power coefficient is obtained when a=⅓. Setting a=⅓ in Equation 5 yields the maximum power coefficient of 16/27.
Referring to
where P1 is the power generated by the west turbine, P0 is the power generated by the east turbine, and Pw,1 is the power in the wind upstream of the wind farm and the west wind turbine. The numberss in the subscripts refer to the number of turbines in the wake of a turbine. For example, the west turbine has the east turbine in its wake and the subscript of “1” is used to refer to the west turbine. The east turbine has no turbines in its wake and a subscript of “0” is used to refer to the east turbine.
The power coefficient Cp for the two turbine system of
From Equation 4 the power in the upstream of the west turbine is
P
w,1=½ρAU13 (10)
and power in the wind upstream of the east turbine is
P
W,0=½ρAU03 (11)
Equation 2 can be used to determine the wind speed upstream of the east turbine U0 from the wind speed upstream of the west turbine U1 and the axial induction factor a1 from the west turbine:
U
0
=U
1(1−2a1) (12)
Substituting Equations 10 and 12 into 11 gives
P
w,0=(1−2a1)3Pw,1 (13)
Substituting Equation 13 into Equation 9 gives
C
p
=C
p,1
+C
p,0(1−2a1)3 (14)
and substituting Equation 5 into Equation 14 yield the power coefficient
C
p=4a1(1−a1)2+4a0(1−a0)2(1−2a1)3 (15)
Referring to
Referring to
The construction and arrangement of the systems and methods as shown in the various exemplary embodiments are illustrative only. Although only a few embodiments have been described in detail in this application, many modifications are possible. For example, the position of elements may be varied and the nature or number of discrete elements or positions may be altered or varied. Accordingly, all such modifications are intended to be included within the scope of the present application. The order or sequence of any process or method steps may be varied or re-sequenced according to alternative embodiments. Other substitutions, modifications, changes, and omissions may be made in the design, operating conditions and arrangement of the exemplary embodiments without departing from the scope of the present application.
The present disclosure contemplates methods, systems and program products on any machine-readable media for accomplishing various operations. The embodiments of the present disclosure may be implemented using existing computer processors, or by a special purpose computer processor for an appropriate system, incorporated for this or another purpose, or by a hardwired system. Embodiments within the scope of the present application include program products comprising machine-readable media for carrying or having machine-executable instructions or data structures stored thereon. Such machine-readable media can be any available media that can be accessed by a general purpose or special purpose computer or other machine with a processor. By way of example, such machine-readable media can comprise RAM, ROM, EPROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code in the form of machine-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer or other machine with a processor. Combinations of the above are also included within the scope of machine-readable media. Machine-executable instructions include, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing machines to perform a certain function or group of functions. Software implementations could be accomplished with standard programming techniques with rule based logic and other logic to accomplish the various connection steps, processing steps, comparison steps and decision steps.
Although the figures may show a specific order of method steps, the order of the steps may differ from what is depicted. Also two or more steps may be performed concurrently or with partial concurrence. Such variation will depend on the software and hardware systems chosen and on designer choice. All such variations are within the scope of the disclosure. Likewise, software implementations could be accomplished with standard programming techniques with rule based logic and other logic to accomplish the various connection steps, processing steps, comparison steps and decision steps.