This application claims priority to U.S. Provisional Application Ser. No. 60/977,498, titled “ANTI-WINDUP SPINDLE SPEED CONTROL DESIGN,” filed on Oct. 4, 2007, the disclosure of which is incorporated herein by reference in its entirety.
The subject matter as described herein is generally related to servo applications.
One way to maintain a controlled device at a desired level (e.g., as measured by a control output of the controlled device) is to implement a controller which sends a control signal to manage a control input of the controlled device. A conventional controller is generally designed with a limiter to prevent the control input from exceeding a given level. However, when the control signal becomes saturated, the controller and the controlled device can become functionally unstable. If the control signal overshoots a given level, the overshoot can restrict the controlled device from reaching the desired level.
One conventional way to resolve this problem is to implement anti-windup control. The aim of anti-windup control is to modify the dynamics of a control loop when the control signal saturates so that a good transient behavior may be attained after de-saturation, while avoiding limit cycle oscillations and repeated saturations. However, because of the complexity of anti-windup control, conventional anti-windup schemes are mostly heuristic in nature, and do not address the saturation problem with stability guarantees and enhanced performance.
A new saturation control technique and apparatus is described for compensating unstable linear time-invariant systems subject to input nonlinearities. The control techniques and apparatus can operate to allow regional stability in the existence of input saturation, and provide less conservative performance than conventional anti-windup compensation schemes.
In some implementations, a system includes: a control section which operates in a feedback control mode to control a controlled device, a feedforward section which operates in a feedforward control mode to control the controlled device, and a state control section to control the controlled device in a steady state in the feedforward control mode or the feedback control mode.
In some implementations, a system includes: a control section to generate a control value for controlling a controlled device, a limiter to receive the control value and generate a regulated value, an adjusting section to adjust the control value through feedback control based on a difference between the control value and the regulated value, and a state control section to control the controlled device based on the regulated value to allow the controlled device to operate in a steady state.
In some implementations, a method includes: generating a control value for controlling a controlled device, generating a regulated value from the control value, adjusting the control value through feedback control based on a difference between the control value and the regulated value, and controlling a controlled device based on the regulated value to allow the controlled device to operate in a steady state.
In some implementations, a method includes: generating a control value for controlling a controlled device in a feedback control mode, generating a feedforward value for controlling a controlled device in a feedforward control mode, and controlling the controlled device in a steady state by switching between the feedforward control mode and the feedback control mode.
The details of one or more embodiments of the invention are set forth in the accompanying drawings and the description below. Other features and advantages of the invention will be apparent from the description and drawings, and from the claims
As shown in
The control section 10, in some implementations, may include a first adder 12, a first delaying section 14, a first multiplier 16, a second adder 18, a second multiplier 20, a third multiplier 22, a second delaying section 24, and a third adder 26. In these implementations, the first adder 12, the first delaying section 14, and the first multiplier 16 can collectively provide an average of the error difference ωerr supplied to the control section 10, which may be used to generate the control value Uin.
The first delaying section 14 may delay the error difference ωerr supplied to the control section 10. In some implementations, the amount of delay used by the first delaying section 14 may be substantially equal to an operation cycle of the controller 100. In other implementations, the original error difference ωerr and the error difference ωerr delayed by the first delaying section 14 from different operating cycles may be added to produce a combined value. For example, the first adder 12 may add the error difference ωerr supplied in a current cycle and the error difference ωerr delayed by the first delaying section 14 from a previous cycle to generate a first combined value prior to being sent to the first multiplier 16.
Upon receiving the first combined value, the first multiplier 16 multiplies the value from the first adder 12 by ½. With this configuration, the first multiplier 16 can generate an average value based on, for example, the error difference ωerr in the present cycle and the error difference ωerr in the previous cycle. While the first multiplier 16 is illustrated with a value of ½, other values also are contemplated, and the value selection may depend partially on a specific design and application.
In some implementations, the average value output by the first multiplier 16 may be output to a digital filter. In these implementations, the digital filter may include the second adder 18, the second multiplier 20, the third multiplier 22, the second delaying section 24 and the third adder 26. Depending on a specific design and application, the digital filter may include a greater or lesser number of components than those described above.
The digital filter, in these implementations, may be configured with an integral characteristic suitable for transferring the average value output by the first multiplier 16 to the limiter 50 based on a transfer function given by [1]:
C(z)=K1pg×(z+b1)/(z−1) [1]
where K1pg is a coefficient of the third multiplier 22, b1 is the coefficient of the second multiplier 20 and (z−1) is an integral term.
The first multiplier 16 forwards the average value to the second adder 18. The second adder 18 receives the average value, and adds a delayed value output by the second delaying section 24 to the average value to produce a second combined value. The third multiplier 22 receives the second combined value, and subsequently multiplies the second combined value by the coefficient K1pg to produce a control value Uin.
In some implementations, the first multiplier 16 also forwards the average value to the second multiplier 20, and the second multiplier 20 then multiplies the received average value by a predetermined coefficient b1, the output of which is sent to the third adder 26. The third adder 26 adds the value output by the second multiplier 20, the value output by the third multiplier 22, and the value output by the adjusting section 40 (as will be discussed in greater detail below) to obtain a third combined value. The second delaying section 24 delays the third combined value output from the third adder 26, the result of which is subsequently fed back to the second adder 18.
Other configurations of the control section 10 are possible. The control section 10 may have a different configuration from that shown in
The limiter 50 may receive the control value Uin output by the third multiplier 22 to generate a regulated value Uout, which may be regulated within a predetermined control range having an upper limit Umax and a lower limit Umin (
In some implementations, the predetermined control range of the limiter 50 may be established based on a predetermined range value Ur. The predetermined range value Ur may be set by, for example, the setting section 80, as will be discussed in greater detail below. In these implementations, the predetermined range value Ur may be determined to allow for stability at a desired value in a steady state, as will be described in greater detail below with respect to
In some implementations, the predetermined range value Ur lies within the predetermined control range. In these implementations, an offset may be used to define the relationship between the predetermined range value Ur and the upper limit Umax, and between the predetermined range value Ur and the lower limit Umin. For example, an offset “a” may be defined, where the difference between the upper limit Umax and the predetermined range value Ur and between the lower limit Umin and the predetermined range value Ur is the offset “a” (e.g., Umax=Ur+a or Umin=Ur−a). It should be noted that other offsets may be used, and the offset used for the upper limit Umax and the lower limit Umin may be different.
The setting section 80 may be configured to set the predetermined range value Ur. The setting section 80 also may be configured to set the predetermined control range of the limiter 50. For example, the setting section 80 may set the value of the upper limit Umax and the lower limit Umin, and their associated offset(s) with respect to the predetermined range value Ur.
To set a suitable range value Ur, the setting section 80 may first monitor and detect the output of the limiter 50. The setting section 80 may determine whether the detected output is sufficient to stabilize the controlled device in a steady state. If the detected output is sufficient to stabilize the controlled device in a steady state, the setting section 80 may set the detected output as the predetermined range value Ur, or a center value of the control range of limiter 50. By setting the range value Ur as the center value of the limiter's control range while the controlled device is in a steady state, it is possible to maintain the controller 100 in a stable operation. This configuration also allows the controller 100 to provide the controlled device with a larger margin β of a stable region through which the controlled device may operate, as will be discussed in greater detail with respect to
In some implementation, the control value Uin may be fed to the adjusting section 40. The adjusting section 40 may be configured to adjust the control value Uin, generated by the control section 10 based on the difference between the control value Uin and the regulated value Uout. In some implementations, if the control value Uin is within the control range of the limiter 50, the control value Uin may not be adjusted. Because no adjustment has been performed, the control value Uin and the regulated value Uout may substantially be identical. In other implementations, if the control value Uin is outside the control range of the limiter 50, the adjusting section 40 may perform adjustment to the control value Uin so as to minimize the difference between the control value Uin and the regulated value Uout.
The adjusting section 40 may include a fourth adder 42 and a feedback coefficient multiplier 44. The fourth adder 42 subtracts the control value Uin input to the limiter 50 from the regulated value Uout output by the limiter 50, and outputs a difference value. Subsequently, the feedback coefficient multiplier 44 multiplies the difference value by a preset feedback coefficient Kaw to generate an adjustment value and supplies the adjustment value to the third adder 26. This process allows the adjusting section 40 to add the adjustment value (e.g., Kaw×(Uout−Uin)) to the control value Uin to be generated by the control section 10 in the next operating cycle. With this feedback configuration, it is possible to minimize undershoot or overshoot which may occur when the control value Uin reaches saturation.
The state control section 60 controls the controlled device based on the regulated value Uout output by the limiter 50. The state control section 60 may include a digital-analog converter which converts the regulated value Uout to an analog voltage value. The state control section 60 also may include a driver circuit (not shown) which generates a voltage or a current to be supplied to the controlled device based on the voltage value output by the digital-analog converter.
As shown in
As described above, the setting section 80 may detect the control value Uin output by the limiter 50 when the controller device is in a steady state. By setting the range value Ur as a center value of the limiter's control range with an appropriate offset, the controller 100 can further achieve stability.
In some implementations, the range value Ur in a steady state of the controlled device may be set as the center value of the limiter's control range. In other implementations, the range value Ur need not be set as the center value, and a value other than zero may be used as the center value of the limiter's control range. In yet other implementations, a value that lies within a predetermined range with respect to the range value Ur may be set as the center value of the limiter's control range, as will be described in greater detail with reference to
In some implementations, the feedforward section 70 may generate a feedforward value according to a predetermined profile. The profile may include information that provides a suitable feedforward value based on, without limitation, a physical value of the controlled device and time that has elapsed since switching. The state control section 60 may control the controlled device using the feedforward value generated by the feedforward section 70. The feedforward section 70 may continue to output a feedforward value to the state control section 60 until a point at which the physical value of the controlled device has reached a predetermined switch value. In some implementations, the switch value may be 80% to 90% of the desired value.
Once the physical value of the controlled device has reached the switch value, the control section 10 may generate the control value Uin. In some implementations, the control value Uin may correspond to the switch value, which may be used as the initial value Xc0 of the control value Uin. In other implementations, the initial value Xc0 may be defined such that the feedforward value and the control value Uin are continuous. For example, the initial value Xc0 may be a constant multiple of the feedforward value when the state control section 60 switches from controlling the controlled device using the feedforward value (i.e., feedforward control) to controlling the controlled device using the control value Uin (feedback control). In some implementations, the initial value Xc0 may be given by [2]:
Xc0=U0/K1pg−ω0×Kvel [2]
where U0 represents the feedforward value at the time of switching, ω0 represents the error difference between the physical value and the desired value of the controlled device at the time of switching (e.g., switching from feedforward control to feedback control), and Kvel represents a predetermined coefficient. In some implementations, the predetermined coefficient Kvel may be, for example, a gain when the physical value is detected. The initial value Xc0, in some implementations, may be set such that the difference between the feedforward value at the time of switching and a value obtained by multiplying the initial value Xc0 by K1pg is smaller than a value obtained by multiplying the initial value Xc0 by K1pg. The initial value Xc0 may be a value other than zero.
The initial value storage section 30 may be used to pre-store the initial value Xc0. The initial value Xc0 may be determined, for example, by the user or the controller 100. In some implementations, the second delaying section 24 may extract the initial value Xc0 manually from the initial value storage section 30, or alternatively may receive the initial value Xc0 from the initial value storage section 30. Upon receipt of the initial value Xc0, the second delaying section 24 outputs the initial value Xc0 to the second adder 18. With this configuration, the controller 100, which employs a switch based on the feedforward control using the feedforward section 70 and the feedback control using the control section 10, can be stabilized when switching takes place.
The abscissa axis of
As shown in
Based on the temperature or the operation duration time of the controlled device, the compensating section 90 also may adjust the feedback coefficient Kaw of the feedback coefficient multiplier 44, the initial value Xc0 of the initial value storage section 30 and the range value Ur of the control range of the limiter 50 accordingly. The adjustment may be performed in a manner that allows the controller 100 to maximize the margin of a stable region through which the controlled device may operate, as will be described below with reference to
In some implementations, the compensating section 90 may include a table comprising a list of values for each of the feedback coefficient Kaw, the initial value Xc0, and the center value Ur. In these implementations, the controller 100 (or the user) can access the table to retrieve an appropriate value based on the detected temperature, operation duration time or other parameters of the controlled device. A user may add or modify the values in the table as desired. For example, the user may add one or more compensation values to the table suitable for compensating fluctuations of the parameters of the controlled device. The parameters may include, without limitation, rotation velocity, offset, temperature and operation duration time. These parameters are exemplary, and are not limiting in nature.
The stable region calculating section 210 receives a range value Ur, an upper limit Umax and a lower limit Umin of the limiter's control range, and calculates a stable region ε(P). The stable region ε(P) may include a range of parameters including a control value Xc and a physical value within which the controlled device can operate stably based on the range value Ur the upper limit value Umax, and the lower limit value Umin. In some implementations, the control value Xc and a physical value also may be determined based on an initial value Xc0 set for the control section 10, in addition to the range value Ur, the upper limit value Umax, and the lower limit value Umin. The stable region calculating section 210 may generate a state equation of the controller 100 and the controlled device (as will be explained in greater detail with respect to equation [9].
In the following description, the error difference ωerr between the rotation velocity ω of a spindle of a hard disk and its desired value, and the current I consumed by the spindle will be used as examples of physical values of controlled device. However, one of ordinary skill in the art would readily appreciate that these parameters are not limiting in nature, and other parameters also are applicable.
In some implementations, the stable region ε(P) may be represented as a function whose variables include parameters (Xc, ωerr, I) indicating a state of the controlled device. In these implementation, the stable region ε(P) may be defined as a region where the state of the controlled device converges to a certain state when the controlled device is in this region.
The coefficient of each parameter of the function representing the stable region ε(P) may be defined based on the feedback coefficient Kaw. In some implementations, if the feedback coefficient Kaw is changed, the region enclosed by the stable region ε(P) also changes in an n-dimensional space defined by n axes of parameters. The stable region calculating section 210 may determine the function of the stable region ε(P) based equation [20] as will be discussed in greater detail below.
The initial region calculating section 220 may store one or more initial values of a current, rotation velocity, and control value at the time of switching, and calculates an initial region Ξ0 based on these values. The initial region Ξ0 may include a range of values suitable for extraction when the controller switches from feedforward control to feedback control. For example, the initial region calculating section 220 may calculate a current range −i0<I<i0 (where −i0 is the lower limit and i0 is the upper limit of the current I), a rotation velocity range −ω0≦ω≦ω0 (where −ω0 is the lower limit and ω0 is the upper limit of the rotation velocity ω), and an initial region range −Xc0<Xc<Xc0 (where −Xc0 is the lower limit and Xc0 is the upper limit of an initial value Xc). In some implementations, the ranges −i0<I<i0, −ω0<ω<ω0 and −Xc0<Xc<Xc0 may be used to describe the initial region Ξ0, as will be described later with respect equation [33].
The gain determining section 230 may be used to determine the feedback coefficient Kaw of the adjusting section 40 such that the stable region ε(P) may include the initial region Ξ0, and the margin β of the stable region ε(P) with respect to the initial region Ξ0 can be maximized. In some implementations, determining the feedback coefficient Kaw may include maximizing the margin β such that β×Ξ0 lies within the stable region ε(P). By maximizing the margin β of the stable region ε(P), the controller 100 may be optimized to achieve stability and efficiency. The process for determining the feedback coefficient Kaw which maximizes the margin β of the stable region ε(P) will be described with respect to, for example, equations [1]-[33].
As shown in
The process of determining the feedback coefficient Kaw which maximizes the margin β will now be described. An error system is a system that defines the difference between the original dynamics of a system and the dynamics of the system in its steady state. In some implementations, the error system may be defined using a state equation and an output equation, which may be given by [3] and [4]:
xp[k+1]−xpr=AP(xp[k]−xpr)+Bpsat(vc[k]−vt) [3]
y[k]−r=Cp(xp[k]−xpr) [4]
where k indicates a k-th sample, xp [k] indicates a state vector of the controlled device represented by an np-dimensional real-number matrix, vc [k] indicates an input vector represented by an m-dimensional real-number matrix (this input vector may function as the control signal output by the controller 100), y[k] indicates an output vector represented by a p-dimensional real-number matrix (this output vector may function as a physical value of the controlled device), vr indicates a vector of an external force represented by an m-dimensional real-number matrix, xpr indicates a state vector of the controlled device in its steady state represented by the np-dimensional real-number matrix, r indicates an output vector in a steady state represented by the p-dimensional real-number matrix (this output vector may function the desired value of the physical value), and Ap, Bp, and Cp each indicate a constant matrix. The function sat(v) may be defined by [5]:
The state equation and output equation of the error system of the controller 100 may be given by [6] and [7]:
xc[k+1]−xcr=Ac(xc[k]−xcr)+Bc(r−y[k])+Ec(sat(vc(t)−vr)−(vc(t)−vr)) [6]
vc[k]−vr=Cc(xc[k]−xcr)+Dc(r−y[k]) [7]
where xc[k] indicates a state vector of the controller 100 represented by an np-dimensional real-number matrix, vc[k] indicates an output vector represented by an m-dimensional real-number matrix, xcr indicates a state vector of the controller 100 in its steady state represented by an nc-dimensional real-number matrix, Ec indicates a matrix representing a feedback coefficient Kaw, and Ac, Bc, Cc, and Dc each indicate a constant matrix. The function sat(vc(k)−vr) may be defined by [8].
A state equation of a system obtained by merging the controller 100 and the controlled device may therefore be obtained from [3], [4], [6] and [7] to establish [9]:
ξ[k+1]=Aξ[k]−(B+REc)φ(Kξ[k]) [9]
where:
A matrix G may be defined as [10]:
G⊂Rmx(n
A polyhedron J also may be defined as [11]:
J={ξ⊂Rn
Establishing [12]:
ξ⊂J [12]
a positive constant matrix T may be given by [13]:
φ(Kξ)′T[φ(Kξ)−Gξ]≦0 [13]
where T may be defined as [14]:
T⊂Rm×m [14]
Establishing the following relationship [15]:
G=YP
Y⊂Rm×(n
the term μ02 may be defined as [16]:
μ02>ξ′(K′−W−1Y′)(K−YW−1)ξ [16]
where the following definition [17] is used:
P=W−1 [17]
A linear matrix inequality (LMI) problem may be assumed, which may be defined by the following inequality [18]:
Based on a Schur's complementary matrix, the following inequality [19] may be defined as:
ξ′W−1ξ·μ02>ξ′(K′−W−1Y′)(K−YW−1)ξ [19]
An ellipse ε(P) also may be assumed, which may be represented by [20]:
ε(P)={ξ⊂Rn
If the inequality [18] is satisfied, the ellipse ε(P) defined in equation [20] may be included in the polyhedron J defined by equation [11] based on equation [16] and equation [19]. The stable region calculating section 210 may calculate the stable region ε(P) based on equation [20].
A symmetric positive matrix P will now be assumed, which may be defined as [21]:
P⊂R(n
Further, a quadratic Lyapunov function given by the equation [22] will be assumed:
Vξ[k])=ξ[k]′Pξ[k] [22]
The variation of the function defined in equation [22] may be represented using equation [9] to create [23]:
ΔV(ξ[k])=V(ξ[k])−V(ξ[k+1])=ξ[k]′Pξ[k]−ξ[k]′(A′PA)ξ[k]2ξ[k]′A′P(B+REe)φ(Kξ[k])−φ(Kξ[k])′(B+REc)P(B+REc)φ(Kξ[k]) [23]
Using equation [13] and equation [23], the following inequality [24] may be defined:
ΔV(ξ[k])≧ξ[k]′Pξ[k]−ξ[k]′(A′PA)ξ[k]+2ξ[k]′A′P(B+REc)φ(Kξ[k])−φ(Kξ[k])′(B+REc)′P(B+REc)φ(Kξ[k])+2φ(kξ[K])′t[φ(kξ[K])−gξ[K]] [24]
Based on equation [23] and equation [24], the following relationship may be established:
where:
In this case, the energy of the system represented by the state equation in equation [9] will gradually decrease along with the transition of the state, and the system will subsequently converge to a predetermined state.
To establish:
ΔV(ξ[k])≧0 [26]
the following equation [27] also should be established from equation [25]:
Based on a Schur's complementary matrix, the following relationship [28] may be established from the equation [27]:
where:
From the above, if equation [28] and equation [18] are satisfied, the stable region ε(P) will include the initial region Ξ0. Note that the initial region Ξ0 may be defined by [29]:
Ξ0=Co{μr⊂Rn
The initial region calculating section 220 may calculate the initial region Ξ0 based on equation [29]. Ec, which may be used to maximize β and represented by the following relationship, will now be assumed.
β·Ξ0⊂ε(P) [30]
That is, Ec, which satisfies the following relationship, may be obtained based on LMI.
where:
β=1/√{square root over (μ)}
The gain determining section 230 may calculate the feedback coefficient Kaw based on equation [32]. By the process described above, the feedback coefficient Kaw(Ec), which maximizes the margin (β) of the stable region ε(P), can be obtained.
Next, the design support apparatus 200 sets the control range of the limiter 50 based on the estimation performed in step S300 (S302). The design support apparatus 200 may set the range value Ur as the center value Ur of the control range as well as the values for the upper limit Umax, the lower limit Umin, as described with respect to
The design support apparatus 200 sets the initial value Xc0 of the control value Uin generated by the control section 10 when the controller 100 switches from feedforward control to feedback control (S304). In some implementations, the design support apparatus 200 may set the feedforward value output by the feedforward section 70 at the time of switching as the initial value Xc0, as described with respect to
Subsequently, the initial region calculating section 220 calculates the initial region Ξ0 (S306). In some implementations, the initial region calculating section 220 may calculate the initial region Ξ0 based on equation [29]. For example, the initial region Ξ0 calculated by the initial region calculating section 220 may be represented by [33]:
where:
i0=1.2i*0,ω0=1.2ω*0,Xc0=1.2X*c0 [34]
The following expression [35] may be used to indicate the initial values of the current consumed by the spindle of the hard disk, the rotation velocity of the spindle, and the control value generated by the control section 10, when the controller 100 switches to feedback control:
i*0,ω*0,X*c0 [35]
Next, the gain determining section 230 calculates the feedback coefficient Kaw (S308). The gain determining section 230 may calculate the feedback coefficient Kaw based on Ec which can be determined via equation [32]. Using the calculated Ec, the gain determining section 230 may calculate the feedback coefficient Kaw based on the following equation [36]:
Kaw=Ec/Klpg [36]
Next, the gain determining section 230 checks whether the stable region ε(P) defined by the feedback coefficient Kaw includes the initial region Ξ0 (S310). The gain determining section 230 may alternatively check whether the margin β of the stable region ε(P) with respect to the initial region □0 (which in one implementation corresponds to the calculated feedback coefficient Kaw) is larger than a predetermined value. In some implementations, determining whether the stable region ε(P) includes the initial region Ξ0 includes determining whether β is larger than 1.
Where the stable region ε(P) includes the initial region Ξ0, in some implementations, the gain determining section 230 may utilize the calculated feedback coefficient Kaw as the coefficient for the feedback coefficient multiplier 44, and complete the process. Thereafter, the gain determining section 230 sets the initial value Xc0, the center value Ur, the upper limit Umax, and lower limit Umin of the limiter's control range as the initial parameters for the controller 100.
Where the stable region ε(P) does not include the initial region Ξ0, in some implementations, the design support apparatus 200 modifies the initial value Xc0, the center value Ur, the upper limit Umax, and lower limit Umin of the limiter's control range, and repeats the process beginning from step S302. For example, where the margin 3 corresponding to the feedback coefficient Kaw calculated at step S308 is smaller than 1, the design support apparatus 200 can modify the initial value Xc0, and repeats the process shown in
If the upper limit Umax, and lower limit Umin of the control range are changed, the range enclosed by the stable region ε(P) may be affected as shown by equations [3], [4], [6], [7], [9], [11], [13], [16], [18] and [19]. Thus, in some implementations, before repeating the process, the design support apparatus 200 may re-set the upper limit Umax, and lower limit Umin such that the difference between the upper limit Umax, and lower limit Umin becomes a larger value than the difference before re-setting so that the region enclosed by the stable region ε(P) may become larger.
Further, if the initial value Xc0 is changed, the initial region Ξ0 also may change as shown by equations [29] and [30]. Thus, in some implementations, before repeating the process, the design support apparatus 200 may re-set the initial value Xc0 to be a value closer to the desired value, so that the initial region Ξ0 may become smaller.
The range determining section 240 may be configured to determine the control range of the limiter 50. As described with respect to
The initial value determining section 250 may be configured to determine the initial value Xc0 of the control section 10. As described with respect to
In some implementations, the range determining section 240 and the initial value determining section 250 may simultaneously modify associated settings to change the control range (Umax, Umin) and the initial value Xc0 when the margin β is smaller than a predetermined value. In these implementations, a priority scheme may be employed for prioritizing such modifications. For example, the range determining section 240 may effectuate changes to the control range (Umax, Umin) before the initial value determining section 250 modifies the initial value Xc0. As another example, if the initial value Xc0 has a greater margin than that of the control range (Umax, Umin), the initial value determining section 250 may modify its associated setting before the range determining section 240 changes its associated setting.
The design support apparatus 200 can set the feedback coefficient Kaw of the controller 100 described with respect to
Referring to
In some implementations, the feedback coefficient used for calculating the stable region ε(P) may be calculated in advance by the design support apparatus 200 (or may be determined by user). For example, the design support apparatus 200 may calculate the feedback coefficient used in step S320 by performing the process described in
The design support apparatus 200 obtains a tolerated value βp of the margin β (S322). Again, the tolerated value βp may, for example, be obtained from the specification of the controlled device. Alternatively, the tolerated value βp may be obtained based on one or more operating parameters associated with the controlled device. In some implementations, the design support apparatus 200 may be given a tolerated value βp whose absolute value is smaller than the maximum margin βmax.
The design support apparatus 200 calculates a width dp of the control range which corresponds to the tolerated value Pp when the ideal value is set as the center value of the control range (S324). For example, the design support apparatus 200 may successively change the width of the control range and calculate the stable region ε(P) for each width of the control range. Subsequently, the design support apparatus 200 may calculate the margin of each calculated stable region ε(P) with respect to the initial region Ξ0, and identify the width that corresponds to the tolerated value βp as the width dp.
The design support apparatus 200 sets the ideal value (range value Ur) as the center value of the control range of the limiter 50 and which corresponds to the difference between dmax and dp, (S326). For example, assuming that L=dmax−dp, the range determining section 240 may set the center value within a range of Ur−L to Ur+L. Of course, the ideal value need not be set as the center value but one which is bound within the range. In such a case, the center value may be determined based on the range defined by the margin γ.
While this specification contains many specifics, these should not be construed as limitations on the scope of what being claims or of what may be claimed, but rather as descriptions of features specific to particular embodiments. For example, the above descriptions also are applicable for controlling the controlled device where an output to the controlled device has reached saturation. Certain features that are described in this specification in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable sub-combination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a sub-combination or variation of a sub-combination.
Similarly, while operations are depicted in the drawings in a particular order, this should not be understand as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system components in the embodiments described above should not be understood as requiring such separation in all embodiments, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products.
A number of embodiments of the invention have been described. Nevertheless, it will be understood that various modifications may be made without departing from the scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
3749891 | Burrows et al. | Jul 1973 | A |
4035719 | Anderson | Jul 1977 | A |
5568456 | Hayashi et al. | Oct 1996 | A |
6330483 | Dailey | Dec 2001 | B1 |
6490119 | Mittal et al. | Dec 2002 | B1 |
7047312 | Aweya et al. | May 2006 | B1 |
7133236 | Koide et al. | Nov 2006 | B2 |
7176648 | Choi | Feb 2007 | B2 |
7472585 | Abramovitch | Jan 2009 | B2 |
7711453 | Yo et al. | May 2010 | B2 |
20020186440 | Adachi et al. | Dec 2002 | A1 |
20030016607 | Cho et al. | Jan 2003 | A1 |
20030060818 | Kannenberg et al. | Mar 2003 | A1 |
20040084015 | Sun et al. | May 2004 | A1 |
20050254598 | Zhidkov et al. | Nov 2005 | A1 |
20060025087 | Nilsson | Feb 2006 | A1 |
20060039079 | Kobayashi et al. | Feb 2006 | A1 |
20060190100 | Weggel | Aug 2006 | A1 |
20070191967 | Yo et al. | Aug 2007 | A1 |
20080065257 | He et al. | Mar 2008 | A1 |
Entry |
---|
Washington et al. “Simulink Tutorial”, Spring 2002, The Intelligent Structures and Systems Laboratory Department of Mechanical Engineering the Ohio State University, pp. 1-34. |
Edwards et al., “An anti-windup scheme with closed-loop stability considerations”, 1999, Pergamon, Automatica 35, pp. 761-765. |
J.M. Gomes da silva Jr, “Anti-Windup design with guaranteed regions of stability for discrete-time linear systems”, American Control Conference 2004, IEEE, vol. 6, pp. 5298-5303. |
Number | Date | Country | |
---|---|---|---|
60977498 | Oct 2007 | US |