Method and System for Controlling Angular Speeds of Motors in Speed Sensorless Induction Motors

Information

  • Patent Application
  • 20170201198
  • Publication Number
    20170201198
  • Date Filed
    January 11, 2016
    9 years ago
  • Date Published
    July 13, 2017
    7 years ago
Abstract
Angular speed of a rotor of an induction motor without an encoder for rotor position and speed sensing is controlled by first sensing stator currents and voltages of the induction motor. A dynamic gain estimator is designed by applying a state transformation to a model of the induction motor. A states of the induction motor is estimated by applying the dynamic gain estimator to the currents and the voltages, and then the state is used to control the angular speed of the rotor of the induction motor.
Description
FIELD OF THE INVENTION

This invention relates generally to controlling electric motors, and more particularly to a method and system for controlling the angular speed of a rotor of in a speed sensorless induction motor.


BACKGROUND OF THE INVENTION

Adjustable speed induction motors are widely used due to low maintenance cost and acceptable performance. The speed control design, or equivalently, the motor drive design, of the induction motor is challenging due to highly nonlinear dynamics. Among various means, the vector (field oriented) control appears to be a good and most popular solution that has evolved as a mature technology.


This invention considers speed sensorless control technologies for the induction motor, i.e., an inductor motor where the rotor speed or position is not measured by encoders. Speed sensorless motor drives (motor drives) are desirable due to the elimination of speed sensors, lower cost, and improved reliability of the resultant system. Current speed sensorless motor drives suffer significant performance degradation due to the absence of the encoder to sense the rotor position and speed. Thus, their applications remain limited to fields requiring low or medium performance.


The performance of speed sensorless motor drives relies heavily on the performance of a flux and speed estimator 106-107 described below with reference to FIGS. 1A and 1B. A number of prior arts methods contribute to the developments of speed sensorless control technologies. The flux and speed estimator design methods include: a voltage model based direct integration approach, an adaptive observer approach, an extended kalman filter approach, see Schauder, “Adaptive speed identification for vector control of induction motors without rotational transducers,” IEEE Transactions on Industry Applications, vol. 28, no. 5, pp. 1054-1061, September/October 1992, H. Kubota, K. Matsuse, and T. Nakano, “DSP-based speed adaptive flux observer of induction motor,” IEEE Transactions on Industry Applications, vol. 29, no. 2, pp. 344-348, March/April 1993, H. Kubota and K. Matsuse, “Speed sensorless field-oriented control of induction motor with rotor resistance adaption,” IEEE Transactions on Industry Applications, vol. 30, no. 5, pp. 1219-1224, September/October 1994, K. Ohyama, G. M. Asher, and M. Sumner, “Comparative analysis of experimental performance and stability of sensorless induction motor drives,” IEEE Transactions on Industrial Electronics, vol. 53, no. 1, pp. 178-186, February 2006, D. J. Atkinson, P. P. Acamley, and J. W. Finch, “Observers for induction motor state and parameter estimation,” IEEE Transactions on Industry Applications, vol. 27, no. 6, pp. 1119-1127, November/December 1991, and M. Hilairet, F. Auger, and E. Berthelot, “Speed and rotor flux estimation of induction machines using a two-stage extended kalman filter,” Automatica, vol. 45, no. 8, pp. 1819-1827, August 2009.



FIGS. 1A and 1B show a conventional speed sensorless motor 105 and controller. An input signal 111 is a reference rotor flux amplitude, a signal 112 is an estimate outputted from a flux estimator block 106. A signal 113 represents a difference between signals 111 and 112.


A flux control block 101 determines a stator current in the d-axis, denoted by signal 114. A signal 115, as an estimate or true stator current in the d-axis, is produced by the flux estimator 106.


A difference signal 116 between signals 115 and 114 is used by a current control block 103 to determine a reference stator voltage in the d-axis, which is part of signal 123. Similarly, a signal 117 denotes a desired rotor speed reference for the induction motor. A signal 118 denotes an estimated rotor speed produced by a speed estimator block 107 based on an output signal 126 of the flux estimator 106.


A difference signal 119 between signals 117 and 118 is input to the speed control block 102 to determine a reference stator current 120 in the q-axis. An estimated or true stator current 121 in the q-axis is compared to the reference stator current 120 in the q-axis to produce a difference signal 122. The current control block 103 determines a desired stator voltage signal 123 in d- and q-axis, on the basis of the difference signals 116 and 122.


An inverse Clarke/Park transformation 104 convert the desired stator voltages signals in d- and q-axis into desired well-known three-phase voltages, and produces three-phase voltages, denoted as by 124, to drive the induction motor 105.


Note that the flux estimator 106 takes the three-phase voltages 124, sensed 131 phase currents 125, see FIG. 1B, as input signals and outputs estimated or true stator currents 115 and 121, estimated rotor flux amplitude 112, and estimated rotor speed signal 118 to produce the difference signals 113, 116, 119, and 122. The signal 119 is used by the speed control block 102.



FIGS. 2A and 2B show prior art estimator methods based on stator currents and voltages 211, which are measured by sensors 202 and are assumed in balanced three-phases and in orthogonal stationary frame, and an induction motor model 201. A Clarke/Park transformation 203 is applied to transform the induction motor model 201 and the sensed signals 211 so that quantities (including variables in the induction motor model and measured signals) in balanced three-phases are converted into quantities in balanced two-phases.


All these estimation methods fit an architecture shown in FIGS. 2A and 2B. As shown in FIG. 2A-2B, the estimator methods are based on stator currents and voltages signals, denoted by 211, measured by a sensing block 202 and an induction model 201. A Park Transformation block 203 may or may not be used to transform the induction motor model 201 and the sensed signals 211. A block 204 represents an estimator to produce estimates of stator currents, rotor flux, and rotor speed signals. The voltage model based direct integration suffers accumulation error due to inaccurate measurement. Adaptive observer and extended kalman filter approaches yield slow speed tracking performance because the speed is treated as an unknown parameter and its identification is slow.


This fact is elaborated by FIG. 2B, where block 222 represents the unnecessary assumption that the rotor speed is a parameter, and a speed estimator 223 produces the rotor speed estimate based on outputs of block 221, and the assumption 222.


Overall, most of existing speed sensorless motor drives produce limited speed tracking performance due to performing estimator design in appropriate state coordinates and under unnecessary assumption. Also, most speed-sensorless estimation methods are ad-hoc and the resultant estimation error dynamics are not guaranteed to be stable.


SUMMARY OF THE INVENTION

The embodiments of the invention provide a method and system for controlling rotor angular speed of an induction motor. The invention focuses on estimation methods that guarantee stability and practical effectiveness. The main contributions of the invention are as follows.


The invention uses an induction motor model that admits a non-triangular observable form by changing state coordinates. Then, high gain observer design can be performed in new coordinates.


However, the high gain observer in the new coordinates is not implementable due to failure to establish a closed form expression of an inverse state transformation. Therefore, the embodiments use several observers, which can be implemented in the original coordinates.


The implementable observers in the original coordinates involve a matrix inversion, which can be subject to numerical stabilities from time to time. Consequentially, the invention uses several techniques to address this issue, and makes the high gain observer practical.





BRIEF DESCRIPTION OF THE DRAWINGS


FIGS. 1A and 1B are block diagrams of a prior art sensorless speed motor drive;



FIGS. 2A and 2B are block diagram of prior art estimator methods based on stator currents and voltages signals;



FIG. 3A is a block diagram of a method for estimating a state of an induction motor according to embodiments of the invention;



FIG. 3B is a block diagram of additional details of the estimation method according to the embodiments of the invention;



FIG. 4 is a block diagram of a speed sensorless motor drive using the estimation method to obtain a state estimate for a controller according to embodiments of the invention;



FIG. 5 is a block diagram of a method for obtaining a high gain estimator in new state coordinates for the induction motor according to embodiments of the invention;



FIGS. 6A and 6B are block diagrams of methods for deriving a dynamic gain estimator in original coordinates based on the estimator design in the new coordinates according to embodiments of the invention;



FIGS. 7A and 7B are block diagrams of point-wise matrix inverse approximations according to embodiments of the invention; and



FIGS. 8A and 8B are block diagrams of functional matrix inversion approximations according to embodiments of the invention.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

The embodiments of our invention provide a method and system for controlling rotor angular speed of an induction motor.


We define the following notations. For a variable ζ of the induction motor, we denote ζ as the measured variable, {circumflex over (ζ)} as the estimate of the variable, ζ* as the reference of the variable, {tilde over (ζ)}=ζ−{circumflex over (ζ)} as the estimation error, and eζ=ζ*−ζ as a tracking error.












Notations










Notation
Description







ids, iqs
stator currents in d- and q-axis



Φdrqr
rotor fluxes in d- and q-axis



ω
rotor angular speed



uds,uqs
stator voltages in d- and q-axis



ω1
angular speed of a rotating frame



Φdr*
rotor flux amplitude reference



ω*
rotor angular speed reference



ids*,iqs*
references of stator currents in d- and q-axis



Tl
load torque



J
inertia



Ls, Lm, Lr
stator, mutual, and rotor inductances



Rs, Rr
stator and rotor resistances







σ







L
s



L
r


-

L
m
2



L
r












α
Rr/Lr



β
Lm/(σLr)



γ
Rs/σ + αβLm



μ
3Lm/(2JLr)










Clarke/Park Transformation


The Clarke transformation (α−β transformation), transforms quantities in three-phase circuits to a space vector representation, and thus simplifies the analysis of the three-phase circuits. In this disclosure, the Clarke transformation is limited to the case that transforms quantities in three-phase circuits such as three-phase stator voltages into a space vector in a fixed frame.


Similarly, the Park transformation (d−q transformation), projects quantities in the fixed frame onto a rotating two-axis reference frame. The Clarke/Park transformation and its inverse are well-known for those skilled in the art. Generally, applying the optional Park transformation after the Clarke transformation facilitates the control design.


Induction Motor Models


With the Clarke/Park transformation, a general model of the induction motor is












i
.

ds

=


-


γ

i

ds


+


ω
1



i
qs


+

β


(


αΦ
dr

+

ωΦ
qr


)


+


u
ds

σ











i
.

qs

=


-


γ

i

qs


+


ω
1



i
ds


+

β


(


αΦ
qr

+

ωΦ
dr


)


+


u
qs

σ












Φ
.

dr

=


-

αΦ
dr


+


(


ω
1

-
ω

)



Φ
qr


+



α

L

m



i
ds




,







Φ
.

qr

=


-

αΦ
qr


-


(


ω
1

-
ω

)



Φ
dr


+



α

L

m



i
qs




,






ω
.

=


μ


(



Φ
dr



i
qs


-


Φ
qr



i
ds



)


-


T
l

J



,





y
=


[




i
ds




i
qs




]

T


,





(
1
)







where y represents sensed stator current signals, ω1 is the rotational speed of a reference frame. If ω1=0, Eqn. (1) is reduced to











i
ds

=


-


γ

i

ds


+

β


(


αΦ
dr

+

ωΦ
qr


)


+


u
ds

σ










i
qs

=


-


γ

i

qs


+

β


(


αΦ
qr

+

ωΦ
dr


)


+


u
qs

σ












Φ
.

dr

=


-

αΦ
dr


-

ωΦ
qr

+



α

L

m



i
ds




,







Φ
.

qr

=


-

αΦ
qr


+

ωΦ
dr

+



α

L

m



i
qs




,






ω
.

=


μ


(



Φ
dr



i
qs


-


Φ
qr



i
ds



)


-


T
l

J



,





y
=


[




i
ds




i
qs




]

T


,





(
2
)







which represents the induction motor model without applying the Park transformation, and corresponds to block 201 in FIG. 2A. State of art estimator designs are usually based on the models in Eqns. (1) or (2), which have the same state coordinates denoted by (ids, i qs, Φdr, Φqr, ω)T. A direct application of existing estimator design methodologies, e.g., sliding mode observer, high gain observer, Luenberger observer, etc., to the models (1) or (2) does not produce a good estimation of induction motor state including stator currents, rotor flux, and rotor speed, due to coupled nonlinear terms in differential equations. For example, the term ωqr in the right hand side of the differential equation defining ids is nonlinear, i.e.,







i
ds

=



-
γ







i
ds


+

β


(


α






Φ
dr


+

ω






Φ
qr



)


+



u
ds

σ

.






Generally, the system in Eqn. (1) cannot be used to design convergence-guaranteed nonlinear observers. In order to design observers giving provably convergent estimation error dynamics, it is beneficial to transform the system (1) into certain structures by a change of coordinates, for simplicity in this invention, a change of state coordinates.


The invention uses the following method and system for state estimation based on a transformed induction motor model obtained by applying a change of state coordinates to the induction motor model (1) or (2).


As shown in FIG. 3A, a state transformation 301, which defines a different set of state coordinates and facilities systematic estimator design, is used in the estimator design flow. The state transformation 301 can be performed on the induction models (1) or (2), e.g., a Park transformation can be used. Applying the state transformation to the induction motor model 201 and sensed stator currents and voltages signals 211 from the sensors 202 produces a transformed induction motor model 303. The transformed induction motor model can then be used to design the state estimator performing the state estimation 302.



FIG. 3B shows additional details of the estimation using the induction motor model 201 and Clarke/Park transformation 203 to obtain the state transformation 301. Given the transformed induction motor model 303, a high gain estimator design in the new coordinates, defined by the state transformation, is performed in block 321. Then, a dynamic high gain estimator design based on the induction motor model 201, in the original coordinates, is performed in block 322.


The block 322 outputs a high gain estimator 401 in the original state coordinates, which can be implemented in processor to produce estimates 402 of induction motor states including the stator currents, the rotor fluxes, and the rotor speed, also see FIG. 4.



FIG. 4 shows a method for obtaining the state estimate 402 for the controller 101 using the high gain estimator in the original coordinates as 401 so that the speed sensorless motor drives can be realized. During operation of the motor, the block 202 senses the induction motor stator voltages and currents in three-phases. Block 203 transforms the three-phase voltages and currents into space vector signals 411 representing stator currents and rotor fluxes in d and q axes.


The dynamic gain estimator in the original coordinates 401 produces state estimates (îds, êqs, {circumflex over (Φ)}dr, {circumflex over (Φ)}qr, {circumflex over (ω)})T 402 for the controller 101, which in turn determines command voltages 123 in two-axis space for the motor. The command voltages 123 are transformed into command voltages in three-phase to the induction motor using the inverse Clarke/Park transformation 104.


Next described is an embodiment of new coordinates which simplifies state estimation in speed sensorless motor drives.


Non-Triangular Observable Form


A high gain observer design can be carried out when the system (1) is transformed into the following non-triangular observable form by a change of state coordinates x=φ(ζ)






{dot over (x)}=Ax+φ(x, u)





y=Cx,   (3)


where the state x ∈custom-charactern, and for 1≦k≦p,






x
=



[




x
1











x
p




]






with






x
k


=


[




x
1
k











x

λ
k

k




]





λ
k











A
=

diag


{


A
1

,





,

A
p


}



,










A
k

=


[



0



I


λ
k

-
1






0


0



]










λ
k

×

λ
k












C
=

diag


{


C
1

,





,

C
p


}



,






C
k

=


[



1


0



]









λ
k




,




where, xk denotes the state of the kth subsystem associated with the kth output yk, and λk, 1≦k≦p are the dimensions of all subsystems. For 1≦k≦p, we call λk subsystem indices, and Σk=1p λk=n. The vector field φ(x, u) is







ϕ
=



[




ϕ
1











ϕ
p




]






with






ϕ
k


=


[




ϕ
1
k











ϕ

λ
k

k




]









λ
k





,





1

k


p
.






Specifically, φik has the following structure: for 1≦i≦λk−1,





φikik(x1, . . . , xk−1, x1k, . . . , xik, x1k+1, . . . , x1p, u)   (4)


and for i=λk





φiiλkk(x1, . . . , xp, u).


Motor Drives: Verifying that System (1) Admits the Form (3)


A concise representation of system (1) is





{dot over (ζ)}=f(ζ)+g1uds+g2uqs,


where





ζ=(dds, iqs, Φdr, Φqr, ω)T,






g
1=(1/σ,0,0,0,0)T,






g
2=(0,1/σ,0,0,0)T, and


f, g1, g2 are appropriately defined according to (1).


System (1) is transformable to the non-triangular observable form by the following change of state coordinates, for the kth subsystem











x
k

=



φ
k



(
ζ
)


=

[





h
k



(
ζ
)













L
f


λ
k

-
1





h
k



(
ζ
)






]



,




(
5
)







where λk are observability indices. Observability ensures that






x=φ(ζ)=((φ1(ζ))T, . . . , (φp(ζ))T)T


defines new coordinates, i.e., φ(ζ) is a local diffeomorphism.


The observable form is not uniquely defined due to the non-uniqueness of observability definitions and observability indices.


In one embodiment, for system (1) with outputs h1=ids and h2=iqs, observability indices can be taken as (3, 2). For example, we take (λ1, λ2)=(3, 2) and verify that new state coordinates, given by






x=(h1, Lfh1, Lf2h1, h2, Lfh2)T   (6)


transforms (1) into the non-triangular observable form (3). For a smooth vector field f (ζ): Rn→Rn and a smooth function h(ζ), we denote








L
f


h

=




h



ζ




f


(
ζ
)







the Lie derivative of h(ζ) along f (ζ). Repeated Lie derivative are defined as








L
f
k


h

=





(


L
f

k
-
1



h

)




ζ




f


(
ζ
)







with k>1.


Given Eqn. (6), the system in x-coordinates is






{dot over (x)}=Ax+φ(x, u)





y=Cx,


where A=diag{A1, A2} with A1 ∈ R3×3 and A2 custom-character2×2, C=diag{C1, C2} with C1 ∈ R3 and C2 custom-character2. One can verify that φ satisfies the triangular condition in Eqn. (4).


In another embodiment, for system (1) with outputs h1=iqs and h2=ids, observability indices can be taken as (λ1, λ2)=(3,2), and we can verify that new state coordinates x=(h1, Lfh1, Lf2h1, h2, Lfh2)T transforms (1) into the non-triangular observable form (3).


High Gain Estimator Design in New Coordinates x


For the case when the inverse of the state transformation ζ=φ−1(x) is unsolvable, the high gain estimator design in new coordinates x=φ(ζ) is not trivial.



FIG. 5 shows that this requires a block 501 to derive an estimate of a strict upper bound of the Lipschitz constant φ(x, u) in the new coordinates, whose expression is unknown. Then, the high gain estimator design 321 in the new coordinates can be used to obtain the high gain estimator design 511.


Case When ζ=φ−1(x) is Solvable


Given the state transformation x=φ(ζ) and its inverse ζ=φ−1(x), one can obtain the system representation in the non-triangular observable form. Observer design is performed in the non-triangular observable coordinates to estimate x. Afterwards, estimates of ζ, denoted by {circumflex over (ζ)}, is reconstructed out of {circumflex over (x)}. For the kth subsystem, we use the following observer













x
^

.

k

=



A
k




x
^

k


+


ϕ
^

k

+


θ

δ
k





Δ
k

-
1




(
θ
)




S
k

-
1




C
k
T



C
k




x
~

k












y
^

k

=


C
k




x
^

k








where









x
^

k

=


(



x
^

1
k

,





,


x
^


λ
k

k


)

T


,



x
~

k

=


x
k

-


x
^

k



,





θ
>
0









δ
k

=

(








2

p
-
k




(




i
=

k
+
1


p



(


λ
i

-

3
2


)


)


,





if





1


k


p
-
1







1
,





if





k

=
p











Δ
k



(
θ
)



=


diag


{

1
,

1

θ

δ
k



,





,

1

θ


δ
k



(


λ
k

-
1

)





}








ϕ
^

k


=




(



ϕ
^

1
k

,





,


ϕ
^


λ
k

k


)

T








ϕ
^

i
k


=


ϕ
i
k



(



x
^

1

,





,


x
^


k
-
1


,


x
^

1
k

,





,


x
^

i
k

,


x
^

1

k
+
1


,





,


x
^

1
p

,
u

)











(
7
)







and Sk is solved from






S
k
+A
k
T
S
k
+S
k
A
k
=C
k
T
C
k.   (8)


Note that θ depends on the Lipschitz constant ω.


Case When ζ=φ−1(x) is Unsolvable


Without the closed form expression of the inverse state transformation (=φ−1(x), one cannot obtain the system representation in the non-triangular observable form because the Lipschitz constant φ(x, u) is unknown. This poses significant challenges to observer design approaches with state transformation involved because the observer (7) cannot be designed or implemented without knowing the expression of the Lipschitz constant φ(x, u). This section describes that one can still perform observer design in the non-triangular observable coordinates.


We describe how to derive the upper bound of the Lipschitz constant of φ. The design of observer (7) necessitates the expression of φ(x, u) in order to estimate the Lipschitz constant of φ(x, u) in x. We show how the Lipschitz constant of φ(x, u) in x can be estimated on the basis of φ(ζ). Assume that φ(x, u) is globally Lipschitz with respect to x uniformly in u, i.e., ∀x1, x2 custom-charactern, ∃Lx>0





|φ(x1, u)−φ(x2, u)≦Lx|x1−x2|.   (9)


Note that Lx is unknown and to be estimated. From Eqn. (9), and considering that φ(x, u) is smooth about its arguments, we have for all u ∈custom-characterm











ϕ


(


x
1

,
u

)


-

ϕ


(


x
2

,
u

)














ϕ


(

x
,
u

)





x






×




x
1

-

x
2















ϕ


(


φ


(
ζ
)


,
u

)





ζ






ζ



x







×




x
1

-

x
2














ϕ


(


φ


(
ζ
)


,
u

)





ζ






×






ζ



x






×




x
1

-

x
2








κ
1








ζ



x






×




x
1

-

x
2






,






x

,

ζ



n


,




where







0
<







ϕ


(


φ


(
ζ
)


,
u

)





ζ








κ
1


,




and







ϕ


(


φ


(
ζ
)


,
u

)


=






φ


(
ζ
)





ζ




(


f


(
ζ
)


+


g


(
ζ
)



u


)


-

A







φ


(
ζ
)


.







Because









ϕ


(


φ


(
ζ
)


,
u

)





ζ





is known, the upper bound of its infinity norm κ1 can be established. To derive the upper bound of












ζ



x






,




we take into account the fact that for a non-singular matrix M, its infinity norm (maximum absolute eigenvalue) is equal to the inverse of the minimum absolute eigenvalue of M−1,







max




eig


(
M
)





=




M




=


1

min




eig


(

M

-
1


)






.






The above equation produces an upper bound of











ζ



x









as







κ
2

=


1
/
min






eig


(



x



ζ


)




.






Therefore, we establish κ1κ2 as the upper bound of the Lipschitz constant Lx.


Motor Drives: High Gain Estimator Design in New Coordinates


Given the observer (7) for the kth subsystem and an estimated upper bound of the Lipschitz constant φ(x, u), an observer can be designed for each subsystem. For the induction motor case, we take λ1=3, λ2=2, p=2, and have design parameters







θ
>
0

,


δ
1

=
1

,


δ
2

=
1










Δ
1



(
θ
)


=

diag


{

1
,

1
θ

,

1

θ
2



}



,



Δ
1



(
θ
)


=

diag


{

1
,

1
θ


}












S
1

-
1




C
1
T


=


(

3
,
3
,
1

)

T


,



S
2

-
1




C
2
T


=



(

2
,
1

)

T

.






Note that θ is a tuning parameter of the observer. Substituting the above design parameters into the kth subsystem for k={1, 2}, we can obtain observer in x-coordinates as follows






{circumflex over ({dot over (x)})}
1
=A
1
{circumflex over (x)}
1+{circumflex over (ω)}1+G1C1{tilde over (x)}1






{circumflex over ({dot over (x)})}
2
=A
2
{circumflex over (x)}
2+{circumflex over (ω)}2+G2C2{tilde over (x)}2,





ŷ1=C1{circumflex over (x)}1





ŷ2=C2{circumflex over (x)}2,   (10)


where






G
1δ1Δ1−1(θ)S1−1C1T=[3θ 3θ2 θ3]T






G
2δ2Δ2−1(θ)S2−1C2T=[2θ θ2]T.


In practice, a less rigorous approach to design the high gain observer in new coordinates can select a sufficiently large θ, which balances performance and sensitivity to noises.


Dynamic Gain Estimator Design in Original Coordinates


One can estimate the state x using the observer designed in x-coordinates. In practice, it is more natural to have the original state estimate {circumflex over (ζ)}. For many cases, given the estimator in new coordinates, it is not easy to derive the corresponding estimator in the original coordinates.



FIGS. 6A and 6B show two methods useful for deriving an implementable dynamic gain estimator in the original coordinates based on the estimator design in the new coordinates. FIGS. 6A and 6B mainly addresses the issues during dynamic gain estimator design when ζ=φ−1(x) is unsolvable.



FIG. 6A shows the method using a point-wise matrix inversion approximation 602, and FIG. 6B shows the method using a functional matrix inversion approximation 603. Block 601 determines a Jacobian matrix of the state transformation in closed form.


As shown in FIG. 6A, block 601 determines a Jacobian matrix of the state transformation in closed form,









Q
o



(
ζ
)


=



x



ζ



,




and then takes the output (estimated state in the original coordinates) of the dynamic gain estimator 401, finally evaluate the numerical value of the Jacobian matrix point-wisely at the estimated state, i.e.,






Q
o(ζ)|ζ={circumflex over (ζ)}=Qo({circumflex over (ζ)})


with {circumflex over (ζ)}=(îds, îqs, {circumflex over (Φ)}qr, {circumflex over (Φ)}qr, {circumflex over (ω)}). We therefore have a point-wise matrix Qo({circumflex over (ζ)}).


It is likely the matrix Qo({circumflex over (ζ)}) is singular or close to singular, i.e., ill-conditionedness. Both facts lead to divergence of state estimation. Block 602 addresses the issues raising from the ill-conditionedness of Qo({circumflex over (ζ)}), and determines an approximate inverse of the point-wise matrix Qo({circumflex over (ζ)}) by replacing the ill-conditioned matrix Qo({circumflex over (ζ)}) with its non-singular and well-conditioned approximation. The dynamic gain estimator 401 is implemented based on the high gain estimator in the new coordinates and the approximate inverse of the point-wise matrix Qo({circumflex over (ζ)}).



FIG. 6B shows an alternative implementation of the dynamic gain estimator 401. The output of the Jacobian matrix of state transformation 601 is a matrix Qo, where each element is a function of ζ. Instead of evaluating the numerical value of Qo at ζ={circumflex over (ζ)}. Block 603 first tries to approximate the function matrix Qo by an approximate function matrix {circumflex over (Q)}o(ζ) then evaluates the numerical value of the approximate function matrix {circumflex over (Q)}o at ζ={circumflex over (ζ)} point-wisely, and determine the inverse of {circumflex over (Q)}o({circumflex over (ζ)}) point-wisely, which is further used by block 401 to implement a dynamic gain estimator.


Case When ζ=φ−1(x) is Solvable


Two approaches can be used to construct {circumflex over (ζ)}. The first solves for {circumflex over (ζ)} from {circumflex over (x)} based on the closed form expression of the inverse transformation ζ=φ−1(x). That is {circumflex over (ζ)}=φ−1({circumflex over (x)}). The second implements the observer (7) in ζ-coordinates as follows












ζ
^

.

=


f


(

ζ
^

)


+

g


(


ζ
^

,
u

)


+




ζ



x



Θ







Δ

-
1




(
θ
)




S

-
1





C
T



(

y
-

y
^


)





,






y
^

=

h


(

ζ
^

)



,




(
11
)







where





Θ=diag{θδ1, . . . , θδp}





Δ−1=diag{Δ1−1(θ), . . . , Δp−1(θ)}






S
−1=diag{S1−1, . . . , Sp−1}.


Notice that Eqn. (11) includes the term









ζ



x


,




which assumes the closed form formula of the inverse transformation ζ=φ−1(x), and thus may not be implementable with an explicit expression of ζ=φ−1(x).


Case When ζ=φ−1(x) is Unsolvable


With the expression of φ(x, u) unknown, the observer (7) cannot be realized unless φ is represented as a function of φ(ζ), u). Consequently, the following implementable x-observer can be obtained






{circumflex over ({dot over (x)})}
k
=A
k
{circumflex over (x)}
kk(φ({circumflex over (ζ)}), u)+θδkΔk−1(θ)Sk−1CkTCk{tilde over (x)}k,





ŷ=Ck{circumflex over (x)}k,   (12)


where φk(φ({circumflex over (ζ)}), u) are the rows corresponding to the kth subsystem in φ(φ({circumflex over (ζ)}), u) given by







ϕ


(


φ


(

ζ
^

)


,
u

)


=






φ


(

ζ
^

)






ζ
^





(


f


(

ζ
^

)


+


g


(

ζ
^

)



u


)


-

A






φ


(

ζ
^

)








and {circumflex over (ζ)} is numerically solved from the following n nonlinear algebraic equations






{circumflex over (x)}=φ({circumflex over (ζ)}).   (13)


As a result, the observer (12) is implemented as (13) and












x
^

.

=






φ


(


ζ
^

,
u

)






ζ
^





(


f


(

ζ
^

)


+


g


(

ζ
^

)



u


)


+

Θ







Δ

-
1




(
θ
)




S

-
1




C
T


C


x
~











y
^

=

C







x
^

.







(
14
)







Alternatively, considering the state transformation φ(ζ) is a local diffeomorphism, and thus its Jacobian








x



ζ





is non-singular. One can therefore implement the observer (11) as follows












ζ
^

.

=


f


(

ζ
^

)


+

g


(


ζ
^

,
u

)


+



(



x



ζ


)


-
1



Θ







Δ

-
1




(
θ
)




S

-
1





C
T



(

y
-

y
^


)





,






y
^

=


h


(

ζ
^

)


.






(
15
)







Note that Eqn. (15) is different from Eqn. (11) where the Jacobian of the inverse state transformation








ζ



x





is used.


Motor Drives: High Gain Estimator Design in Original Coordinates


Two approaches can be used to estimate ζ on the basis of Eqn. (10). The estimated state {circumflex over (ζ)} can be constructed by implementing the observer in ζ-coordinates, i.e., as in Eqn. (15).


Point-Wise Matrix Inverse Approximation


To shorten the notation, we use







Q
o

=





x
^





ζ
^



.





Implementation of the observer in Eqn. (15) requires one to solve the inverse of Qo in realtime, more accurately, to solve the observer gain Gζ in ζ-coordinates from the following linear system





Gx=QoGζ,   (16)


where Gx=ΘΔ−1(θ)S−1CT. Numerical instability could be serious when Qo is ill-conditioned, and we cannot easily rely on the solutions coining out of an ill-conditioned Qo, for instance the least square solution






G
ζ=(QoTQo)−1QoTGx


becomes useless. Let cond(Qo)=|Qo|28 |Qo−1|28 be the condition number of Qo. One can expect a loss of roughly log10(cond(Qo)) decimal places in the accuracy of the solutions.


Next, we describe techniques to remedy the aforementioned numerical instability.



FIGS. 7A and 7B show embodiments of point-wise matrix inverse approximation 602. In both cases, the input 700 is the numeral value of Jacobian matrix of the state transformation Qo 700. As shown in FIG. 7A, the point-wise numerical matrix Qo({circumflex over (ζ)}) is preconditioned by several techniques as below to produce a pre-conditioned Qo({circumflex over (ζ)}) 701, and then determine 702 the inverse of the preconditioned matrix 701.


Preconditioning


A number of method are known for obtaining a good approximate inverse of an ill-conditioned Qo using techniques such as pre-conditioning, scaling, etc. An intuitive pre-conditioning, also called the Tikhonov regularization, uses a positive constant h into (16) and tries to solve






G
ζ=(QoTQo+hI)−1QoTGx.


By using h, the Tikhonov regularization reduces the condition number of QoTQo and results in an improvement of the solution accuracy. Alternatively, one can regularize the problem by adding extra information, for instance the smoothness of Gζ. The basic idea is that the correct solution among all “near” solutions is characterized by requiring a “smoothness” of some function, curve or surface constructed from Gζ at a fixed time instant.


Dynamic Gain


When a smooth function of ζ(t) is continuous over time, Gζ is continuous over time as well. However, this contradicts the fact that an ill-conditioned Qo typically results in discontinuity of Gζ over time. Therefore, during implementation, one can force that Gζ is be continuous over time.


As shown in FIG. 7B, the inverse of the point-wise numerical matrix Qo({circumflex over (ζ)}) is first determined in 703, and then the the inverse matrix is fed into a matrix smoothing block 704 to smooth the matrix, such that effects of instantaneous ill-conditionedness of Qo({circumflex over (ζ)}) are attenuated by previous values.


One embodiment of the matrix smoothing mechanism can be








G
ζ



(
k
)


=

(






solved





from






(
16
)


,





if





cond






(

Q
o

)



c








G
ζ



(

k
-
1

)


,



otherwise



,






where k is the time step, and c is a positive constant. Another embodiment of the matrix smoothing mechanism uses a low pass filter.


Functional Matrix Inverse Approximation Qo


The above described preconditioning methods concentrate on Eqn. (16), and try to resolve the ill-conditionedness of the numerical matrix Qo at a fixed time instant (point-wisely). As shown in FIG. 6B, one can also take an approach from a systematic perspective, where Qo is treated as a function of ζ instead. The idea is to replace Qo in Eqn. (16) with an approximate matrix {circumflex over (Q)}o. Both Qo and {circumflex over (Q)}o are functions of ζ. Block 603 solve the problem finding {circumflex over (Q)}o that can be explicitly written as follows, for all ζ,











min




Q
^

o



(
ζ
)



Q








Q
o



(
ζ
)


-



Q
^

o



(
ζ
)














subject





to






cond


(



Q
^

o



(
ζ
)


)



<
c

,





(
17
)







where Q is a functional space, and |Qo−{circumflex over (Q)}o| is certain norm representing the distance between Qo and {circumflex over (Q)}o. The problem in Eqn. (17) is of infinite dimensions and very difficult to solve. Instead, approximation of Qo is more often accomplished intuitively.



FIGS. 8A and 8B show embodiments of functional matrix inversion approximation 603. As shown in FIG. 8A, the Jacobian matrix Qo(ζ) 700, which is a multi-variable smooth function matrix, can be approximated to arbitrary accuracy by Tylor series expansion, which is infinite dimensional and not suitable for implementation. By truncating the Taylor series expansion of Qo(ζ) to certain order in, one can obtain a low order polynomial series approximation of Qo(ζ) 801, which is not ill-conditioned. Evaluating 802 the value of low order polynomial series approximation at ζ={circumflex over (ζ)} 802, and determining 803 its inverse enables the implementation of dynamic gain estimator 401.



FIG. 8B shows another embodiment, which eliminates from Qo certain components which causes ill-conditionedness of Qo(ζ). For the speed sensorless motor drive case, the ill-conditioned matrix Qo incurs large fluctuations of the speed estimate.


An embodiment of the function approximation idea solves (17) by exploiting the structure of Qo. Notice that in the fixed frame, the matrix Qo is periodically time-varying, and thus makes the numerical stability issue more complicated.


Hence, we first rewrite the system (1) in a frame rotating at ω1 so that at a steady state, ids, iqs, Φdr, Φqr are constants. Then, we remove 804 some components in Qo to get {circumflex over (Q)}o and avoid ill-conditionednesstrim Qo, which is suitable for realtime implementation and give reasonable state estimation performance. For illustration purpose, we express







Q
o

=


[



1


0


0


0


0




0



ω
1




α





β




β






ω
^





β







Φ
^

qr






0


1


0


0


0





-

ω
1




0




-
β







ω
^





α





β





-
β








Φ
^

dr











*


*


*


*



]

.





Notice that the elements in the last row of matrix Qo are large numbers, and cause the ill-conditionedness. Also, the last row uses large feedback gains in the ĩds and ĩds-dynamics, and thus make the entire error dynamics sensitive to measurement noises. Therefore, we approximate matrix {circumflex over (Q)}o by letting the first four elements of the last row in Qo be zero. We implement the observer (15) with










x
^





ζ
^



,




equivalently Qo, replaced by








Q
^

o

=


[



1


0


0


0


0




0



ω
1




α





β




β






ω
^





β







Φ
^

qr






0


1


0


0


0





-

ω
1




0




-
β







ω
^





α





β





-
β








Φ
^

dr











0



0


0


0


*



]

.





Although the invention has been described by way of examples of preferred embodiments, it is to be understood that various other adaptations and modifications can be made within the spirit and scope of the invention. Therefore, it is the object of the appended claims to cover all such variations and modifications as come within the true spirit and scope of the invention.

Claims
  • 1. A method for controlling an angular speed of a rotor of an induction motor without an encoder for rotor position and speed sensing, comprising steps of: sensing stator currents and voltages of the induction motor;designing a dynamic gain estimator by applying a state transformation to a model of the induction motor;estimating a state of the induction motor by applying the dynamic gain estimator to the currents and the voltages, andusing the state to control the angular speed of the rotor of the induction motor.
  • 2. The method of claim 1, wherein the designing further comprises: applying the state transformation to the model in the original coordinates defined by (ids, iqs, Φdr, Φqr, ω)T to produce a transformed induction motor model in a non-triangular observable form, wherein ids represents the currents , iqs, represents the voltages, Φdr and Φqr respectively represent rotor fluxes d- and q-axis, ω represents a rotor angular speed, and T is a transpose operator;determining the high gain estimator in new state coordinates defined by the state transformation, based on the transformed induction motor model; anddetermining an approximation of an inverse of a Jacobian matrix of the state transformation.
  • 3. The method of claim 2, wherein the model is transformed to the non-triangular observable form by the state transformation with observability indices (λ1=3, λ2=2) x=(h1, Lfh1, Lf2h1, h2, Lfh2)T
  • 4. The method of claim 1, where the dynamic gain estimator consists of nonlinear differential equations represented in the original state coordinates, and performs estimating by integrating the nonlinear differential equations over time.
  • 5. The method of claim 2, wherein the designing further comprises: deriving an upper bound of a Lipschitz constant of a nonlinear vector field φ in the transformed induction motor model;selecting a tuning parameter θ according to the upper bound; anddetermining parameters in the high gain estimator according to θ and the state transformation.
  • 6. The method of claim 5, wherein the upper bound is based on determining a maximum eigenvalue of a Jacobian matrix of the state transformation, or selecting a sufficiently large positive number.
  • 7. The method of claim 5, wherein the tuning parameter θ is selected to be a sufficiently large positive number to ensure convergent state estimation.
  • 8. The method of claim 2, where the determination of the approximation of the inverse of the Jacobian matrix of the state transformation comprises: evaluating the Jacobian matrix at an estimated state point-wisely; anddetermining the approximate inverse of the evaluated Jacobian matrix.
  • 9. The method of claim 8, where the determining of the approximation inverse of the Jacobian matrix is based on applying pre-conditioning techniques to obtain a pre-conditioned Jacobian matrix, and the approximate inverse is obtained by determining the inverse of the pre-conditioned Jacobian matrix.
  • 10. The method of claim 8, where the determining of the approximation inverse of the Jacobian matrix is based on first determining an pseudo-inverse of the Jacobian matrix point-wisely, and then smoothing the pseudo-inverse with a low pass filter.
  • 11. The method of claim 2, where the determination of the approximation of the inverse of the Jacobian matrix of the state transformation comprises: determining an approximate function matrix of the Jacobian matrix;evaluating the approximate function matrix at an estimated state point-wisely; anddetermining the approximate inverse of the evaluated Jacobian matrix by inverting the approximated function matrix point-wisely.
  • 12. The method of claim 11, where the determination of the approximate function matrix comprises: representing the Jacobian matrix as a polynomial series expansion; and determining a low order polynomial series approximation of the Jacobian matrix by truncating high order terms in the polynomial series expansion.
  • 13. The method of claim 11, where the determination of the approximate function matrix comprises: performing structural analysis of the Jacobian matrix to identify elements causing ill-conditionedness of the Jacobian matrix; andobtaining an approximate Jacobian matrix by removing the elements.
  • 14. The method of claim 1, wherein the designing further comprises: applying the state transformation to the model in the original coordinates defined by (ids, iqs, Φdr, Φqr, ω)T to produce a transformed induction motor model in a non-triangular observable form, wherein ids represents the currents , iqs, represents the voltages, Φdr and Φqr respectively represent rotor fluxes d- and q-axis, ω represents a rotor angular speed, and T is a transpose operator;determining the high gain estimator in new state coordinates defined by the state transformation, based on the transformed induction motor model; andchoosing the high gain estimator in new state coordinates and a set of nonlinear algebraic equations derived from the state transformation as the dynamic gain estimator.
  • 15. The method of claim 14, wherein the dynamic gain estimator consists of another set of nonlinear differential equations representing the high gain estimator in the new state coordinates, and a set of nonlinear algebraic equations defined by the state transformation.
  • 16. The method of claim 15, where the dynamic gain estimator produces an estimated state defined by the state transformation by integrating the nonlinear differential equations defining the high gain estimator; and estimating the original state coordinates by numerically and iteraively solving the set of nonlinear algebraic equations.
  • 17. A system for controlling an angular speed of a rotor of an induction motor without an encoder for rotor position and speed sensing, comprising: a sensor configured to sense stator currents and voltages of the induction motor; anda processor configured to design a dynamic gain estimator by applying a state transformation to a model of the induction motor, to estimate estimating a state of the induction motor by applying the dynamic gain estimator to the currents and the voltages, and to using the state to control the angular speed of the rotor of the induction motor.