METHOD AND DEVICE FOR CONTROLLING THREE-PHASE MOTOR

Information

  • Patent Application
  • 20240014757
  • Publication Number
    20240014757
  • Date Filed
    October 01, 2021
    3 years ago
  • Date Published
    January 11, 2024
    a year ago
Abstract
The present invention concerns a method and a device for controlling a three-phase motor using a field oriented control system. The invention: —estimates, in a dq plane incremental inductances (I) and (II) of the motor, —determines an incremental saliency (III) of the motor as a ratio between the incremental inductance (I) and the incremental inductance (II), —estimates a first current id* from the estimated incremental saliency (III) and a reference incremental saliency ISR*, —estimates the rotor speed value (IV) of the motor, —estimates a second current iq* from a reference rotor speed value ω*, and the estimated rotor speed value (IV), —controls the voltage applied to the motor according to the first and second estimated currents.
Description
TECHNICAL FIELD

The present invention relates generally to a device and a method for controlling a three-phase motor.


BACKGROUND ART

Mechanical sensor less control is used in electric motor applications for which rotor position feedback is needed, and when rotary encoder is not a viable solution, e.g. in low-cost and/or dusty environment. It basically consists in estimating the rotor angular position by manipulation of available electrical quantities (motor phase or line voltages and currents).


Several algorithms have been proposed in literature to address this problem. A first class of algorithms are based on observation at a sufficient speed of differences in Back Electromotive Force (BEMF) produced in d and q axes. The BEMF may differ due to presence of permanent magnets and/or due to different inductances in d and q axes (in salient pole machines).


At low speeds or standstill, BEMF tends to hide behind the measurement background noise. Therefore, other methods must be used such as dI/dt based methods. For salient pole machines, difference in incremental inductances of d and q axes enables to estimate the position of the machine from comparison of applied voltage steps and current derivatives. Also for these methods, the measurement background noise limits the detection ability to cases with sufficiently high current ripple. At standstill, voltage pulses get very narrow and hard to assert with high precision, e.g. due to switching transients, and current ripple also tends to hide below the measurement noise. High-frequency, high resolution analog-to-digital converters (ADC) are needed for measurements.


High frequency voltage injection can be used to produce arbitrary current ripple shapes and increase the signal-to-noise ratio for the estimation. The paper of M. Laumann, C Weiner, and R. Kennel entitled “Arbitrary injection based sensorless control with a defined high frequency current ripple and reduced current and sound level harmonics,” published in SLED 2017, discloses a method that enables the determination of machine position by injecting high frequency voltage for any injected voltage shape. In practice, high frequency injection is producing audible noise, and deserves special care for either rejecting the produced acoustic noise away from audible frequency band or for reducing/spreading the levels of produced hatinonics resulting from injection.


Most methods rely on availability of inductances or differential inductance values, building look up tables (LUT), prior to the estimation. This is not so easy to implement in practice with great accuracy, as inductances significantly vary with currents (saturation and/or cross saturation) and temperature profile of the core. Furthermore, the estimation of inductances in the torque producing regions typically requires some specific instrumentation (locked rotor tests, or rotational tests with test load and rotary encoder) to avoid uncontrolled (and potentially dangerous) operation of the machine. Last, two identical motors may have slightly different inductance maps due to manufacturing tolerances.


Besides estimation of position, sensorless control must also implement the MTPA (maximum torque per Ampere) law, that decides the current vector reference for a given reference torque. Numerous vector references could reach the desired torque, but only one current vector can minimise the amplitude of the current flowing in the machine for the corresponding torque. Because the torque is a combined function of current and flux linkage waveforms, a good estimation of inductances is required to achieve an effective MTPA control.


It is especially difficult to estimate the cross-saturation, that reflects the change of inductance of one saliency axis with the level of current in the other saliency axis. The lack of information on cross-saturation typically causes an erroneous estimation of the position in sensorless control. This error fools the MTPA function and can cause instability in the control.


SUMMARY OF INVENTION

The present invention aims to provide a method and a device for determining a precise rotor position without requiring any inductance value knowledge.


To that end, the present invention concerns a method for controlling a three-phase motor using a field oriented control system, characterized in that the method comprises the steps of:

    • estimating, in a dq plane the incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} of the motor,
    • determining an incremental saliency custom-character of the motor as a ratio between the incremental inductance {circumflex over (l)}{circumflex over (d)} and the incremental inductance {circumflex over (l)}{circumflex over (q)},
    • estimating a first current id* from the estimated incremental saliency and a reference incremental saliency ISR*,
    • estimating the rotor speed value {circumflex over (ω)} of the motor,
    • estimating a second current iq* from a reference rotor speed value ω*, and the estimated rotor speed value {circumflex over (ω)},
    • controlling the voltage applied to the motor according to the first and second estimated currents.


The present invention concerns also a device for controlling a three-phase motor using a field oriented control system, characterized in that the device comprises:

    • means for estimating in a dq plane the incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} of the motor,
    • means for determining an incremental saliency custom-character of the motor as a ratio between the incremental inductance {circumflex over (l)}{circumflex over (d)} and the incremental inductance {circumflex over (l)}{circumflex over (q)},
    • means for estimating a first current id* from the estimated incremental saliency and a reference incremental saliency ISR*,
    • means for estimating the rotor speed value Co of the motor,
    • means for estimating a second current iq* from a reference rotor speed value ω*, and the estimated rotor speed value {circumflex over (ω)},
    • means for controlling the voltage applied to the motor according to the first and second estimated currents.


Thus, the present invention always exhibits sufficient saliency in order to estimate the rotor position. Under high torque/current, in presence of heavy saturation, a sufficient saliency is maintained. As a result, sensorless control keeps controllability and doesn't diverge.


According to a particular feature, the first and second estimated currents are estimated as:


id*=Kp,ISR(ISR*−custom-character)+Ki,ISR∫(ISR*−custom-character)dt where Kp,ISR and Ki,ISR are constants of a first proportional integral module.








i
q
*

=


T
*



i

d
*




K
L




,




where T* is the torque of the motor and






T*=K
p,ω(ω*−{circumflex over (ω)})+Ki,ω∫(ω*−{circumflex over (ω)})dt

    • where Kp,ω and Ki,ω are constants of a second proportional integral module, and KL is a gain dependent on the inductances of the machine.


Thus, the machine always exhibit sufficient saliency to enable estimation of rotor position. Under high torque/current, in presence of heavy saturation, sufficient saliency will be maintained and the method will not loose control. Robustness is improved as well in presence of cross-saturation, where the position error due to cross-saturation can be limited in the high saliency regions. The present invention can easily provide current references for robust control schemes, such as field oriented control, or model predicted control. The method can implement speed control, especially at low speeds.


According to a particular feature, the method further comprises the step of estimating a position error of the rotor of the motor and the estimated rotor speed value {circumflex over (ω)} is estimated using a phase lock loop having as input signal the estimated position error.


Thus, the present invention can implement speed control of the machine without position sensor, including at low speeds. The estimated position error is also directly usable for precise position control.


According to a particular feature, the voltage applied to the motor is a voltage vector and consecutive voltage vectors are applied successively during successive periods of time, the estimated incremental inductances are estimated from a stator flux linkage of the motor on d or q axis and a steady state position error ε.


Thus, the position estimation error can get minimised using model predicted control.


According to a particular feature, the estimated incremental inductance {circumflex over (l)}{circumflex over (d)} and the estimated incremental inductance {circumflex over (l)}{circumflex over (q)} are defined as:








l



d
ˆ


=



Δ


λ

d
ˆ

k


Δ


λ

q
ˆ


k
-
1



-

Δ


λ

q
ˆ

k


Δ


λ

d
ˆ


k
-
1






Δ


J

d
ˆ

k


Δ


λ

q
ˆ


k
-
1



-

Δ


l

q
ˆ

k


Δ


λ

d
ˆ


k
-
1













l
ˆ


q
ˆ


=



Δ


λ

q
ˆ

k


Δ


λ
d

k
-
1



-

Δ


λ

d
ˆ


k
¯



Δ


λ
q

k
-
1






Δ


J

q
ˆ

k


Δ


λ

d
ˆ


k
-
1



-

Δ


l

d
ˆ

k


Δ


λ

q
ˆ


k
-
1












ε
ˆ

=





l
ˆ


d
ˆ





l
ˆ


q
ˆ






l
ˆ


d
ˆ


-


l
ˆ


q
ˆ









Δλ

d
ˆ

k


Δ


λ

q
ˆ


k
-
1



-

Δ


λ

q
ˆ

k


Δ


λ

d
ˆ


k
-
1







Δl
d
k


Δ


λ
q
k


-

Δ


l
q
k


Δ


λ
d
k











    • where k denotes the discrete domain representation of the kth sampling instant, Δ symbolizes Δxk=xk−Xk−1, Vdq,k, λdq is the stator flux linkage on d or q axis.





Thus, provided that the signal-to-noise ratio is sufficient, the sensorless control method can estimate online in real-time the position and the inductances of the machine without any associated lookup table and without any position sensor. The sensorless control method can operate any time on any kind of machine, and for any saturation or temperature conditions.


According to a particular feature, the consecutive voltage vectors are defined as:





ν{circumflex over (d)}*=i{circumflex over (d)}kRs+{circumflex over (l)}{circumflex over (d)}(id*−{circumflex over (l)}{circumflex over (d)}k+1)/Ts





ν{circumflex over (q)}*=i{circumflex over (q)}kRs+{circumflex over (l)}{circumflex over (q)}(iq*−{circumflex over (l)}{circumflex over (q)}k+1)/Ts


According to a particular feature, the method further comprises the step of injecting voltage signals that are equal to νdh*cos(ωdht) and νqh*cos(ωqht), where ωdh and ωqh are the injection frequencies on axis d and q respectively, νdh* and νqh* are the amplitude of the injected voltage in axis d and q respectively, the incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} of the motor are estimated as:








l
ˆ


d
ˆ


=


v

d

h

*



i

d

h




ω

d

h













l
ˆ


q
ˆ


=


v

q

h

*



i

q

h




ω

q

h










    • where idh is the high frequency current component on d axis, iqh is the high frequency current component on q axis, idh, iqh are obtained by a heterodyne demodulation,

    • and the estimated position error is:










ε
ˆ

=





l
ˆ


d
ˆ





l
ˆ


q
ˆ






l
ˆ


d
ˆ


-


l
ˆ


q
ˆ








i

q

h




ω

d

h




v

d

h

*







Thus, the sensorless control method can estimate online in real-time the position and the inductances of the machine without any lookup table associated with it, and without any position sensor. The sensorless control method can operate any time on any kind of machine, and for any saturation or temperature conditions. The signal-to-noise ratio is maintained high in presence of injected signal.


According to a particular feature, the method further comprises the step of injecting voltage signals that are equal to νdh*cos(ωdht) with a frequency of ωdh on the d axis and a squarewave injection on the q axis of period Ts and amplitude νq and incremental inductances are:








l
ˆ


d
ˆ


=


v

d

h

*



i

d

h




ω

d

h












l
ˆ


q
ˆ


=

L

P


F

(



v
q

k
-
1




T
s



Δ


i
q
k



)








    • where LPF denotes a low pass filter, k denotes the discrete domain representation of the kth sampling instant, Δ symbolizes Δxk=xk−xk−1

    • and the estimated position error is:










ε
ˆ

=





l
ˆ


d
ˆ





l
ˆ


q
ˆ






l
ˆ


d
ˆ





l
ˆ


q
ˆ








i

q

h




ω

d

h




v

d

h

*







Thus, the injection frequency on the q axis can be closer to the switching frequency and the flux span becomes smaller, reducing the acoustic noise generated by the high frequency injection.


According to a particular feature, the voltage applied to the motor is determined as:





ν{circumflex over (d)}**=νdh*cos(ωdht)+ν{circumflex over (d)}*





ν{circumflex over (q)}**=νqh*cos(ωqht)+ν{circumflex over (q)}*





where:





ν{circumflex over (d)}*=Kp,Id(Id*−I{circumflex over (d)})+Ki,Id∫(Id*−I{circumflex over (d)})dt





ν{circumflex over (q)}*=Kp,Iq(Iq*−I{circumflex over (q)})+Ki,Iq∫(Iq*−I{circumflex over (q)})dt

    • where Kp,Id is the proportional gain of a third proportional integral regulator, Ki,Id is the integral gain for the d axis of the third proportional integral regulator, Kp,Iq is the proportional gain of a fourth proportional integral regulator and Ki,Iq is the integral gain for the q axis of the fourth proportional integral regulator.


Thus, the present invention implements field oriented control on current references determined according to the invention. The method is effective in keeping the desired saliency ratio and thus keeps good controllability.


According to a particular feature, the method further comprises the step of injecting a current i*dh cos(ωht) on the current reference of the d axis and the incremental inductances are equal to:






=



Δ


λ

q
^

k


Δ


λ
d

k
-
1



-

Δ


λ

d
^

k


Δ


λ
q

k
-
1






Δ


I

q
^

k


Δ


λ

d
^


k
-
1



-

Δ


I

d
^

k


Δ


λ

q
^


k
-
1











=



i
dh
*



ω
h









    • where k denotes the discrete domain representation of the kth sampling instant, Δ symbolizes Δxk=xk−xk−1, νdq,k, λdq is the stator flux linkage on d or q axis and custom-character is the high frequency amplitude of voltage injected on the d axis.





Thus, inductance on axis d can get estimated even for high saliency machine, where inductance on d axis is so high that the current response would otherwise be too small.


According to a particular feature, the voltage applied to the motor is determined from:





ν{circumflex over (d)}*=i{circumflex over (d)}kRs+{circumflex over (l)}{circumflex over (d)}(id*−{circumflex over (l)}{circumflex over (d)}k+1)/Ts





ν{circumflex over (q)}*=i{circumflex over (q)}kRs+{circumflex over (l)}{circumflex over (q)}(iq*−{circumflex over (l)}{circumflex over (q)}k+1)/Ts


Where Rs is the stator resistance of the motor and Ts is the sampling time.


Thus, the estimation of inductances can be determined in control conditions using at least two dissimilar consecutive voltage vectors. This is as example applicable to the control of machine voltage using voltage switched inverters, where dissimilar voltage vectors are applied to the machine terminal according to different inverter state conditions. This includes deadbeat controllers such as FCS-MPC.


The characteristics of the invention will emerge more clearly from a reading of the following description of example embodiments, the said description being produced with reference to the accompanying drawings.





BRIEF DESCRIPTION OF DRAWINGS


FIG. 1 represents a first example of a Field-Oriented Control system in which the present invention is implemented.



FIG. 2 represents a second example of a Field-Oriented Control system in which the present invention is implemented.



FIG. 3 represents a third example of a Field-Oriented Control system in which the present invention is implemented.



FIG. 4 represents an incremental saliency ratio control module which is implemented in the first, second and third examples of the Field-Oriented Control system.



FIG. 5 represents an architecture of an estimation module that controls a motor.



FIG. 6 represents an example of an algorithm for controlling a motor.





DESCRIPTION OF EMBODIMENTS


FIG. 1 represents a first example of a Field-Oriented Control system in which the present invention is implemented.


Field-Oriented Control (FOC) is a variable-frequency drive control method in which the stator currents of a three-phase AC electric motor are identified as two orthogonal components that can be visualized with a vector iaq. In the αβ reference frame representative of the stator, the vector rotates around the origin in synchronism with the rotor. In the dq reference frame representative of the rotor, the vector, at steady-state, is stabilised around the reference current levels idq* using (PI) controllers. The current reference can be as example determined from torque reference, which can itself be determined from a speed controller, depending on the application.


FOC is used to control AC synchronous and induction motors.


It was originally developed for high-performance motor applications that are required to operate smoothly over a variable speed range, generate full torque at zero speed, and have high dynamic performance including fast acceleration and deceleration.


Field-Oriented Control system, in the example of FIG. 1 is more precisely a dual signal injection current vector control.


In FIG. 1, the system comprises an incremental saliency ratio (ISR) module 100.


The incremental saliency ratio module 100 receives a reference rotor speed value ω*, an estimated rotor speed value {circumflex over (ω)}, an incremental saliency ratio reference ISR* and an estimated incremental saliency ratio






=



l
^


d
^




l
^


q
^







{circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} are estimated incremental inductances in the estimated dq frame provided by an inductance computation module 108.


The incremental saliency ratio module 100 will be disclosed more precisely in FIG. 4.


The output of the incremental saliency ratio module 100 provides a reference current idq* to a subtracting module 101 that subtracts a measured current custom-character to the reference current idq*.


The output of the subtracting module 101 is provided to a current controller 102, which provides voltage references νdq* through two proportional integral current PI regulators. The PI regulators are tuned with the estimated inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)}.


The output of the current controller 102 is provided to an adding module 104 that adds the controlled current injection signal to a dual injection signal.


The output of the current controller 102 is defined as:





ν{circumflex over (d)}*=Kp,Id(Id*−I{circumflex over (d)})+Ki,Id∫(Id*−I{circumflex over (d)})dt





ν{circumflex over (q)}*=Kp,Iq(Iq*−I{circumflex over (q)})+Ki,Iq∫(Iq*−I{circumflex over (q)})dt

    • where Kp,Id is the proportional gain of a third proportional integral regulator, Ki,Id is the integral gain for the d axis of the third proportional integral regulator, Kp,Iq is the proportional gain of a fourth proportional integral regulator and Ki,Iq is the integral gain for the q axis of the fourth proportional integral regulator.


The dual injection signal is provided by an injection signal module 103 and is equal to νdh*cos(ωdht) and νqh*cos(ωqht), where ωdh and ωqh are predetermined angular frequencies, νdh* and νqh* are the amplitude of the injected voltage in axis d and q respectively.


The angular frequency values of the dual injection signal is for example comprised between a fundamental frequency and the switching frequency. In a variant, the injection signals have different angular frequencies and different shapes. For example, the injection signal on one axis is a square wave signal having a first angular frequency between the fundamental frequency and the switching frequency and the injection signal on the other axis is a sinewave signal having a second angular frequency between the fundamental frequency and the switching frequency, but different from the first one and the two different frequencies do not share the same harmonic order for non intereference of one with another.


As other example, injection signals of both axes are sinewave signals with different angular frequency. The custom-character at the output of the summing module 104 is expressed as:





ν{circumflex over (d)}**=νdh*cos(ωdht)+ν{circumflex over (d)}*





ν{circumflex over (q)}**=νqh*cos(ωqht)+ν{circumflex over (q)}*


The output custom-character of the summing module 104 is provided to an inverse Park transform module 105 and to an inductance computation module 108. The output custom-character of the inverse Park transformation module 105 is provided to an inverter 106. The output voltages of the inverter 106 are connected to the stator of a motor, and the currents that are measured at the output of the inverter are connected to a Park transformation module 107. The Park transformation module 107 determines the measured current custom-character using an estimated rotor position value. The measured current custom-character is provided to the inductance computation module 108.


The inductance computation module 108 determines by heterodyne demodulation, an estimated error {circumflex over (ε)} and estimated incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} on the estimated dq frame as follows:







ε
^

=





l
^


d
^





l
^


q
^






l
^


d
^


-


l
^


q
^








i
qh



ω
dh



v
dh
*











l
^


d
^


=


v
dh
*



i
qh



ω
dh











l
^

q

=


v
qh
*



i
qh



ω
qh







In the case of a squarewave injection on the q and νdh*cos(ωqht) on the d axis








l
^


d
^


=


v
dh
*



i
qh



ω
dh











l
^


q
^


=

LPF

(



v
q

k
-
1




T
s



Δ


i
q
k



)







    • where LPF denotes a low pass filter, k denotes the discrete domain representation of the kth sampling instant, Δ symbolizes Δxk=xk−xk−1

    • and the estimated position error is:










ε
^

=





l
^


d
^





l
^


q
^






l
^


d
^


-


l
^


q
^









i
qh



ω
dh



v
dh
*


.






The estimated error {circumflex over (ε)} is provided to a phase lock loop module 109.


The phase lock loop module 109 determines the estimated rotor speed value {circumflex over (ω)} and an estimated rotor position {circumflex over (θ)} that is provided to the inverse Park transformation module 105 and the Park transformation module 107.



FIG. 2 represents a second example of a Field-Oriented Control system in which the present invention is implemented.


Field-Oriented Control system in the example of FIG. 2 is more precisely an injection less FCS-MPC (Finite-Control-Set Model Predictive Control) controller.


In FIG. 2, the system comprises an incremental saliency ratio (ISR) module 100.


The incremental saliency ratio module 100 receives a reference rotor speed value ω*, an estimated rotor speed value {circumflex over (ω)}, an incremental saliency ratio reference ISR* and an estimated incremental saliency ratio






=



l
^


d
^




l
^


q
^







where {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} are estimated incremental inductances in the estimated dq frame provided by an inductance computation module 208.


The incremental saliency ratio module 100 will be disclosed more precisely in FIG. 4.


The output of the incremental saliency ratio module 100 provides a reference current idq* to a MPC (Model Predictive Control) module 200. The module 200 is responsible for giving the ideal estimated voltage at the next inverter switching step (k+1), by means of a unit delay compensation module 202 and a deadbeat module 201.


The output of the MPC module 200 provides an estimated voltage custom-character to a minimum cost function module 203 that determines which voltage vector is the closest to the ideal voltage vector estimated in the module MPC 200 among seven vectors achievable with inverter 206.


The calculation of custom-character from the MPC module 200 is based on the estimation of the current and voltage at the next step. The estimation of the current is:







i

d
^


k
+
1


=


i

d
^

k

+



T
s

(


v

d
^

k

-


i

d
^




R
s



)



l
^


d
^











i

q
^


k
+
1


=


i
q
k

+



T
s

(


v

q
^

k

-


i

q
^




R
s



)



l
^


q
^








where Rs is the stator resistance of the motor and Ts is the sampling time, which is then used to calculate the voltage references custom-character:





ν{circumflex over (d)}*=i{circumflex over (d)}kRs+{circumflex over (l)}{circumflex over (d)}(id*−{circumflex over (l)}{circumflex over (d)}k+1)/Ts





ν{circumflex over (q)}*=i{circumflex over (q)}kRs+{circumflex over (l)}{circumflex over (q)}(iq*−{circumflex over (l)}{circumflex over (q)}k+1)/Ts


The output of the minimum cost function module 203 is provided to a Park transformation module 204 and to an inverter 206. The output voltages of the inverter 206 are connected to the stator of a motor M and measured currents at the output of the inverter are connected to a Park transformation module 205.


The Park transformation modules 204 and 205 determine in the estimated frame custom-character a voltage custom-character and current custom-character respectively, using an estimated rotor position {circumflex over (θ)}. Both voltage custom-character and current custom-character are then provided to the MPC module 200 and to the inductance computation module 208.


The inductance computation module 208 determines an estimated error {circumflex over (ε)} and estimated incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} on the estimated dq frame.


These estimates at low speeds are built from flux spans custom-character observed between k−1th to and kth steps:






custom-characterdq,k−1Ts,custom-characterdq,kTs

    • where k denotes the discrete domain representation of the kth sampling instant, Δ symbolizes Δxk=xk−xk−1, νdq,k, λdq is the stator flux linkage on d or q axis





[custom-charactercustom-character]=l{tilde over (θ)}[custom-charactercustom-character]

    • where l{tilde over (θ)} is the incremental inductance matrix and {tilde over (θ)} is the steady state position error.







l

θ
~


=

[





l
Σ

+


l
Δ



cos

(

2


θ
~


)







l
Δ



sin

(

2


θ
~


)








l
Δ


sin


(

2


θ
~


)






l
Σ

-


l
Δ



cos

(

2


θ
~


)






]








l

θ
~


-
1


=


[





l
Σ

+


l
Δ



cos

(

2


θ
~


)







-

l
Δ




sin

(

2


θ
~


)








-

l
Δ




sin

(

2


θ
~


)






l
Σ

-


l
Δ



cos

(

2


θ
~


)






]




(


l
Σ

+


l
Δ



cos

(

2


θ
~


)



)



(


l
Σ

-


l
Δ



cos

(

2


θ
~


)



)


-


(


l

Δ





sin

(

2


θ
~


)


)

2











and


where



l
Σ


=



l
d

+

l
q


2


,


l
Δ

=



l
d

-

l
q


2






For small position error {tilde over (θ)}, cos(2{tilde over (θ)})≃1; sin(2{tilde over (θ)})≃2{circumflex over (ε)}







l

θ
~


-
1




[





l
^


d
^


-
1






-




l
^


d
^


-


l
^


q
^






l
^


d
^





l
^


q
^







ε
^








-




l
^


d
^


-


l
^


q
^






l
^


d
^





l
^


q
^







ε
^






l
^


d
^


-
1





]










[




Δ


i

d
^

k





Δ


i

q
^

k







Δ


i

d
^


k
-
1






Δ


i

q
^


k
-
1






]

[




Δ


λ

d
^

k





Δ


λ

q
^

k







Δ


λ

d
^


k
-
1






Δ


λ

q
^


k
-
1






]


-
1




[





l
^


d
^


-
1






-




l
^


d
^


-


l
^


q
^






l
^


d
^





l
^


q
^







ε
^








-




l
^


d
^


-


l
^


q
^






l
^


d
^





l
^


q
^







ε
^






l
^


d
^


-
1





]





The inductance computation module 208 determines the estimated error e and estimated incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} on the estimated dq frame as follows.








l
^


d
^


=



Δ


λ

d
^

k


Δ


λ

q
^


k
-
1



-

Δ


λ

q
^

k


Δ


λ

d
^


k
-
1






Δ


I

d
^

k


Δ


λ

q
^


k
-
1



-

Δ


I

q
^

k


Δ


λ

d
^


k
-
1













l
^


q
^


=



Δ


λ

q
^

k


Δ


λ
d

k
-
1



-

Δ


λ

d
^

k


Δ


λ
q

k
-
1






Δ


I

q
^

k


Δ


λ

d
^


k
-
1



-

Δ


I

d
^

k


Δ


λ

q
^


k
-
1












ε
^

=





l
^


d
^





l
^


q
^






l
^


d
^


-


l
^


q
^








Δ


λ

d
^

k


Δ


λ

q
^


k
-
1



-

Δ


λ

q
^

k


Δ


λ

d
^


k
-
1






Δ


I

d
^

k


Δ


λ
q

k
-
1



-

Δ


I
q
k


Δ


λ
d
k









The estimated error {circumflex over (ε)} is provided to a phase lock loop module 109.


The phase lock loop module 109 determines the estimated rotor speed value {circumflex over (ω)} and an estimated rotor position {circumflex over (θ)} that is provided to the Park transformations modules 204 and 205.



FIG. 3 represents a third example of a Field-Oriented Control system in which the present invention is implemented.


Field-Oriented Control system, in the example of FIG. 3, is more precisely an injection aided FCS-MPC (Finite-ControlSet-Model Predictive Control) controller.


In FIG. 3, the system comprises an incremental saliency ratio (ISR) module 100.


The incremental saliency ratio module 100 receives a reference rotor speed value ω*, an estimated rotor speed value {circumflex over (ω)}, an incremental saliency ratio reference ISR* and an estimated incremental saliency ratio






=



l
^


d
^




l
^


q
^







where {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} are estimated incremental inductances in the estimated dq frame provided by an inductance computation module 308.


The incremental saliency ratio module 100 will be disclosed more precisely in FIG. 4.


The output of the incremental saliency ratio module 100 provides a reference current id* and iq* to a sum block 301 where an injection of idh cos(ωht) on the current reference of the d axis (id*) is made. The output of the module 301 is combined to iq* is giving i**dq, which is finally connected to a MPC (Module Predictive Control) module 200. The module 200 estimates an ideal voltage at the next inverter switching step (k+1), by means of a unit delay compensation block 202 and a deadbeat module 201 which is directly responsible for the estimation of the ideal voltage at the next step (k+1).


The output of the MPC module 200 provides an estimated voltage custom-character to a minimum cost function module 203 that determines which voltage vector is the closest to the ideal voltage vector estimated in the module MPC 200 among seven vectors achievable with inverter 206.


The calculation of custom-character from the MPC module 200 is based on the estimation of the current and voltage at the next step instead of using a proportional integral regulator. The estimation of the current is:








l
^


d
^


k
+
1


=



i
^


d
^


+



T
s

(


v

d
^

k

-


i

d
^




R
s



)



l
^


d
^












l
^


q
^


k
+
1


=



i
^


q
^


+



T
s

(


v

q
^

k

-


i

q
^




R
s



)



l
^


q
^










    • which is then used to calculate the voltage references custom-character:








ν{circumflex over (d)}*=i{circumflex over (d)}kRs+{circumflex over (l)}{circumflex over (d)}(id*−{circumflex over (l)}{circumflex over (d)}k+1)/Ts





ν{circumflex over (q)}*=i{circumflex over (q)}kRs+{circumflex over (l)}{circumflex over (q)}(iq*−{circumflex over (l)}{circumflex over (q)}k+1)/Ts


The output of the minimum cost function module 203 is provided to a Park transformation module 204 and to an inverter 206. The output voltages of the inverter 206 are connected to the stator of a motor M and measured currents at the output of the inverter are connected to a Park transformation module 205.


The output of the Park transformation modules 204 and 205, using an estimated rotor position {circumflex over (θ)} provides a voltage in the estimated dq frame custom-character and current custom-character on the estimated frame custom-character to the MPC module 200.


The output custom-character of the Park transformation module 205 is provided to the inductance computation module 308.


The inductance computation module 308 determines an estimated error k and estimated incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} on the estimated dq frame as follows:






custom-characterdq,k−1Ts,custom-characterdq,kTs

    • where k denotes the discrete domain representation of the kth sampling instant, Δ symbolizes Δxk=xk−xk−1, custom-character, λdq is the stator flux linkage on d or q axis





[custom-charactercustom-character]=l{tilde over (θ)}[custom-charactercustom-character]

    • where l{tilde over (θ)} is the incremental inductance matrix and {tilde over (θ)} is the steady state position error.







l

θ
~


=

[





l
Σ

+


l
Δ



cos

(

2


θ
~


)







l
Δ



sin

(

2


θ
~


)








l
Δ


sin


(

2


θ
~


)






l
Σ

-


l
Δ



cos

(

2


θ
~


)






]








l

θ
~


-
1


=


[





l
Σ

+


l
Δ



cos

(

2


θ
~


)







-

l
Δ




sin

(

2


θ
~


)








-

l
Δ




sin

(

2


θ
~


)






l
Σ

-


l
Δ



cos

(

2


θ
~


)






]




(


l
Σ

+


l
Δ



cos

(

2


θ
~


)



)



(


l
Σ

-


l
Δ



cos

(

2


θ
~


)



)


-


(


l

Δ





sin

(

2


θ
~


)


)

2











l
Σ

=



l
d

+

l
q


2


,


l
Δ

=




l
d

-

l
q


2

:






As cos(2{acute over (θ)})≃1; sin(2{tilde over (θ)})≃2{circumflex over (ε)}







l

θ
~


-
1




[





l
^


d
^


-
1






-




l
^


d
^


-


l
^


q
^






l
^


d
^





l
^


q
^







ε
^








-




l
^


d
^


-


l
^


q
^






l
^


d
^





l
^


q
^







ε
^






l
^


d
^


-
1





]










[




Δ


i

d
^

k





Δ


i

q
^

k







Δ


i

d
^


k
-
1






Δ


i

q
^


k
-
1






]

[




Δ


λ

d
^

k





Δ


λ

q
^

k







Δ


λ

d
^


k
-
1






Δ


λ

q
^


k
-
1






]


-
1




[





l
^


d
^


-
1






-




l
^


d
^


-


l
^


q
^






l
^


d
^





l
^


q
^







ε
^








-




l
^


d
^


-


l
^


q
^






l
^


d
^





l
^


q
^







ε
^






l
^


d
^


-
1





]







    • from which we get











l
^


q
^


=



Δ


λ

q
^

k


Δ


λ
d

k
-
1



-

Δ


λ

d
^

k


Δ


λ
q

k
-
1






Δ


I

q
^

k


Δ


λ

d
^


k
-
1



-

Δ


I

d
^

k


Δ


λ

q
^


k
-
1












ε
^

=





l
^


d
^





l
^


q
^






l
^


d
^


-


l
^


q
^








Δ


λ

d
^

k


Δ


λ

q
^


k
-
1



-

Δ


λ

q
^

k


Δ


λ

d
^


k
-
1






Δ


I
d
k


Δ


λ
q
k


-

Δ


I
q
k


Δ


λ
d
k









Assuming a current injection in the d axis for high saliency machines, the inductance estimation is made by:








l
ˆ


d
ˆ


=





In a variant, voltage injection is used instead of a current injection. If a voltage injection is used, the injection would be made between the modules 203 and 200 instead at the modules 301 was used instead of a current one we would have:








l
ˆ


d
ˆ


=





The estimated error {circumflex over (ε)} is provided to a phase lock loop module 109.


The phase lock loop module 109 determines the estimated rotor speed value {circumflex over (ω)} and an estimated rotor position {circumflex over (θ)} that is provided to the Park transformation modules 204 and 205.



FIG. 4 represents an incremental saliency ratio control module which is implemented in the first and second and third examples of the Field-Oriented Control system.


The incremental saliency ratio control module 100 comprises PI proportional-integral regulators 401 and 405, a current limiter 403 and two subtracting modules 400 and 404.


The subtracting module 400 subtracts to the reference rotor speed value ω* the estimated rotor speed value {circumflex over (ω)} and provides the result of the subtracting to the proportional integral module 401.


The output of the proportional integral module 401 is the torque reference T* and it is provided to a Torque model module 402 with the output of the block 405, the current reference id* in the d axis makes possible to calculate the current reference iq* in the q axis:







i
q
*

=


T
*



I
d
*



K
L









    • with











K
L

=


3
2




P

(


L
d

-

L
q


)

·

L
d




,


L
q

(

e
.
g
.



"\[LeftBracketingBar]"



V
dq

/

ω
^



I
qd




"\[RightBracketingBar]"








or using nameplate values) and P is the number of pole pairs.


In a variant, the torque reference is identified as current reference Iq* in the q axis. The torque reference T* issued by 2nd PI regulator is a virtual torque, representative of Iq* rather than torque:






i
q
*=T*


The output of the Torque model module 402 is connected to a current limitation module 403 that limits the current to a current value on the stator |ismax|. The current limitation module 403 changes the value of the q axis reference if current in the stator is higher than the allowed current |ismax|.






{





i
q

*
*


=

i
q
*






if





i
d

*
2


+

i
q

*
2





<



"\[LeftBracketingBar]"


i
s
max



"\[RightBracketingBar]"









i
q

*
*


=






"\[LeftBracketingBar]"


i
s
max



"\[RightBracketingBar]"


2

-

i
d

*
2









if





i
a

*
2


+

i
q

*
2





>



"\[LeftBracketingBar]"


i
s
max



"\[RightBracketingBar]"










The subtracting module 404 subtracts the incremental saliency ratio reference ISR* to the estimated incremental saliency ratio






=



l
ˆ


d
^




l
ˆ


q
^







and provides the result of the subtracting to the proportional integral module 405.


The output of the proportional integral module 404 is provided to the current limitation module 403 and to the Torque module 402.


The outputs of the proportional integral module 405 and the current limitation module 403 are combined in order to provide the reference current idq*.


Then, id*=Kp,ISR(ISR*−custom-character)+Ki,ISR∫(ISR*−custom-character)dt where Kp,ISR and Ki,ISR are constants of the first proportional integral module 405.








i
q
*

=


T
*



I
d
*



K
L




,




where T* is the torque reference and






T*=K
p,ω(ω*−{circumflex over (ω)})+Ki,ω∫(ω*−{circumflex over (ω)})dt

    • where Kp,ω and Ki,ω are constants of a second proportional integral module 401.



FIG. 5 represents an architecture of a control module that controls a motor.


The control module 50 has, for example, an architecture based on components connected together by a bus 501 and a processor 500 controlled by a program.


The bus 501 links the processor 500 to a read only memory ROM 502, a random access memory RAM 503, and an input output I/O interface I/F 505.


The memory 503 contains registers intended to receive variables and the instructions of the program related to the algorithm disclosed in FIG. 6.


The read-only memory, or possibly a flash memory 502, contains instructions of the program related to the algorithm disclosed in FIG. 6.


When the control module 50 is powered on, the instructions stored in the memory 502 are transferred to the random access memory 503.


The control module 50 may be implemented in software by execution of a set of instructions or program by a programmable computing machine, such as a PC (Personal Computer), a DSP (Digital Signal Processor) or a microcontroller; or else implemented in hardware by a machine or a dedicated component, such as an FPGA (Field-Programmable Gate Array) or an ASIC (Application-Specific Integrated Circuit).


In other words, the control module 50 includes circuitry enabling the control module 50 to perform the program.



FIG. 6 represents an example of an algorithm for controlling a motor.


At step S60 the currents at the output of the inverter are measured.


At step S61, the control module 50 estimates in a dq plane the incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} and an estimated position error {circumflex over (ε)} of the rotor of the motor, as disclosed for the modules 108, 208 and 308.


At step S62, the control module 50 determines an incremental saliency custom-character of the motor as a ratio between the incremental inductance {circumflex over (l)}{circumflex over (d)} and the incremental inductance {circumflex over (l)}{circumflex over (q)} and the estimated position error, as disclosed for the modules 108, 208 and 308.


At step S63, the control module 50 estimates the rotor speed value {circumflex over (ω)} of the motor by means of the position estimated error {circumflex over (ε)} obtained at step S61 using the phase lock loop module 109.


At step S64, the control module 50 estimates a first current Id* from the estimated incremental saliency and a reference incremental saliency ISR, as disclosed in reference to the module 100, and further in detail with the modules 404 and 405.


At step S65, the control module 50 estimates a second current Iq* from a reference rotor speed value ω*, the estimated rotor speed value {circumflex over (ω)} and the first current Id* as disclosed in reference to the module 100, and in further detail by the modules 400, 401, 402 and 403.


The first and second currents Id* and Iq* are determined as:

    • Id*=Kp,ISR(ISR*−custom-character)+Ki,ISR∫(ISR*−custom-character)dt where Kp,ISR and Ki,ISR are constants of the first proportional integral module.








I
q
*

=


T
*



I
d
*



K
L




,






    • where T* is the torque of the motor and









T*=K
p,ω(ω*−{circumflex over (ω)})+Ki,ω∫(ω*−{circumflex over (ω)})dt

    • where Kp,ω and Ki,ω are constants of the second proportional integral module, with KL=(Ld−Lq). Ld, Lq estimation (e.g. |Vdq/{circumflex over (ω)}Iqd| or using nameplate values).


In a variant, the torque reference is identified as current reference Iq* in the q axis. The torque reference T* issued by the second PI regulator is a virtual torque, representative of Iq* rather than torque.


At step S66, the control module 50 determines the voltage to be used for controlling the motor M.


According to the first example at step S67b, the voltage is calculated by the blocs 101, 103 and 104 and the voltage applied on the motor is:





ν{circumflex over (d)}**=νdh*cos(ωdht)+ν{circumflex over (d)}*





ν{circumflex over (q)}**=νqh*cos(ωqht)+ν{circumflex over (q)}*

    • where ν{circumflex over (d)}* and ν{circumflex over (q)}* are obtained by:





ν{circumflex over (d)}*=Kp,Id(Id*−I{circumflex over (d)})+Ki,Id∫(Id*−I{circumflex over (d)})dt





ν{circumflex over (q)}*=Kp,Iq(Iq*−I{circumflex over (q)})+Ki,Iq∫(Iq*−I{circumflex over (q)})dt

    • where Kp,Id is the proportional gain of a third proportional integral regulator, Ki,Id is the integral gain for the d axis of the third proportional integral regulator, Kp,Iq is the proportional gain of a fourth proportional integral regulator and Ki,Iq is the integral gain for the q axis of the fourth proportional integral regulator. According to the second example, the voltage to be used for controlling the motor M is determined from the modules 200, which is composed by the modules 201 and 202:





ν{circumflex over (d)}*=i{circumflex over (d)}kRs+{circumflex over (l)}{circumflex over (d)}(id*−{circumflex over (l)}{circumflex over (d)}k+1)/Ts





ν{circumflex over (q)}*=i{circumflex over (q)}kRs+{circumflex over (l)}{circumflex over (q)}(iq*−{circumflex over (l)}{circumflex over (q)}k+1)/Ts


According to the third example, at step S67a a supplementary injection to the current id* is performed as: id**=id*+idh*cos(ωht) by the modules 201. The voltage to be used for controlling the motor M is determined by the module 200, which is composed by the modules 201 and 202:





ν{circumflex over (d)}*=i{circumflex over (d)}kRs+{circumflex over (l)}{circumflex over (d)}(id*−{circumflex over (l)}{circumflex over (d)}k+1)/Ts





ν{circumflex over (q)}*=i{circumflex over (q)}kRs+{circumflex over (l)}{circumflex over (q)}(iq*−{circumflex over (l)}{circumflex over (q)}k+1)/Ts


The determined control voltage is then applied to the motor M.

Claims
  • 1. A method for controlling a three-phase motor using a field oriented control system, characterized in that the method comprises the steps of: estimating, in a dq plane the incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} of the motor,determining an incremental saliency of the motor as a ratio between the incremental inductance {circumflex over (l)}{circumflex over (d)} and the incremental inductance {circumflex over (l)}{circumflex over (q)},estimating a first current id* from the estimated incremental saliency and a reference incremental saliency ISR*,estimating the rotor speed value {circumflex over (ω)} of the motor,estimating a second current iq* from a reference rotor speed value ω*, and the estimated rotor speed value {circumflex over (ω)},controlling the voltage applied to the motor according to the first and second estimated currents.
  • 2. The method according to claim 1, characterized in that the first and second estimated currents are estimated as: id*=Kp,ISR(ISR*−)+Ki,ISR∫(ISR*−)dt where Kp,ISR and Ki,ISR are constants of a first proportional integral regulator.
  • 3. The method according to claim 1, characterized in that the method further comprises the step of estimating a position error of the rotor of the motor and the estimated rotor speed value {circumflex over (ω)} is estimated using a phase lock loop having as input signal the estimated position error.
  • 4. The method according to claim 1, characterized in that the voltage applied to the motor is a voltage vector and consecutive voltage vectors are applied successively during successive periods of time, the estimated incremental inductances are estimated from a stator flux linkage of the motor on d or q axis and a steady state position error ε is determined.
  • 5. The method according to claim 4, characterized in that the incremental inductance {circumflex over (l)}{circumflex over (d)} and the incremental inductance {circumflex over (l)}{circumflex over (q)} are defined as:
  • 6. The method according to claim 5, characterized in that the consecutive voltage vectors are defined as: ν{circumflex over (d)}*=i{circumflex over (d)}kRs+{circumflex over (l)}{circumflex over (d)}(id*−{circumflex over (l)}{circumflex over (d)}k+1)/Ts ν{circumflex over (q)}*=i{circumflex over (q)}kRs+{circumflex over (l)}{circumflex over (q)}(iq*−{circumflex over (l)}{circumflex over (q)}k+1)/Ts where Rs is the stator resistance of the motor and Ts is the sampling time.
  • 7. The method according to claim 1 characterized in that the method further comprises the step of injecting voltage signals that are equal to νdh*cos(ωdht) and νqh*cos(ωqht), where ωdh and ωqh are the injection frequencies on axis d and q respectively, νdh* and νqh* are the amplitude of the injected voltage in axis d and q respectively, the incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} of the motor are estimated as:
  • 8. The method according to claim 1 characterized in that the method further comprises the step of injecting voltage signals that are equal to νdh*cos(ωdht) with a frequency of ωdh on the d axis and a squarewave injection on the q axis of period Ts and amplitude νq*, and incremental inductances are:
  • 9. The method according to claim 7, characterised in that the voltage applied to the motor is determined as: ν{circumflex over (d)}**=νdh*cos(ωdht)+ν{circumflex over (d)}*ν{circumflex over (q)}**=νqh*cos(ωqht)+ν{circumflex over (q)}*with:ν{circumflex over (d)}*=Kp,Id(Id*−I{circumflex over (d)})+Ki,Id∫(Id*−I{circumflex over (d)})dt ν{circumflex over (q)}*=Kp,Iq(Iq*−I{circumflex over (q)})+Ki,Iq∫(Iq*−I{circumflex over (q)})dt where Kp,Id is the proportional gain of a third proportional integral regulator, Ki,Id is the integral gain for the d axis of the third proportional integral regulator, Kp,Iq is the proportional gain of a fourth proportional integral regulator and Ki,Iq is the integral gain for the q axis of the fourth proportional integral regulator.
  • 10. The method according to claim 1 characterized in that the method further comprises the step of injecting a current idh*cos(ωht) on the current reference of the d axis and the incremental inductances are equal to:
  • 11. The method according to claim 10, characterised in that the voltage applied to the motor is determined from: ν{circumflex over (d)}*=i{circumflex over (d)}kRs+{circumflex over (l)}{circumflex over (d)}(id*−{circumflex over (l)}{circumflex over (d)}k+1)/Ts ν{circumflex over (q)}*=i{circumflex over (q)}kRs+{circumflex over (l)}{circumflex over (q)}(iq*−{circumflex over (l)}{circumflex over (q)}k+1)/Ts where Rs is the stator resistance of the motor and Ts is the sampling time.
  • 12. A device for controlling a three-phase motor using a field oriented control system, characterized in that the device comprises: means for estimating in a dq plane the incremental inductances {circumflex over (l)}{circumflex over (d)} and {circumflex over (l)}{circumflex over (q)} of the motor,means for determining an incremental saliency of the motor as a ratio between the incremental inductance {circumflex over (l)}{circumflex over (d)} and the incremental inductance {circumflex over (l)}{circumflex over (q)},means for estimating a first current Id* from the estimated incremental saliency and a reference incremental saliency ISR*,means for estimating the rotor speed value {circumflex over (ω)} of the motor,means for estimating a second current Iq* from a reference rotor speed value ω*, and the estimated rotor speed value {circumflex over (ω)},means for controlling the voltage applied to the motor according to the first and second estimated currents.
Priority Claims (1)
Number Date Country Kind
20315433.1 Oct 2020 EP regional
PCT Information
Filing Document Filing Date Country Kind
PCT/JP2021/037258 10/1/2021 WO