The present application relates to a controller for a variable voltage and variable frequency type power convertor and a motor driving system.
U.S. Pat. No. 9,281,772 discloses a controller for a power convertor. The controller can put, on a motor, a brake of good response. The following Non Patent Literature 1 discloses a flux observer for safe operation of a motor.
However, in the systems of the above Patent Literature 1 and Non-Patent Literature 1, no field weakening is implemented. For this reason, an operation of the electric motor can be limited on the high speed range.
As a general technique of field weakening, there is a method of suppressing the influence of voltage saturation when the output frequency of the power converter increases, by lowering the flux command value in inverse proportion to the rotational speed. The fundamental output frequency of the power converter is also referred to as power supply angular frequency.
The flux command method in simply inverse proportion to a frequency does not consider the output limit of the convertor. Therefore, the control stability is potentially degraded when output torque in a field weakening region is increased.
The present application is intended to solve the above-described problem and provide a controller for a power convertor, and a motor driving system that are capable of simultaneously achieving control stability and output torque increase in a field weakening region.
In the control device described in Non-Patent Literature 1, sensorless control is performed by obtaining the rotation speed using the stator flux estimated by the flux observer. However, this stator flux is subject to harmonics caused by PWM control and current measurement noise. For this reason, the stator flux has a low S/N ratio because the flux amplitude decreases particularly in the field weakening region. For these reasons, the accuracy of the speed estimation declines and there is a possibility that stable operation cannot be performed.
The present application is also intended to provide a controller for a power convertor, and a motor driving system that are capable of highly accurately calculating an estimated speed value.
A first controller for a power convertor according to a first aspect of the present application includes: a torque command value calculation module configured to calculate a first torque command value to a power convertor based on a speed command value of a motor driven by the power convertor; a torque command limit module configured to receive the first torque command value and generate a second torque command value obtained by correcting the first torque command value so that the first torque command value is limited to a torque limiter range defined by an upper limit torque value calculated by a predetermined calculation formula for upper limit torque command value calculation and a lower limit torque value obtained by multiplying the upper limit torque value by a predetermined negative coefficient or zero; a flux command generation module configured to generate a stator flux command value in accordance with a fundamental wave output frequency of output from the power convertor; and an output voltage calculation module configured to calculate an output voltage command value of the power convertor based on the second torque command value and the stator flux command value. The torque command limit module calculates the upper limit torque value to be smaller as the fundamental wave output frequency increases at least in a speed region equal to or higher than a field weakening starting point.
A second controller for a power convertor according to a second aspect of the present application includes: a torque command value calculation module configured to calculate a torque command value to a power convertor based on a speed command value of a motor driven by the power convertor; a voltage command value calculation module configured to calculate a voltage command value to the power convertor based on the torque command value calculated by the torque command value calculation module; a flux estimation module configured to calculate estimated values of the stator flux and rotor flux of the motor in a subsequent control period based on the voltage command value to the power convertor and a measured stator current of the motor; and a motor speed estimation module configured to calculate an estimated value of a speed of the motor in a subsequent control period based on the estimated value of the rotor flux calculated by the flux estimation module.
A motor driving system according to a third aspect of the present application includes: a power convertor configured to drive a motor; and one of the first or second controller for a power convertor, which is configured to control the power convertor.
Other and further objects, features and advantages of the invention will appear more fully from the following description.
Embodiments of the present invention will be described in accordance with the accompanying drawings. It should be noted that in the drawings, the same or corresponding parts are denoted by the same reference signs. Overlapping description of such parts will be simplified or omitted as appropriate.
Symbols are explained below. Complex vectors are as follows.
Vqds stator voltage complex vector [V]
Vqdr rotor voltage complex vector [V]
iqds stator current complex vector [A]
iqdr rotor current complex vector) [A]
λqds stator flux linkage complex vector [V-sec]
λqdr rotor flux linkage complex vector [V-sec]
Scalars are as follows.
Vqs stator q-axis voltage [V]
Vds stator d-axis voltage [V]
Vqr rotor q-axis voltage [V]
Vdr rotor d-axis voltage [V]
iqs stator q-axis current [A]
ids stator d-axis current [A]
iqr rotor q-axis current [A]
idr rotor d-axis current [A]
λqs stator q-axis Flux [V-sec]
λds stator d-axis Flux [V-sec]
λqr rotor q-axis Flux [V-sec]
λdr rotor d-axis Flux [V-sec]
Te electromagnetic torque [N-m]
TL load torque [N-m]
vus u-phase stator voltage [V]
vvs v-phase stator voltage [V]
vws w-phase stator voltage [V]
ius u-phase stator current [A]
ivs v-phase stator current [A]
iws w-phase stator current [A]
iur u-phase rotor current [A]
ivr v-phase rotor current [A]
iwr w-phase rotor current [A]
Rs stator resistance [Ω]
Rr rotor resistance [Ω]
Lls stator leakage inductance [H]
Llr rotor leakage inductance [H]
Lm magnetizing inductance [H]
Ls stator winding inductance [H] Ls=Lls+Lm
Lr rotor winding inductance [H] Lr=Llr+Lm
Jp inertia [kg-m2]
P Pole number
P/2 Pole pair number
ts sampling time [s]
Pcu IM cupper loss [W]
Pfe IM iron loss [W]
Ploss IM loss [W] Ploss=Pcu+Pfe
Pe input power [W] Pe=Ploss+Pstored+Pem
Pstored Time differentiation of magnetic energy accumulated in the inductance of the induction machine [W]
Pem mechanical loss [W] (Power contributing to torque)
Ke eddy current coefficient
Kh hysteresis coefficient
Req equivalent resistance [Ω]
τeq equivalent time constant [s]
τr rotor time constant [s] That is, MI_T2 (Secondary time constant)
ω angular speed [rad/s] ω=pθ
General Description without Specifying Coordinate System (Arbitrary Coordinate System)
θangle [rad] ω=pθ General description without specifying the coordinate system
ωr rotor electrical angular speed [rad/s] ωr=Pωrm/2
θr rotor electrical angular position [rad]
(Angle of u-Phase Rotor Winding Taken Counterclockwise with Respect to u-Phase Stator Winding)
ωrm rotor mechanical angular speed [rad/s] ωrm=2ωr/P
Rotational Angular Speed of the Output Shaft
θrm rotor mechanical angle [rad] θrm=2θr/P
Rotational Angular of the Output Shaft
ωe synchronous angular frequency [rad/s]
ω=pθ, but if the synchronization angular frequency is constant, it is also expressed as ωt=θ.
θe synchronous angular position
ωsl slip angular frequency [rad/s]
ωsl=ωe−ωr
Mathematical Elements are as Follows.
j imaginary number
p differential operator
s Laplace operator
a space vector rotation operator a=exp(j2π/3)
Re{ } complex real part
Im{ } complex imaginary part
L{ } Laplace transform
Z{ } z-transform)
Each symbol of superscript has the following meaning.
fs stationary reference frame
fe general synchronous reference frame
fr rotor reference frame
fras re-aligned stationary reference frame
f* command value
{dot over (f)} differential value
{circumflex over (f)} estimate value
Each subscript symbol has the following meaning.
fs stator
fr rotor
( )opt appropriate value
In
An output part of the motor 2 is connected to an input part of a load machine 4. For example, the load machine 4 is an inertia load. A speed sensor 119 for detecting the rotational speed of the rotor is connected to the electric motor 2.
An input part of the motor driving system 3 is connected to an output part of an AC power supply 5. For example, the AC power supply 5 is a grid.
The motor driving system 3 includes a diode rectifier 6, a capacitor 7, an inverter 8, a first current detector 9a, a second current detector 9b, and controller 11.
The diode rectifier 6 converts, into DC power, the three-phase AC power supplied from the AC power supply 5. If necessary, the diode rectifier 6 may be replaced with a PWM converter.
The capacitor 7 is provided across a DC link on the output side of the diode rectifier 6. The capacitor 7 is used to smooth the DC voltage applied to the DC link.
The inverter 8 is converts the DC power supplied from the diode rectifier 6 into three-phase AC power for driving the electric motor 2. The inverter 8 is a voltage source inverter. The inverter 8 is subjected to variable voltage variable frequency (VVVF) control through pulse width modulation (PWM) control.
The power conversion circuit of the inverter 8 is formed of three arms. One of the arms includes an upper arm and a lower arm. The upper and lower arms are each formed of at least one switching element.
The first current detector 9a is provided at the v-phase of the output side of the inverter 8. The first current detector 9a detects the v-phase stator current Ivs. The second current detector 9b is provided at the w-phase of the output side of the inverter 8. The second current detector 9b detects the w-phase stator current Iws.
The controller 11 includes a speed controller 12, a DB-DTFC calculation module 14, a first coordinate conversion module 15, PWM controller 16, a second coordinate conversion module 17, a current/flux estimation module 20, a speed/phase estimation module 21, a torque command limit module 13, an appropriate flux command generation module 18, a power supply angular frequency calculation module 19, and a first slip angular frequency estimation module 32.
The speed controller 12 is a torque command value calculation module. The speed controller 12 calculates the torque command value Tem1* so that the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r, which is detected by the speed/phase estimation module 21, will follow the rotor mechanical angular speed command value ωrm* obtained from an external device.
Here, the “dqs-axes” is such that the U phase and the q axis coincide of a stator with each other in a stationary axis system, and distributes the three phase components to two phases of the d axis and the q axis orthogonal to each other. The second coordinate conversion module 17, which will be described later, is a circuit that performs dq-axes conversion to replace the input signal with the biaxial signal. The first coordinate conversion module 15, which will be described later, is an inverse conversion circuit that restores the two phase signals converted into the d axis and the q axis in the stationary axis system to three phase signals in the stationary coordinate system.
For example, a superscript symbol “S” of the stator dqs-axes flux value λqdsS represents the stationary coordinate system. A subscript symbol “qds” of the stator dqs-axes flux value λqdsS represents “two phase components” of the stator flux. That is, the stator dqs-axes flux value λqdsS represents the d-axis component λdsS of the stator flux value and the q-axis component λqsS of the stator flux command value. In the following description, symbols with the subscript suffix “qds” are the symbols representing both the d-axis component and the q-axis component of the stator flux.
On the other hand, a superscript symbol “S” of the rotor dqs-axes flux value λqdrS represents the stationary coordinate system. A subscript symbol “qdr” of the rotor dqs-axes flux value ΔqdrS represents the d-axis component λdrS of the rotor flux value and the q-axis component λqrS of the rotor flux value. In the following description, symbols with the subscript suffix “qdr” are the symbols representing both the d-axis component and the q-axis component of the rotor flux.
The torque command limit module 13 calculates the second torque command value Tem* based on the first torque command value Tem1* calculated by the speed control module 12, the stator flux command value λs_opt generated by the appropriate flux command generation module 18, and the power supply angular frequency ωe calculated by the power supply angular frequency calculation module 19. Details of the torque command limit module 13 will be described later with reference to
The DB-DTFC calculation module 14 calculates the stator dqs-axes voltage command value VqdsS* based on the second torque command value Tem*, the flux command value λs*, the stator dqs-axes flux estimated value {circumflex over (λ)}dsS the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS, and the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r estimated by the speed/phase estimation module 21 which is described later. The flux command value λs* is a stator flux command value λs_opt generated by the appropriate flux command generation module 18. The DB-DTFC calculation module 14 employs, as a control method, a deadbeat direct torque & flux control (DB-DTFC) method.
The first coordinate conversion module 15 converts the stator dqs-axes voltage command value VqdsS* into three-phase stator voltage command values Vus*, Vvs*, and Vws*. The conversion performed by the first coordinate conversion module 15 is an inverse conversion of the dqs-axes transformation.
The PWM controller 16 converts the three-phase stator voltage command values Vus*, Vvs*, and Vws* into gate pulses for the inverter 8 based on the pulse width modulation. The PWM controller 16 outputs the gate pulses to the inverter 8.
The second coordinate conversion module 17 converts the stator currents Ivs, Iws into a stator dqs-axes current measured value iqdss. The conversion performed by the second coordinate conversion module 17 is “dqs-axes conversion”.
Three-phase to two-phase conversion by dqs-axes conversion is performed based on the following equation. For example, if the currents of three phases are Iu, Iv, Iw and the currents after two-phase conversion are Ids, Iqs, the following equation is obtained.
I
u
+I
v
+I
w=0
I
qs
=I
u
I
ds=(Iu+2Iw)/√3
This conversion is somewhat different from Clarke conversion which is a general three-phase to two-phase conversion.
The appropriate flux command generation module 18 generates the stator flux command value λs_opt by performing calculation on an appropriate flux command based on the power supply angular frequency ωe calculated by the power supply angular frequency calculation module 19. The stator flux command value λs_opt having an appropriate value is input to the DB-DTFC calculation module 14 as the flux command value λs*. The appropriate flux command generation module 18 will be described later in detail with reference to
The power supply angular frequency calculation module 19 calculates the power supply angular frequency ωe based on the rotor mechanical angle estimated value {circumflex over (ω)}rm-r estimated by the speed/phase estimation module 21 and the slip angular frequency estimated value {circumflex over (ω)}sl estimated by the first slip angular frequency estimation module 32. The relationship between the detected rotational speed
It should be noted that the output value of the speed sensor 119 is not the instantaneous value but the average speed between the detection timings, and thus the output value of the speed sensor 119 is expressed as {circumflex over (ω)}rm using the symbol indicating the average value.
Here, the stator dqs-axes current measured value iqdss and the stator dqs-axes voltage measured value Vqdss are values obtained by dqs converting the three phase measured values. The total sum of the instantaneous values of the three-phase currents, which is the output of the inverter 8, is zero. By using this property, in the first embodiment, two-phase current is detected, and for the other phase, a value obtained by inverting the sign of the added value of two-phase current is used.
The current/flux estimation module 20 calculates the stator dqs-axes flux estimated value {circumflex over (λ)}qdsS and the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS as a flux estimation module based on the rotor electrical angle estimated value {circumflex over (θ)}r estimated by the speed/phase estimation module 21, the voltage command value VqdsS*, the stator dqs-axes current measured value iqdss, the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r.
A speed and phase estimation module 21 as a motor speed estimation module calculates a rotor electrical angle estimated value {circumflex over (θ)}r and a rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r based on the second torque command value Tem* and a measurement value
The speed/phase estimation module 21 basically performs a calculation such that a torque command value is divided by a moment of inertia of the motor 2 to calculate an acceleration value, the acceleration value is integrated to calculate a speed, and the speed is integrated to calculate a phase. The delay operator is used in the speed/phase estimation module 21.
The rotational speed
The integral module 21c is an integration circuit having a gain Kio. The integral module 21c outputs a calculation result to the adder module 21f. The proportional module 21d performs amplification by a gain Kso. The proportional module 21d outputs a calculation result to the adder module 21f. The proportional module 21e performs amplification by a gain bo. The proportional module 21e outputs a calculation result to the adder module 21f.
The adder module 21f performs addition of the output from the integral module 21c, the output from the proportional module 21d, and the output from the proportional module 21e, and outputs the calculation result to the adder module 21g. The adder module 21g performs addition of the second torque command value Tem*, which is the output from the torque command limit module 13, and the output from the adder module 21f, and then outputs a calculation result to the acceleration value calculation module 21h.
The acceleration value calculation module 21h divides an inputted value by the moment of inertia estimated value ĵp of the motor 2, and then outputs the estimated acceleration value to the integral module 21j. The integral module 21j integrates the inputted estimated acceleration value to estimate the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r.
The rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r is transmitted to the integral module 21n and the average value calculation module 21k. The rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r is also transmitted to the outside of the speed/phase estimation module 21. The outside of the speed/phase estimation module 21 is for example the DB-DTFC calculation module 14. Further, the rotor mechanical angular speed estimated value ωrm-r is also transmitted to the current and flux estimation module 20, the power supply angular frequency calculation module 19, and the speed control module 12.
The integral module 21n integrates the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r to calculate the estimated phase (mechanical angle) {circumflex over (θ)}rm. The estimated phase (mechanical angle) {circumflex over (θ)}rm is inputted to the proportional module 21p. The proportional module 21p multiples the estimated phase (mechanical angle) {circumflex over (θ)}m by the pole number P/2 of the motor 2 to calculate the estimated phase (electrical angle) {circumflex over (θ)}r. The estimated phase (electrical angle) {circumflex over (θ)}r is outputted to the outside of the speed/phase estimation module 21. The outside of the speed/phase estimation module 21 is for example the current and flux estimation module 20.
The average value calculation module 21k calculates the average value {circumflex over (ω)}rm with respect to the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r by calculating an average of an estimated value in the present calculation period and another estimated value before one calculation period, and then outputs the calculation result to the delay calculation module 21m. The delay calculation module 21m performs a calculation to delay the average value {circumflex over (ω)}rm by one calculation period, and then outputs a calculation result to the subtraction module 21a as a subtraction value. It should be noted that, the configuration in
Voltage, current, and flux always change in the dqs-axes coordinate in the steady state. On the other hand, speed is constant, and the influence of the phase delay need not to be considered. By using the motion observer, phase and speed information with little noise can be obtained without phase delay.
The torque command limit module 13 includes a first block 13a, a second block 13b, a third block 13c, a fourth block 13d, a fifth block 13e, and a sixth block 13f.
The first block 13a calculates an upper limit torque command value Te_max based on the stator flux command value λs_opt in accordance with Expression (30) to be described later. Expression (30) is a predetermined first calculation formula for upper limit torque command value calculation. A second-order polynomial including the second-order term (λs_opt2) of the stator flux command value λs_opt and the first-order term (λs_opt) thereof is derived by expanding the expression in the square root in Expression (30).
The second block 13b calculates the upper limit torque command value Te_max based on the stator flux command value λs_opt in accordance with Expression (36) to be described later. Expression (36) is a predetermined second calculation formula for upper limit torque command value calculation. Expression (36) is a monomial obtained by multiplying the second-order term (λs_opt2) of the stator flux command value by a predetermined coefficient. The predetermined coefficient is
The third block 13c calculates a boundary speed ωe_c in accordance with Expression (34) to be described later. The boundary speed ωe_c is a speed predetermined to be higher than a field weakening starting point, and determined by Expression (34). The field weakening starting point may be, for example, the rated speed of a motor.
The fourth block 13d determines a speed region based on the power supply angular frequency ωe and the boundary speed ωe_c. The speed region is divided into a normal operation region, Region I, and Region II. Region I is a region between the boundary speed ωe_c and the field weakening starting point. Region II is a region higher than the boundary speed ωe_c.
Specifically, the fourth block 13d determines the speed region in accordance with the power supply angular frequency ωe as follows. The field weakening starting speed is defined as ωbase. When ωe<ωbase, it is determined the speed is in the normal operation region. When ωbase≤ωe<ωe_c, it is determined that the speed is in Region I (a first field weakening region). When ωe_c≤ωe, it is determined that the speed is in Region II (a second field weakening region). The fourth block 13d outputs “0” when the current speed is in the normal operation region or Region I. The fourth block 13d outputs “1” when the current speed is in Region II.
When the output from the fourth block 13d is “0”, the fifth block 13e selects the upper limit torque command value Te_max output from the first block 13a. When the output from the fourth block 13d is “I”, the fifth block 13e selects the upper limit torque command value Te_max output from the second block 13b. The fifth block 13e transmits the selected upper limit torque command value Te_max to the sixth block 13f.
The sixth block 13f determines a torque limiter range by using the upper limit torque command value Te_max transmitted from the fifth block 13e. The torque limiter range is a range defined by an upper limit torque value (+Te_max) and a lower limit torque value (−Te_max). The upper limit torque value is the upper limit torque command value Te_max. The lower limit torque value is a value obtained by multiplying the upper limit torque value by a negative coefficient. The negative coefficient is a predetermined value, and may be “−1” or a value other than minus one. Also, instead of this negative coefficient, the lower limit torque value may be set to zero by multiplying zero by the upper limit torque value.
When the first torque command value Tem1* is in the torque limiter range, the sixth block 13f substitutes the first torque command value Tem1* directly into the second torque command value Tem*. When the first torque command value Tem1* is larger than the upper limit torque value +Te_max, the sixth block 13f substitutes the upper limit torque value +Te_max into the second torque command value Tem*. When the first torque command value Tem1* is smaller than the lower limit torque value −Te_max, the sixth block 13f substitutes the lower limit torque value −Te_max into the second torque command value Tem*.
In this manner, the sixth block 13f functions as a filter that allows only a torque command value in the torque limiter range to pass through. Accordingly, the sixth block 13f generates the second torque command value Tem*. The second torque command value Tem* is a value obtained by correcting the first torque command value Tem1* so that the first torque command value Tem1* is limited to the torque limiter range.
The appropriate flux command generation module 18 includes a first block 18a and a second block 18b. The appropriate flux command generation module 18 generates the stator flux command value λs_opt in accordance with the power supply angular frequency ωe.
The first block 18a calculates the stator flux command value λs_opt in accordance with Expression (29) to be described later. The first block 18a calculates a value obtained by dividing a stator voltage maximum value Vmax by the power supply angular frequency ωe.
The second block 18b limits the stator flux command value λs_opt calculated by the first block 18a to a certain range. The second block 18b employs a predetermined upper limiter flux value and limits the stator flux command value λs_opt to be equal to or smaller than the upper limiter flux value. The upper limiter flux value may be the rated stator flux λrate as one of parameters of the motor in the embodiment.
The power supply angular frequency calculation module 19 calculates the rotor electrical angular speed estimated value {circumflex over (ω)}r by multiplying the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r calculated by the speed and phase estimation module 21 by P/2. The value P is the pole number of the motor 2. The power supply angular frequency calculation module 19 calculates the power supply angular frequency ωe by adding the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r and a slip angular frequency estimated value {circumflex over (ω)}sl outputted from a first slip angular estimation module 32.
The slip angular frequency estimated value {circumflex over (ω)}sl may be estimated by Expressions (43) or (44), as described later. In the first embodiment, the rotor dqs-axes flux estimated value λqdsS outputted from the current/flux estimation module 20 and the rotor dqs-axes current measured value iqdss outputted from the second the second coordinate conversion module 17 are inputted to the first slip angular estimation module 32. The first slip angular estimation module 32 performs a calculation based on Expression (43) to estimate the slip angular frequency estimated value {circumflex over (ω)}sl.
The following describes a theory for increasing an output torque in a field weakening region in DB-DTFC control. Expressions (1) to (4) are equations for an induction machine in an optional coordinate system.
V
qds
=R
s
i
qds
+jωλ
qds
+pλ
qds (1)
0=Rriqdr+j(ω−ωr)λqdr+pλqdr (2)
λqds=Lsiqds+Lmiqdr (3)
λqdr=Lriqdr+Lmiqds (4)
A stator-side voltage equation in a synchronous coordinate system (synchronous with the power supply frequency) of the induction machine can be given by Expression (5).
V
qds
e
=R
s
i
qds
e
+jω
eλqdse+pλqdse (5)
Any differential term can be omitted in a steady state, and thus Expression (5) becomes Expression (6).
V
qds
e
=R
s
i
qds
e
+jω
eλqdse (6)
The term of the power supply angular frequency ωe is dominant in a high speed range, and thus finally, Expression (7) is obtained.
V
qds
e
=jω
eλqdse (7)
It is clear from Expression (7) that a voltage upper limit is reached as the speed increases. In such a case, ωe can be increased by decreasing the flux. This is called field weakening.
One of features of the embodiment is a method of determining a flux command for achieving an increased torque in the high frequency region.
Studies performed by the inventor of the present application have found a novel torque output increasing technology, the contents of which will be described below.
1.1 Stator Flux Limit with the Voltage and Current Limits Taken into Account
The stator voltage maximum value Vmax is limited by a DC voltage Vdc of the inverter and a modulation method. The stator voltage maximum value Vmax is Vsmax=Vdc/2 for sinusoidal wave pulse width modulation (SPWM), or Vsmax=Vdc/√{square root over (3)} for space vector pulse width modulation (SVPWM). If necessary, in deriving the maximum value Vsmax of the stator voltage, an influence of a forward voltage drop or a dead time of switching elements constituting the inverter 8 may be taken into consideration.
Another point is, if necessary, a coefficient slightly smaller than 1, for example 0.98, can be used to calculate Vsmax to account for the voltage drop on the stator resistance.
Expression (7) gives a dqs-axes complex vector. Expression (8) is a voltage limit expression obtained from Expression (7).
In addition to the voltage limit, another limit is placed on the stator flux amplitude. This limit is an allowable output current limit of the inverter 8 and allowable current through the motor
(iqse)2+(idse)2≤Ismax2 (9)
To use the stator flux in control, a relational expression between the stator current and the stator flux is derived. In the stationary state, Expression (2) as a voltage equation for the rotor becomes Expression (10).
0=Rriqdre+j(ωe−ωr)κqdre (10)
When Expression (10) is rewritten for the q-axis and d-axis components separately, Expressions (11) and (12) below are obtained.
0=Rriqre+(ωe−ωr)λdre (11)
0=Rridre+(ωe−ωr)λqre (12)
Expressions (11) and (12) are simplified by performing coordinate transformation on the rotor flux so that Expressions (13) and (14) are obtained.
λdre=λr (13)
λqre=0 (14)
From Expressions (12) and (14), a rotor-side d-axis current on the synchronous coordinate system is given by Expression (15).
0=idre (15)
Expression (4) is rewritten in a manner divided for the q and d axes.
λqse=Lsiqse+Lmiqre (16)
λdse=Lsidse+Lmidre (17)
From Expressions (15) and (17), Relation Expression (18) between the stator current and the stator flux on the d-axis side can be obtained.
λdse=Lsidse (18)
Then, a relational expression between the stator current and the stator flux on the q-axis side is obtained. Expression (3) is rewritten in a manner divided for the d and q-axes.
λqre=Lmiqse+Lriqre (19)
λdre=Lmidse+Lridre (20)
Expression (21) can be obtained from Expressions (14) and (19).
Lastly, the relational expression between the stator current and the stator flux on the q-axis side can be obtained from Expressions (16) and (21). In the expression, a represents a leakage coefficient listed in a symbol list.
The current-voltage relation expressions (18) and (22) on the d-axis and q-axis sides are substituted into the current limit expression (9) to finally obtain a current limit expression (23).
When illustrated on a stator flux plane, the expression depicts an ellipse as illustrated in
As described in the previous section, a combination of (d-axis and q-axes) stator flux command vectors are limited by the current and voltage limits of the inverter. Achievable torque differs between stator flux command vectors. The present section derives stator flux for achieving increased torque.
1.2.1 Torque Formula (Expression Only with Stator Flux)
A torque formula is expressed as Expression (24). This formula is expressed only with the stator flux to depict torque on the dqs-axes plane of the stator flux.
Expression (25) can be obtained from Expressions (15), (18), and (20).
Torque Formula (26) expressed only with the stator flux can be obtained from Expressions (14), (24), and (25).
Expression (26) indicates that the stator flux locus depicts a hyperbola on the dqs-axes flux plane when the torque is constant.
When the power supply frequency is 1.2 pu, the number of combinations of stator fluxes satisfying the voltage and current limits is infinite for TL=1.0 pu. However, the number of such combinations is one for TL=1.7 pu. This is a maximum torque achievable in theory. Both limits cannot be satisfied for TL=2.3 pu, and thus this torque cannot be achieved.
The radius of the voltage limit circle decreases as the power supply frequency increases. Accordingly, no torque curve exists in a region common to the current limit ellipse and the voltage limit circle. A maximum torque is achieved at a contact point between a torque curve and the voltage limit circle. This point is a point of transition from Region I to Region II, which will be described later.
Specifically, in a particular region, the stator flux is limited by two limits, namely, the current and voltage limits. In the other region, however, the stator flux is limited by one limit, namely, the voltage limit. A flux command needs to be determined in each region due to this limit difference.
The above-described two field weakening regions are referred to as Region I and Region II. The following describes Region I, Region II, and a boundary point between these regions. The relation between each region and the speed is listed below with description of terms.
ωe<ωbase: Normal operation region
ωbase≤ωe<ωe_c: Region I (first field weakening region)
ωe_c≤ωe: Region II (second field weakening region)
ωe_c: Boundary speed between Regions I and II
ωbase: Field weakening start speed
The field weakening starting point ωbase is determined by the stator voltage and the rated flux. In the first embodiment, it is assumed that field weakening automatically starts at voltage saturation.
1.2.2 Stator flux in Region I (ωbase<ωe<ωe_c)
As illustrated in
In Region I, a stator flux for achieving the maximum torque is at the intersection point between the current limit ellipse and the voltage limit circle. In
Stator flux command vectors satisfying the intersection point are given by Expressions (27) and (28) due to the voltage and current limits.
The amplitude of the stator flux is limited by Expression (29) as the radius of the voltage limit circle.
Expression (30), which calculates the maximum torque in the field weakening region I, is obtained from Expressions (26) to (29).
1.2.3 Stator flux (ωe_c<ωe) in Region II
The intersection point between the ellipse and the circle is below the straight line of λdse=λqse at a higher speed. No intersection point exists at a further higher speed. An operation frequency band in which these phenomena occur is defined to be Region II.
Here, among the stator flux λqds_ce, the λqs_ce represents the q-axis component of the stator flux at the boundary speed, and the λds_ce represents the d-axis component of the stator flux at the boundary speed.
The boundary speed ωe_c is finally obtained by Expression (34).
Similarly to Region I, the stator flux command amplitude is limited by Expression (29). The maximum torque achievable in the field weakening region H is expressed as Expression (36). Expression (36) is derived from Expressions (26), (29), and (35).
One of differences between Regions I and II is that the current is constantly lower than the current limit (upper limit) due to a condition on the maximum torque achievable in Region II. As a result, a stator flux amplitude for achieving the maximum torque is determined by the radius of the voltage limit circle in both of Regions I and IL
The entire image of the above-described control is illustrated in
However, a certain limit is placed on the upper limit of the stator flux command by the second block 18b. An achievable torque command is calculated by the torque command limit module 13 by using the stator flux command in accordance with Expressions (30) and (36). The achievable torque differs between the field weakening region I and the field weakening region II as described above.
According to the first embodiment above described, operation described below is achieved.
The first block 18a of the appropriate flux command generation module 18 calculates the stator flux command value λs_opt to be smaller as the power supply angular frequency ωe increases.
The second block 18b limits the stator flux command value λs_opt to a constant value at the rated flux (λrate) in a low speed range in which the power supply angular frequency ωe is small. However, the second block 18b places no limit in a high speed range in which the power supply angular frequency ωe is large. The second block 18b places no limit at least in a speed region equal to or higher than the field weakening starting point. Without the limit by the second block 18b, the stator flux command value λs_opt is calculated to be smaller as the power supply angular frequency ωe increases.
As understood from Expressions (30) and (36), the upper limit torque command value Te_max is calculated to be smaller as the stator flux command value λs_opt is smaller. The width between the upper limit torque value (+Te_max) and the lower limit torque value (−Te_max) decreases as the upper limit torque command value Te_max is smaller.
The torque command limit module 13 can calculate the upper limit torque command value Te_max to be smaller as the power supply angular frequency ωe increases in a somewhat high speed range. When the upper limit torque command value Te_max is calculated to be smaller, the width between the upper limit torque value (+Te_max) and the lower limit torque value (−Te_max) is set to be smaller.
Through such operation, the torque limiter range can be set to be smaller as the power supply angular frequency ωe increases at least in the field weakening regions I and II. An allowable torque range in which the control stability can be maintained tends to be smaller as the power supply angular frequency ωe increases. According to the first embodiment, the torque limiter range is dynamically adjusted in accordance with such a tendency.
Torque increase can be performed without degrading the control stability because a torque command value changes only in the torque limiter range adjusted to an appropriate range. Accordingly, when the motor is operated fast in a field weakening region, the control stability and the output torque increase can be simultaneously achieved.
In the first embodiment, Expression (30) of the first block 13a is applied at a speed lower than the boundary speed ωe_c. The upper limit torque command value Te_max can be changed at an appropriate tendency in accordance with the second-order polynomial of the stator flux command value λs_opt.
In the first embodiment, Expression (36) of the second block 13b is applied at a speed equal to or higher than the boundary speed ωe_c. The upper limit torque command value Te_max can be appropriately changed in accordance with the monomial of the second-order term (λs_opt2) of the stator flux command value at a tendency different from that of Expression (30).
Accordingly, the upper limit torque command value Te_max can be changed at an appropriate tendency in each of the field weakening regions I and II.
In the embodiment, the torque command limit module 13 includes the fifth block 13e. With this configuration, the upper limit torque command value Te_max calculated by the first block 13a and the upper limit torque command value Te_max calculated by the second block 13b can be selectively switched in accordance with the power supply angular frequency ωe.
In the first embodiment, the fourth block 13d is provided. With this configuration, the first block 13a, in other words, Expression (30) is applied in both of Region I and the normal operation region. Accordingly, calculation of the upper limit torque command value Te_max can be seamlessly performed through the normal operation region and the field weakening region.
In the first embodiment, the appropriate flux command generation module 18 includes the second block 18b. When Expression (29) is applied in a low speed range in which the power supply angular frequency ωe is small, the stator flux command value λs_opt is calculated to be excessively large. The second block 18b places an upper limiter to prevent the stator flux command value λs_opt from being calculated to be excessively large.
Next, an example of the controller is described with the use of
As illustrated in
For example, the processor 30a is a central processing unit (CPU), e.g., a central processing device, a processing device, a microprocessor, a microcomputer, a processor or a digital signal processor (DSP).
For example, the memory 30b is a non-volatile or volatile semiconductor memory such as RAM, ROM, flash memory, EPROM, EEPROM, or magnetic disk, flexible disk, optical disk, compact disk, mini-disk or DVD.
In the processing circuit, a program stored in the memory 30b is executed by the processor 30a.
In the second embodiment, the speed sensor 119 is omitted, and the speed and phase estimation module 21 is replaced with a speed and phase estimation module 121. In addition, the first slip angular frequency estimation module 32 is replaced by the second slip angular frequency estimation module 33. Any other configuration is the same as that of the first embodiment.
The speed and phase estimation module 121 as a motor speed estimation module calculates the rotor electrical angle estimated value {circumflex over (θ)}r and the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r based on the second torque command value Tem*, a slip frequency estimated value ωsl outputted from the second slip angular frequency estimation module 33, and the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS.
The second slip angular frequency estimation module 33 uses the second torque command value Tem* and the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS as input values to calculate the slip angular frequency estimation values {circumflex over (ω)}sl based on Equation (44). The slip angular frequency estimated value {circumflex over (ω)}sl is inputted to the speed/phase estimation module 121 and the power supply angular frequency calculation module 19.
As illustrated in
The current observation module 22 calculates a stator dqs-axes current estimated value îqdss in a subsequent control period based on the voltage command value VqdsS*, the stator dqs-axes current measured value iqdss, a rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r and a rotor dqs-axes flux estimated value λqdrS.
The stator dqs-axes current measured value iqdss is the output of the second coordinate conversion module 17. The rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r is an output of the speed/phase estimation module 121. The rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS is an output of the second flux estimation module 24. The voltage command value VqdsS* is an output from the DB-DTFC calculation module 14.
On this occasion, the proportional gain K3, the integral gain K4, the estimated value {circumflex over (R)}eq of the equivalent resistance, the estimated value {circumflex over (L)}r of the rotor winding inductance, the estimated value {circumflex over (L)}m of the magnetizing inductance, the rotor resistance {circumflex over (R)}r and the imaginary number j, the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r, the equivalent time constant τeq, the control period T and the delay operator z−1 are used.
Specifically, the current observation module 22 includes a first block 22a, a second block 22b, a third block 22c, a fourth block 22d, a fifth block 22e, a sixth block 22f, and a seventh block 22g.
The first block 22a calculates a value obtained by subtracting the stator dqs-axes current estimated value îqdss from the stator dqs-axes current measured value iqdss. The stator dqs-axes current estimated value îqdss is the output of the seventh block 22g.
The output of the first block 22a is inputted into the second block 22b and the third block 22c. The second block 22b is a proportional circuit of gain K3. The third block 22c is an integrating circuit of gain K4. The fourth block 22d calculates a complemented value from a rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r and a rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS. The rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r is an output of the speed/phase estimation module 121. The rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS is an output of the second flux estimation module 24.
The fourth block 22d calculates a value obtained by multiplying the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS by the transfer coefficient G1 expressed by the following Expression (37).
The fifth block 22e calculates a value obtained by adding the voltage command value VqdsS*, the value calculated by the second block 22b, the value calculated by the third block 22c, the value calculated by the fourth block 22d.
The sixth block 22f calculates a value obtained by dividing the value calculated by the fifth block 22e by the estimated value {circumflex over (R)}eq of the equivalent resistance.
The output of the sixth block 22f is input into the seventh block 22g. The seventh block 22g calculates a transfer function expressed in the Expression (38). The seventh block 22g outputs a stator dqs-axes current estimated value îqds.
The stator dqs-axes current estimated value îqdss is input into the first block 22a and the second flux estimation module 24.
The first flux estimation module 23 calculates a rotor dqs-axes flux estimated value λqdrS* based on the rotor electrical angle estimated value {circumflex over (θ)}r and the stator dqs-axes current measured value iqdss. The rotor electrical angle estimated value {circumflex over (θ)}r is an output of the speed/phase estimation module 121. The stator dqs-axes current measured value iqdss is an output of the second coordinate conversion module 17.
On this occasion, the estimated value {circumflex over (L)}m of the magnetizing inductance of the motor 2, the rotor time constant τr of the motor 2, the control period T and the delay operator z−1 are used.
Specifically, the first flux estimation module 23 includes a first block 23a, a second block 23b, and a third block 23c.
The first block 23a converts the stator dqs-axes current measured value iqdss to the value of the rotor coordinate system by the rotor electrical angle estimated value {circumflex over (θ)}r.
The output of the first block 23a is the input of the second block 23b.
The second block 23b multiplies the value calculated by the first block 23a by the transfer function G3 expressed by the following Expression (39) to calculate the stator dqs-axes flux estimated value of the primary hold.
The output of the second block 23b is the input of the third block 23c.
The third block 23c converts the output of the second block 23b to the value of the rotor coordinate system by the rotor electrical angle estimated value {circumflex over (θ)}r. The output of the second block 23b is the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS*. The rotor dqs-axes flux estimated value λqdrS* is inputted into second flux estimation module 24.
The second flux estimation module 24 calculates a stator dqs-axes flux estimated value {circumflex over (λ)}qdsS and a rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS in a subsequent control period based on the voltage command value VqdsS* outputted from the DB-DTFC calculation module 14, the stator dqs-axes current measured value iqdss output of the second coordinate conversion module 17, the stator dqs-axes current estimated value îqdss estimated by the current observation module 22, the rotor dqs-axes flux estimated value λqdrS* estimated by the first flux estimation module 23.
On this occasion, the proportional gain K1, the integral gain K2, the estimated value {circumflex over (R)}s of the stator resistance, the leakage factor σ, the estimated value {circumflex over (L)}r of the rotor winding inductance, the estimated value of {circumflex over (L)}s of the stator winding inductance, the estimated value {circumflex over (L)}m of the magnetizing inductance, the control period T and the delay operator z−1 are used.
Specifically, the second flux estimation module 24 includes a first block 24a, a second block 24b, a third block 24c, a fourth block 24d, a fifth block 24e, a sixth block 24f, a seventh block 24g, and an eighth block 24h, a ninth block 24i, and a tenth block 24j.
The first block 24a calculates a value of the voltage drop by multiplying the stator dqs-axes current measured value iqdss by the estimated value {circumflex over (R)}s of the stator resistance.
The second block 24b subtracts the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS which is the output of the tenth block 24j from the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS*.
The third block 24c calculates a value obtained by subtracting the value calculated by the first block 24a from the voltage command value VqdsS*.
The fourth block 24d, the fifth block 24e, and the sixth block 24f function as a transition frequency determination unit 24k. The transition frequency determining unit 24k determines the transition frequency between the first flux estimation module 23 and the second flux estimation module 24.
Specifically, the fourth block 24d calculates a value obtained by multiplying the value calculated by the second block 24b by the proportional gain K1.
The fifth block 24e is an integrating circuit of gain K2. The fifth block 24e calculates an integral of the output of the fourth block 24d.
The sixth block 24f calculates a value of the input voltage of the motor 2 by adding the value calculated by the third block 24c, the value calculated by the fourth block 24d and the value calculated by the fifth block 24e.
The seventh block 24g calculates the stator dqs-axes flux estimated value {circumflex over (λ)}qdsS by integrating the output of the sixth block 24f.
The eighth block 24h calculates a value obtained by multiplying the stator dqs-axes current estimated value îqdss by the factor G4 expressed by the following Expression (40).
G4=σ{circumflex over (L)}s (40)
The ninth block 24i calculates a value obtained by subtracting the value calculated by the eighth block 24h from the stator dqs-axes flux estimated value {circumflex over (λ)}qdsS calculated by the seventh block 24g.
The tenth block 24j multiplies the value calculated by the ninth block 24i by the factor G5 expressed by the following Expression (41) to calculate the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS.
For example, in the case where the frequency of the rotor flux of the motor 2 is lower than the transition frequency, the first flux estimation module 23 is dominant. For example, in the case where the frequency of the rotor flux of the motor 2 is higher than the transition frequency, the second flux estimation module 24 is dominant. As a result, the rotor dqs-axes flux estimated value is accurately calculated.
The speed/phase estimation module 21 includes a phase estimation module 25, a slip angle estimation module 26, a flux vector rotation module 27, a phase error estimation module 28 and a speed and position observing module 29.
The phase estimation module 25 calculates an estimated value ejθ
In particular, the phase estimation module 25 calculates an estimated value ejθ
Although the power phase can be calculated by using any one of the stator flux {circumflex over (λ)}qds and the rotor flux {circumflex over (λ)}qdr in the Expression (42), the stator flux is used for the estimation in the first embodiment. In the Expression (42), the suffix “*”, i.e. an asterisk, is “s” when a calculation is done using the stator flux {circumflex over (λ)}qds. On the other hand, in the Expression (42), the suffix “*” is “r” when a calculation is done using the rotor flux {circumflex over (λ)}qdr.
An estimated value {circumflex over (ω)}sl of a slip frequency of the motor 2 is calculated by the second slip angular frequency estimation module 33. The estimated value {circumflex over (ω)}sl of the slip frequency is inputted to the slip angle estimation module 26.
The slip angle estimation module 26 calculates a slip angle estimated value {circumflex over (θ)}sl. The slip angle estimated value {circumflex over (θ)}sl is calculated by integrating the estimated value {circumflex over (ω)}sl of the slip frequency. The sine and cosine of the slip angle estimated value {circumflex over (θ)}sl is calculated by the sine/cosine calculation unit 27a and is inputted to the flux vector rotation module 27.
The flux vector rotation module 27 calculates a first rotor electrical angle estimated value {circumflex over (θ)}r1 based on the estimated value ejθ
The sine and cosine of the rotor electric angle estimated value {circumflex over (θ)}r is calculated by the sine/cosine calculation unit 28a. The calculated values of the sine and cosine of the rotor electric angle estimated value {circumflex over (θ)}r are inputted to the phase error estimation module 28.
The phase error estimation module 28 performs additive theorem operation by using the two rotor electrical angles calculated by the flux vector rotation module 27 and the speed and position observing module 29. The estimated value {circumflex over (θ)}err of rotor electrical angle error is calculated by using approximation of sin Δθ≈Δθ when Δθ is minute.
The speed and position observing module 29 calculates rotor mechanical angular estimated values {circumflex over (ω)}rm-r and {circumflex over (ω)}rm-r, a mechanical angle estimated value {circumflex over (θ)}rm, electrical angle estimated value {circumflex over (θ)}r based on the estimated value {circumflex over (θ)}err calculated by phase error estimation module 28.
Specifically, the speed and position observing module 29 includes a first block 29a, a second block 29b, a third block 29c, a fourth block 29d, a fifth block 29e, a seventh block 29f, an eighth block 29g, and a ninth block 29h and a tenth block 29i.
The first block 29a is an integrating circuit of gain Kio. The first block 29a calculates an integral of the estimated value {circumflex over (θ)}err calculated by phase error estimation module 28. The second block 29b corrects the estimated value {circumflex over (θ)}err estimated by the phase error estimation module 28 by multiplying the estimated value {circumflex over (θ)}err estimated by the phase error estimation module 28 and the gain Kso.
The third block 29c multiples the estimated value {circumflex over (θ)}err estimated by the phase error estimation module 28 and the gain bo.
The fourth block 29d calculates a value obtained by adding the value calculated by the first block 29a and the value calculated by the second block 29b.
The fifth block 29e calculates a value obtained by adding the value calculated by the fourth block 28d and the torque command value Tem*, and outputs the calculated value to the sixth block 29f. The sixth block 29f divides the input value by the estimated value Ĵp of moment of inertia and outputs it to the seventh block 29g.
The seventh block 29g calculates a rotor mechanical angular speed estimated value {circumflex over (ω)}rm-l. The seventh block 29g is an integrating circuit. The seventh block 29g calculates an integral of the output of the sixth block 29f.
The eighth block 29h calculates the speed correction value by dividing the value calculated by the third block 29c by the estimated value Ĵp of the moment of inertia.
The ninth block 29i calculates a rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r by adding the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-l calculated by the seventh block 29g and the speed correction value obtained by the eighth block 29h.
The tenth block 29j calculates a rotor mechanical angle estimated value {circumflex over (θ)}rm. The tenth block 29j is an integrating circuit. The seventh block 29g calculates an integral of the rotor mechanical angular speed estimated value {circumflex over (ω)}rm-r
The eleventh block 29k calculates the rotor electrical angle estimated value {circumflex over (θ)}r by dividing the value obtained by multiplying the rotor mechanical angle estimated value {circumflex over (θ)}rm calculated by the tenth block 29j by the number of poles P of the motor 2 by 2.
The system according to the second embodiment is a sensor-less system including no speed sensor, and has a self-estimation function of estimating, for example, a speed by using various parameters in the system. The self-estimation function is also referred to as “self-sensing”.
As described above in the first embodiment, the output torque can be increased by selecting a combination of stator flux command vectors in a field weakening region. This allows fast operation when the load torque is large, and accordingly, leads to increase of the field weakening region. The present section describes discussions related to the field weakening region increase by the self-sensing.
In the system according to the second embodiment illustrated in
In addition, a slip angular frequency is input to the speed and phase estimation module 121. Estimation of the slipping angular frequency can be performed by using one of the stator flux estimated value and the rotor flux estimated value. Thus, either the stator flux estimated value or the rotor flux estimated value can be optionally selected as an input value used in the speed estimation and the slipping angular frequency estimation.
The speed and position observation module 29 in the speed and phase estimation module 121 illustrated in
The slipping angular frequency calculated based on the stator flux is expressed by Expression (43). The slipping angular frequency calculated based on the rotor flux is expressed by Expression (44).
When the power supply phase ejθ
It should be noted that, in the Expression (43), a superscript symbol “es” of each sign represents a synchronous coordinate system developed with the stator flux as a reference. The stator flux value λqss of the stationary coordinate system is a sine wave signal, and the development is done based on the stator flux as a reference.
In the synchronous coordinate system, the origin of the coordinate system is reset in each control cycle so as to ensure λqses=0. Thereby, other signals are also converted accordingly. The advantageous effect of this coordinate transformation is that specific calculations can be easier.
The rotor flux has less noise than the stator flux. This is because the rotor flux is less affected by a high frequency component included in voltage due to PWM. This will be described below by using Expression (45) as a stator flux equation and Expression (46) as a rotor flux equation.
The stator flux receives an input of voltage as indicated in Expression (45). Thus, the stator flux is directly affected by a high frequency component of voltage due to PWM. However, this influence on the rotor flux is reduced by a filter. This filter effect will be described below.
Expression (46) is provided with Laplace transform and rewritten by replacing coefficients of the stator flux and the rotor flux on the right hand side with A and B, respectively.
Finally, Expression (47) below is derived.
As understood from Expression (47), the rotor flux is equivalent to flux obtained by applying a low pass filter to the stator flux. The rotor flux is a value obtained based on the stator flux, and the stator flux is affected by a high frequency component of voltage. However, influence of voltage noise on the rotor flux is reduced by the above-described low pass filter effect.
When the flux amplitude is reduced by field weakening, the S/N ratio degrades. Additionally, in self-sensing in which the stator flux is used in phase estimation, control is likely to be unstable as compared to a case in which the rotor flux is used. This is because the stator flux is directly affected by a high frequency component of voltage.
The above-described low pass filter effect is achieved by the eighth block 24h, the ninth block 24i, and the tenth block 24j, in particular, among the blocks of the second flux estimation module 24 illustrated in
The vertical axis in
The estimated torque is calculated by multiplying the stator flux estimated value and the rotor flux estimated value. As shown in
This performance depends on a bandwidth obtained by internal proportional integral gain of each observer. Suppressing the bandwidth at relatively low level makes it possible that a high frequency band noise component is not included in the estimated speed. In the field weakening operation, it is preferable to set the bandwidth of the speed and phase estimation module 121 to be relatively low to reduce noise included in the estimated speed. A speed (phase) for self-sensing can be calculated from various waveforms of current, voltage, and flux, for example.
The second embodiment above described includes at least two characteristic configurations.
The first characteristic configuration is the speed and phase estimation module 121. This configuration achieves a sensor-less system equivalent to the system according to the first embodiment. The sensor-less configuration provides a technological advantage such as the torque limit adjustment in a field weakening region achieved according to the first embodiment, and allows any speed sensor to be omitted.
The second characteristic configuration is the usage of the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS as an input value to the speed and phase estimation module 121. The speed and phase estimation module 121 calculates an estimated value of a speed of the motor in a subsequent control period based on the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS.
A rotor flux estimated value contains less noise than a stator flux estimated value, which leads to highly accurate calculation of the estimated speed value. As a result, the effect of increasing a field weakening region can be achieved in the self-sensing of the sensor-less system.
The stator dqs-axes flux estimated value {circumflex over (λ)}qdsS outputted from the current and flux estimation module 20 and the stator dqs-axes current measured value iqdss outputted from the second coordinate conversion module 17 are inputted to the first slip angular frequency estimation module 32. The first slip angular frequency estimation module 32 performs a calculation based on Expression (43) by using the above inputted values to calculate the slip angular frequency estimated value {circumflex over (ω)}sl_s.
The second torque command value Tem* and the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS are inputted to the second slip angular frequency estimation module 33.
The second slip angular frequency estimation module 33 performs a calculation based on Expression (44) by using the above inputted values to calculate the slip angular frequency estimated value {circumflex over (ω)}sl_r.
The switching block 122 selectively transmits one of the estimated value selected from the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS and the stator dqs-axes flux estimated value {circumflex over (λ)}qdsS to the speed and phase estimation module 121.
The switching block 123 selectively transmits one of the estimated value selected from the slip angular frequency estimated value {circumflex over (ω)}sl_s outputted from the first slip angular frequency estimation module 32 and the slip angular frequency estimated value {circumflex over (ω)}sl_r outputted from the second slip angular frequency estimation module 33 to the speed and phase estimation module 121.
The switching block 122 works together with the switching block 123.
When the switching block 122 selects the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS, the switching block 123 selects the slip angular frequency estimated value {circumflex over (ω)}sl_r outputted from the second slip angular frequency estimation module 33.
On the other hand, when the switching block 122 selects the stator dqs-axes flux estimated value {circumflex over (λ)}qdsS, the switching block 123 selects the slip angular frequency estimated value {circumflex over (ω)}sl_s outputted from the first slip angular frequency estimation module 32.
The criterion by which the switching block 122 and the switching block 123 switch the above estimated values may be predetermined.
For example, the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS may be selected if the power supply angular frequency ωe is equal to or higher than a predetermined value. For example, the stator dqs-axes flux estimated value {circumflex over (λ)}qdsS may be selected if the power supply angular frequency ωe is lower than the predetermined value.
The modification illustrated in
The controller 11 according to the second embodiment may be achieved by using the structure illustrated in the hardware configuration diagram in
The noise is normalized to 1 when the flux is 1 pu. The noise increases to 13 approximately when the flux becomes near 0.1 pu.
The formula of the noise is rms ({circumflex over (ω)}r−{circumflex over (ω)}avg). In the formula, {circumflex over (ω)}r represents an instantaneous speed at each sampling point, and {circumflex over (ω)}avg represents an average speed between sampling points.
It is preferable to reduce influence of noise at low amplitude flux (that is, in a high speed range). To achieve this, it is preferable to set controller gains bo, Kso, and Kio to be low when rotor flux base speed estimation is performed by the speed and phase estimation modules 21, 121 illustrated in
In
Decrease of the controller gains bo, Kso, and Kio is equivalent to decrease of the cutoff frequency of the filter. Accordingly, noise in a high frequency component included in a rotor flux input of an observer can be reduced.
The torque command limit module 13, the appropriate flux command generation module 18, and the power supply angular frequency calculation module 19, which are provided in the first and second embodiments, are omitted in the motor system according to the third embodiment. Any other configuration is the same as that of the second embodiment.
A value input to the DB-DTFC calculation module 14 is changed due to the configuration omission. In place of the second torque command value Tem*, the first torque command value Tem1* calculated by the speed control module 12 is input to the DB-DTFC calculation module 14. In place of the stator flux command value λs_opt generated by the appropriate flux command generation module 18, the rated stator flux λrate is input to the DB-DTFC calculation module 14.
Since the torque command limit module 13 and the like are omitted, the advantage of “operation at high power in a wider frequency range”, which is achieved in the first embodiment, is restricted in the third embodiment as compared with the first embodiment.
However, similarly to the second embodiment, the speed and phase estimation module 121 is provided and an input value to the speed and phase estimation module 121 is the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS in the third embodiment. Thus, the effects of “improvement of calculation accuracy of the estimated speed value and sensor-less field weakening region increase by the use of the rotor flux”, which are the same as those of the second embodiment, can be obtained in the third embodiment.
The configuration shown in
However, the configuration in the third embodiment can be implemented not only in the DB-DTFC method but also in a Field Oriented Control method. Field Oriented Control method is also referred to as FOC method hereinafter.
The FOC method is a method in which a current component for generating a torque (rotational force) and a current component for generating a flux are separated from each other, and each current component is independently controlled as a direct current amount.
One of FOC methods is DFOC (Direct Field Oriented Control) method. DFOC method is a method of directly estimating and controlling the flux vector by a flux sensor or a flux observer.
Another one of the FOC methods is IFOC (Indirect Field Oriented Control) method. The IFOC method uses indirect type vector control (also called slip frequency type vector control) that controls a slip of an induction machine regardless of flux estimation or flux detection.
In the modification shown in
The controller 11 includes a third coordinate conversion module 17a and a fourth coordinate conversion module 17b. The v-phase stator current Ivs and the w-phase stator current Iws are inputted to the third coordinate conversion module 17a.
The three phase stator voltage command value Vus*, Vvs*, and Vws*, which is outputted from the fifth coordinate conversion module 15a, is inputted to the fourth coordinate conversion module 17b.
The first torque command value Tem1* calculated by the speed control module 12 is inputted to the DFOC calculation module 314 in the system according to DFOC method shown in
With respect to a flux command, although the rated flux value λrate is inputted to the DFOC calculation module 314 as the stator flux command value λs*, other system based on DFOC method may perform a control based on the rotor flux command value {circumflex over (λ)}qdrS* instead of the stator flux command value λs*. Since the rotor flux command value {circumflex over (λ)}qdrS* can be calculated from of the stator flux command value λs*, only the stator flux command value λs* is illustrated in
The speed and phase estimation module 121 inputs the stator power supply phase estimated value {circumflex over (θ)}e as a reference signal to the third coordinate conversion module 17a and the fifth coordinate conversion module 15a.
On the basis of the reference signal, the third coordinate conversion module 17a converts the input signal to a signal of the rotating coordinate system of γ and δ components orthogonal to each other.
By appropriately selecting the phase of the reference signal, it is possible to make the γ component in-phase with the reference and to make the 8 component orthogonal to the reference.
The third coordinate conversion module 17a performs a coordinate conversion to obtain a γ-axis stator current iγ and a δ-axis stator current iδ, and outputs the current values to the DFOC calculation module 314.
Conversely to the above, the fifth coordinate conversion module 15a converts the voltage command value Vγ* of the γ component and the voltage command value Vδ* of the δ component, which are outputs from the DFOC calculation module 314, to the three-phase stator voltage command values Vus*, Vvs*, and Vws*. The output from the fifth coordinate conversion module 15a is inputted to the PWM control module 16 and the fourth coordinate conversion module 17b.
The fourth coordinate conversion module 17b converts the inputted three-phase stator voltage command values Vus*, Vvs*, and Vws* which are values in fixed coordinate system to the voltage command value VqdsS* of two-axes components of dqs-axes. The converted values by the fourth coordinate conversion module 17b are inputted to the current and flux estimation module 20.
The stator flux estimated value {circumflex over (λ)}qdss and the rotor flux estimated value {circumflex over (λ)}qdrs estimated by the current and flux estimation module 20 are inputted to the DFOC calculation module 314.
The DFOC calculation module 314 internally generates a stator current command value of they component and a stator current command value of the δ component based on the inputted values, and generates the voltage command value Vγ* of the γ component and the voltage command value Vδ* of they component so that the γ-axis stator current iγ and the δ-axis stator current iδ follow the command values.
The voltage command value Vγ* of the γ component and the voltage command value Vδ* are inputted to the fifth coordinate conversion module 15a.
The voltage command value Vγ* of they component and the voltage command value Vδ* re transmitted to the inverter 8 as gate pulses via the PWM control module 16.
Since the torque command limit module 13 and the like are omitted, the advantage of “operation at high power in a wider frequency range”, which is achieved in the first embodiment, is restricted in the modification of the third embodiment as compared with the first embodiment.
However, similarly to the second embodiment, the speed and phase estimation module 21 is provided and an input value to the speed and phase estimation module 21 is the rotor dqs-axes flux estimated value {circumflex over (λ)}qdrS in the third embodiment. Thus, the effects of “improvement of calculation accuracy of the estimated speed value and sensor-less field weakening region increase by the use of the rotor flux”, which are the same as those of the second embodiment, can be obtained in the third embodiment.
It should be noted that, although the DB-DFTC calculation module 14 is replaced with the DFOC calculation module 314 in the modification in
The controller 11 according to the third embodiment can be achieved by using the structure illustrated in the hardware configuration diagram in
The features and advantages of the present disclosure (or embodiments) may be summarized as follows.
In the first controller for a power convertor according to the first aspect of the present disclosure, the upper limit torque value is calculated to be smaller as the fundamental wave output frequency of output from the power convertor increases in a field weakening region. In other words, the torque limiter range is set to be smaller as the fundamental wave output frequency increases. The range of the torque command value for maintaining control stability tends to be smaller in a faster operation region in which the fundamental wave output frequency is larger. The torque limiter range is dynamically adjusted in accordance with this tendency. The torque command value changes only in the adjusted torque limiter range, and thus torque increase can be achieved without losing the control stability. As a result, the control stability and the output torque increase can be simultaneously achieved.
According to the second controller for a power convertor according to the second aspect of the present disclosure, the estimated value of the rotor flux is used in calculation. The estimated value of the rotor flux includes less noise than the estimated value of the stator flux, and thus the estimated speed value can be highly accurately calculated with less ripple. The torque command value has less ripple.
According to the third aspect of the present disclosure, the motor driving system including the first controller for a power convertor according to the first aspect can simultaneously achieve the control stability and the output torque increase when the motor is operated fast in the field weakening region. The motor driving system including the second controller for a power convertor according to the second aspect can highly accurately calculate the estimated speed value.