Variable speed drive for the sensorless PWM control of an AC motor by exploiting PWM-induced artefacts

Information

  • Patent Grant
  • 11264935
  • Patent Number
    11,264,935
  • Date Filed
    Thursday, September 24, 2020
    4 years ago
  • Date Issued
    Tuesday, March 1, 2022
    2 years ago
Abstract
A variable speed drive comprises an output for delivering a drive voltage to an electric motor, power inverter, a drive controller, and a current sensor. The drive controller includes a PWM generator, a control law module, and a state variable estimator for estimating a state variable of the electric motor. The module computes a target voltage signal based on state variable estimates provided by the estimator and outputs the target voltage signal to the PWM generator. The generator approximates the target voltage signal with a PWM control signal, controls the inverter using the control signal, computes, based on the deviation between the control signal and the target voltage signal, an estimation support signal, and outputs the estimation support signal to the estimator. The estimator estimates a state variable of the motor based on the estimation support signal and the drive current, and outputs the estimate to the module.
Description
TECHNICAL FIELD

This disclosure generally pertains to the field of motor control. More precisely, it relates to Variable Speed Drives (VSDs), which are used to control the operation of Alternating Current (AC) electric motors. The focus is on VSDs that rely on Pulse-Width Modulation (PWM) to have continuous control over the speed of the controlled AC motor.


VSDs are typically used as industrial drives in factories, installations, HVAC systems and the like to control e.g. the position, speed and/or torque of an electric motor that is dedicated to a particular task, such as e.g. the operation of a fan or the hoisting of a load.


BACKGROUND ART

In order to perform a closed-loop control of an AC motor, a VSD needs to have real-time information on the operating status of the AC motor. This information might for example be the instantaneous angular position and/or angular velocity of the motor's rotor.


The VSD may obtain this information from dedicated sensors, which are arranged on the motor and monitor the motor's operating status. However, fitting an electric motor with such sensors adds to the complexity and size of the whole drive assembly. The required sensors and sensor cabling also increase the price and reduce the reliability.


This is why so-called “sensorless” VSDs have become more and more common. In these sensorless VSDs, the motor's operating status is estimated on the basis of measurements of the motor's drive current. No additional external sensors are used. In order to improve the estimations, in particular when the motor operates at low velocity, it is a standard procedure to inject an external high-frequency probing signal into the motor's drive voltage.


The article “Adding virtual measurements by signal injection” by Pascal Combes et al., published in 2016 in the proceedings of the 2016 American Control Conference on pages 999 ff., conceptualizes and generalizes the signal injection technique for the sensorless control of electric motors at low speed.


Signal injection is an effective method, but it comes at a price: the ripple it creates may in practice yield unpleasant acoustic noise and excite unmodeled dynamics. In particular, in the very common situation where the electric motor is fed by a PWM inverter, the frequency of the injected probing signal may not be as high as desired so as not to interfere with the PWM (typically, it cannot exceed 500 Hz in an industrial drive with a 4 kHz-PWM frequency).


The article “A novel approach for sensorless control of PM machines down to zero speed without signal injection or special PWM technique” by C. Wang et al., IEEE Transactions on Power Electronics, Vol. 19, No. 6, November 2004, pages 1601 ff., proposes to measure the phase current ripples induced by conventional PWM to derive the rotor position and speed of a PWM-controlled electric motor. However, this approach is based on the measurement of current derivatives, which requires specialized current sensors and is sensitive to noise.


SUMMARY

In view of the above, it is an object of the present disclosure to provide a PWM-based variable speed drive with an improved sensorless AC motor control without signal injection.


According to the present disclosure, this object is achieved with a variable speed drive for the closed loop control of the operation of an AC electric motor based on a given control law, the variable speed drive comprising:

    • an output terminal for delivering a controlled alternating drive voltage to the controlled AC electric motor;
    • a solid-state power inverter for generating the drive voltage;
    • a drive controller for controlling the generation of the drive voltage by the power inverter; and
    • a drive current sensing device for measuring the instantaneous intensity of the drive current taken up by the controlled AC electric motor, and for providing the resulting measurements as a drive current intensity signal to the drive controller,


      wherein the drive controller includes:
    • a pulse-width modulation generator;
    • a control law module storing the given control law; and
    • a state variable estimation module for estimating the instantaneous value of at least one state variable of the controlled AC electric motor,


      wherein the control law module is adapted to, based on the stored control law and state variable estimates provided by the estimation module, compute a target voltage signal and output the computed target voltage signal to the pulse-width modulation generator,


      wherein the pulse-width modulation generator is adapted to:
    • approximate the received target voltage signal with a pulse-width modulated inverter control signal;
    • control the operation of the power inverter using the inverter control signal, thereby obtaining the drive voltage;
    • compute, based on the deviation between the inverter control signal and the target voltage signal, a state variable estimation support signal; and
    • output the computed state variable estimation support signal to the state variable estimation module, and


      wherein the state variable estimation module is adapted to:
    • estimate the instantaneous value of a state variable of the AC electric motor based on the received state variable estimation support signal and the drive current intensity signal provided by the drive current sensing device; and
    • output the resulting state variable estimate to the control law module.


By modifying the PWM generator so that it computes an estimation support signal based on the PWM, and by providing this estimation support signal to the state variable estimator, the state variable estimator has supplementary information, which it can use to improve its state variable estimations.


Optionally, the variable speed drive according to the present disclosure can have the following features, separately or in combination one with the others:

    • the pulse-width modulation generator is adapted to compute the state variable estimation support signal based on a pulse-width modulation inherent disturbance signal, which is obtained by subtracting the target voltage signal from the inverter control signal;
    • the pulse-width modulation generator is adapted to compute the state variable estimation support signal by integrating the disturbance signal to obtain the primitive of the disturbance signal;
    • the variable speed drive is adapted to rely on a single feedback to perform closed loop control of the AC electric motor, namely the drive current intensity signal provided by the drive current sensing device;
    • the variable speed drive is adapted to control the operation of the AC electric motor without the injection of a dedicated probing signal into the drive voltage;
    • the drive controller further includes an analog-to-digital converter for converting the drive current intensity signal into a digital signal prior to its input into the state variable estimation module;
    • the state variable estimation module is adapted to estimate the instantaneous value of the rotor position of the electric motor based on the received state variable estimation support signal and the drive current intensity signal provided by the drive current sensing device;
    • the pulse-width modulation generator is adapted to apply three-phase pulse-width modulation with single carrier to generate the inverter control signal;
    • the pulse-width modulation generator is adapted to apply three-phase pulse-width modulation with interleaved carriers to generate the inverter control signal.


According to a further aspect, the present disclosure also relates to an electric drive assembly comprising a synchronous reluctance motor or a permanent-magnet synchronous motor and a variable speed drive as defined above for controlling the motor.


According to yet a further aspect, the present disclosure also relates to a method of controlling, in a closed loop, the operation of an AC electric motor based on a given control law, the method comprising the following steps:

  • a) measuring the instantaneous intensity of the drive current taken up by the controlled AC electric motor;
  • b) estimating the instantaneous value of a state variable of the AC electric motor using the measured drive current intensity;
  • c) computing, based on the given control law and the estimated state variable, a target voltage signal;
  • d) approximating the computed target voltage signal with a pulse-width modulated inverting control signal;
  • e) computing, based on the deviation between the inverting control signal and the target voltage signal, a state variable estimation support signal;
  • f) generating, by voltage inversion, a controlled alternating drive voltage using the inverting control signal; and
  • g) delivering the generated drive voltage to the controlled AC electric motor;


    wherein the state variable estimation according to step b) relies on the state variable estimation support signal computed in step e) as an additional input together with the drive current intensity measured in step a).





BRIEF DESCRIPTION OF DRAWINGS

Other features, details and advantages will be shown in the following detailed description and in the figures, in which:



FIG. 1 is a block diagram of an electric drive assembly of the present disclosure, with a variable speed drive and an AC electric motor.



FIG. 2 is a block diagram illustrating the signal flow and processing in the electric drive assembly of FIG. 1, and FIGS. 3 through 22 illustrate example graphs.





DESCRIPTION OF EMBODIMENTS
I. Exemplary Setup of a Variable Speed Drive According to the Present Disclosure


FIG. 1 is a schematic diagram of an electric drive assembly 100 according to the present disclosure. The electric drive assembly 100 comprises a variable speed drive, or VSD, 200 and an AC electric motor 300.


The electric drive assembly 100 may be used in diverse industrial settings. For example, it may drive a fan of a heating, ventilation and air conditioning (HVAC) system. As another example, it may also be used to drive a water pump of a sewage installation. Many other industrial applications can be envisaged by the skilled person.


Preferably, the AC electric motor 300 is a synchronous motor, such as a permanent magnet synchronous motor, or PMSM, or a synchronous reluctance motor, or SynRM.


The purpose of the variable speed drive 200 is to control the proper operation of the electric motor 300. Thanks to the variable speed drive 200, the motor 300 can be operated at the right speed at the right time, depending on the application. The variable speed drive 200 may also allow to control the torque output of the electric motor 300 to its load.


The variable speed drive 200 controls the electric motor 300 in a closed loop. This means that the variable speed drive 200 constantly receives feedback on the instantaneous status of the motor 300 during the control of the motor. The variable speed drive 200 adjusts its control of the electric motor 300 based on a given control law. The specifics of the control law depend on the type of application of the electric motor 300.


With reference to FIG. 1, the variable speed drive 200 comprises an output terminal 210, a solid-state power inverter 220, a drive controller 230, and a drive current sensing device or current sensor 240.


The variable speed drive 200 is electrically connected to the electric motor 300 via its output terminal 210. The power output 210 delivers a controlled alternating drive voltage upwm to the AC electric motor 300. The drive voltage upwm is a modulated signal whose amplitude is determined by the DC voltage Vbus applied to the power inverter 220. The modulation frequency of the drive voltage upwm depends on the switching frequency of the power inverter 220. The modulated drive voltage upwm emulates an ideal sinusoidal drive voltage whose amplitude and frequency determine the operation of the electric motor 300.


The power inverter 220 generates the drive voltage upwm by chopping up a DC voltage with the help of solid-state switches T1, T2.


The skilled person will note that the diagram of FIG. 1 shows a single phase control. This is only for simplification. Typically, the electric motor 300 will be a three-phase motor. In this case, the power inverter 220 generates a drive voltage for each of the three phases of the motor.


The current sensor 240 of the VSD 200 measures the instantaneous intensity of the drive current taken up by the electric motor 300. The current sensor 240 provides its measurements as a drive current intensity signal is to the drive controller 230.


According to the present disclosure, the motor control by the VSD 200 is a so-called “sensorless” control. This means that the control feedback entirely relies on the current measurements provided by the current sensor 240. There are no external sensors mounted on the motor 300, such as shaft encoders and the like, to provide feedback to the VSD 200 on the motor status.


The drive controller 230 controls the generation of the drive voltage upwm by the power inverter 220. This is done on the basis of an inverter control signal M provided by the drive controller 230 to the power inverter 220.


The drive controller 230 may be implemented as a microcontroller or a field programmable gate array (FPGA).


According to the present disclosure, the drive controller 230 includes a pulse-width modulation, or PWM, generator 232, a control law module 234 storing the given control law, a state variable estimation module 236, and an analog to digital converter, or ADC, 238.


The control law module 234 is adapted to, based on the stored control law and state variable estimates z0 to zn provided by the estimation module 236, compute a target voltage signal us and output the computed target voltage signal us to the PWM generator 232.


The target voltage signal us represents the analog voltages that must be applied to the stator windings of the electric motor 300 to obtain the desired speed or torque from the motor 300.


Since the variable speed drive 200 relies on pulse-width modulation, the target voltage signal us is not directly applied to the electric motor 300. Rather, it is fed to the PWM generator 232 to be approximated by the pulse-width modulated inverter control signal M, which in turn is used to control the power inverter 220.


The pulse-width modulation generator 232 may apply three-phase pulse-width modulation with single carrier to generate the inverter control signal M (i.e. the approximation of the target voltage signal us).


Alternatively, the PWM generator may also apply three-phase pulse-width modulation with interleaved carriers to generate the inverter control signal M.


The PWM generator 232 may of course also use other PWM schemes to generate the inverter control signal M.


According to the present disclosure, the PWM generator 232 has the particularity that it computes, based on the deviation between the inverter control signal M and the target voltage signal us, a state variable estimation support signal s1, and outputs the computed state variable estimation support signal s1 to the state variable estimation module 236.


The state variable estimation module or estimator 236 estimates the instantaneous value of one or more state variables of the AC electric motor 300 based on the drive current intensity signal is provided by the drive current sensor 240.


As shown in FIGS. 1 and 2, the estimator 236 may estimate several state variables z0 to zn. These state variables may e.g. correspond to the rotor position of the electric motor, the angular velocity of the motor's rotor, etc.


According to the present disclosure, the estimator 236 also uses the estimation support signal s1 to estimate the value of at least one of the state variables z0 to zn.


The estimator 236 provides the state variable estimates z0 to zn to the control law module 234. The control law module 234 uses these estimates in the stored control law in order to determine the target voltage signal us.


As shown in the figures, the drive controller 230 may also include an analog to digital converter 238. The purpose of the ADC 238 is to convert the analog current signal is provided by the current sensor 240 into a digital signal that can be processed by the estimator 236.



FIG. 2 shows the signal flow between the different components of the electric drive assembly 100 of FIG. 1. The PWM generator 232 receives the target voltage signal us from the control law module 234. Using pulse-width modulation, it approximates the target voltage signal us by an inverter control signal M (u, t/ε). The inverter control signal M is fed to the power inverter 220. Based on this control signal M, the inverter 220 delivers a drive voltage upwm to the electric motor 300. With the current sensor 240, the currents in the motor's stator windings are measured and digitized in the ADC 238. The digitized current signal is then fed to the estimator 236. The estimator 236 also receives the estimation support signal s1 (u, t/ε) from the PWM generator 232. The estimator 236 provides estimates of different motor state variables z0 to zn based on the received inputs.


An important aspect of the present disclosure is the enhanced PWM generator 232, which not only generates the inverter control signal M, but also the state variable estimation support signal s1. With the help of the estimation support signal s1, the estimation module 236 can extract supplementary information from the current signal is to improve the state variable estimations.


The PWM generator 232 computes the state variable estimation support signal s1 based on a pulse-width modulation inherent disturbance signal s0. In fact, the present disclosure relies on the insight that the inverter control signal M generated by the PWM generator 232 can be modelled as a superposition of the target voltage signal us and a disturbance signal s0. Indeed, the inverter control signal M is a series of rectangular voltage pulses of varying widths, which on average, corresponds to the desired target voltage signal us. In other words, the inverter control signal M can be regarded as the desired target voltage signal us with an added voltage “ripple”. This ripple or PWM disturbance in the voltage creates a disturbance in the stator flux of the motor 300, which in turn creates a disturbance in the measured current is.


The present disclosure takes advantage of this unintended side-effect of the pulse width modulation. The ripple/artefact induced by the pulse-width modulation in the measured currents is used in the state variable estimation. This improves the estimates and thus the control of the electric motor 300.


A measure of the pulse-width modulation disturbance signal s0 (i.e. the ripple) can be obtained by subtracting the target voltage signal us from the inverter control signal M. The difference between the target voltage signal us and the inverter control signal M can then be integrated to obtain the primitive s1 of the disturbance signal s0.


These calculations, namely the subtraction and the integration, are done by the PWM generator 232. As shown in the figures, the PWM generator 232 provides the result s1 to the estimator 236.


It can be mathematically shown (see the remainder of the present disclosure) that the primitive s1 is a useful input for the estimator 236 to determine the instantaneous value of a state variable of the electric motor 300, such as the rotor position θ.


The variable speed drive of the present disclosure is particularly useful for the control of synchronous electric motors at low speeds. By suitably using the excitation provided by the pulse-width modulation itself, the variable speed drive of the present disclosure has the same benefits as a conventional variable speed drive relying on an external excitation signal, without the drawbacks of increased acoustic noise and potential interference with the pulse width modulation.


In the variable speed drive of the present disclosure, standard pulse-width modulation does not need to be modified.


Also, the estimates by the estimation module 236 only require current measurements from standard current sensors. There is no need for current measurements at extremely precise instants, which is prone to measurement errors and very impractical in an industrial drive.


Furthermore, the variable speed drive of the present disclosure also does not require specialized sensors capable of measuring current derivatives, as in other known solutions.


The teachings of the present disclosure may also be applied to the control of other types of actuators. For example, one may think of controlling the operation of an electromagnet in a magnetic bearing, or of a solenoid valve of a hydraulic or pneumatic cylinder.


II. Mathematical Derivation of Exemplary Estimators for Sensorless Electric Motor Control



  • Consider the control system modeled by the evolution equation

    ż=f(z)+g(z)u
    yα=h(z)  (1)

    where z is the internal state vector of the system, u is the control input vector, and yα is the measurement vector. In several practical applications (in particular electromechanical devices fed by PWM inverter), the control input is not applied directly, but through a fast-periodic modulation which yields u only in the mean. The actual system is therefore

    {dot over (x)}=f(x)+g(x)custom character(u,t/ϵ)
    y=h(x)

    where x is the state vector of the system disturbed by the modulator and y the corresponding measurement. ϵ>0 is a known small number, and custom character is 1-periodic and has mean u with respect to its second argument, i.e., custom character(ν, σ)=custom character(ν, σ+1) and ∫01custom character(ν, σ)dσ=ν. The system can clearly be written as

    {dot over (x)}=f(x)+g(x)(u+s0(u,t/ϵ))
    y=h(x)

    where s0 defined by s0(ν, σ):=custom character(ν,σ)−ν is 1-periodic and has zero mean with respect to its second argument, i.e., s0(ν, σ)=s0(ν, σ+1) and ∫01s0(ν, σ)dσ=0. In other words, we consider a generalized kind of signal injection, where the probing signal s0 is generated by the modulation process itself; notice s0 depends on u, which causes several difficulties.

  • Thanks to a mathematical analysis based on the cherry of second-order averaging, it can be shown that the measured signal y may be written as

    y(t)=yα(t)+ϵyν(t)s1(u(t),t/ϵ)+O2)

    where defined by s1, defined by s1(ν, σ):=∫0σs0(ν, s)ds−∫010σs0(ν, s)ds dσ, is the zero-mean primitive of s0 with u considered as a parameter; the “actual measurement” yα and the “virtual measurement” yνs1s1T can be interpreted as outputs of the “ideal” system without modulation (1), namely

    yα=h(z)  (2)
    yνs1s1T(u)=h′(z)g(z)s1s1T(u)  (3)

    Notice the square matrix s1s1T(u)=∫01(s1s1T)(u, σ)dσ is in general invertible (see “Multiphase PWM” hereafter), so that we simply have yν=h′(z)g(z).

  • The overall purpose of the invention is to extract from the measured signal y estimates of yα and yν which can be used to control the system. All is then as if one would want to control the “ideal” system without modulation (1) with a feedback law relying not only on the “actual measurement” (2), but also on the “virtual measurement” (3). The problem is then simpler thanks to the supplementary information (3); in particular in the case of sensorless control electric motors at low velocity, this supplementary information gives access to the rotor position, hence is instrumental in the design of the control law. The invention consists mainly of two parts:
    • 1) an enhanced modulator, generating not only the modulating signal custom character, but also the zero-mean primitive s1 of s0
    • 2) estimators custom character and custom character extracting not only yα, but also yν from the measured signal y, using the knowledge of s1.

  • A possible implementation for the estimators is













(
t
)


=



3

2

ϵ







t
-
ϵ

t




y


(
τ
)



d





τ



-


1

2

ϵ







t
-

2

ϵ



t
-
ϵ





y


(
τ
)



dt













(
t
)





s
1



s
1
T


—––



(

u


(
t
)


)


=


1

ϵ
2







t
-
ϵ

t




(


y


(
τ
)


-



(
τ
)



)




s
1



(


u


(
τ
)


,

τ
/
ϵ


)



d





τ











related to the desired signals by

custom character(t)=yα(t)+custom character2)
custom character(t)s1s1T(u(t))=yν(t)s1s1T(u(t))+custom character(ϵ).

Notice these estimators are periodic low-pass filters with FIR (Finite Impulse response) many variants relying on different periodic low-pass FIR filters are possible.


III. Pulse-Width Modulation (PWM)

Generating analog physical power signals is extremely impractical, since a lot of power must be dissipated in the amplifier. Pulse Width Modulation (PWM) addresses the issue by using the transistors in saturation mode. Indeed, transistors are more efficient when they are used in saturation than when they are used in their linear range. The desired value is realized in average by adjusting the width of the pulses (hence the name of the technique).


The simplest way to realize a PWM modulator is to compare the analog signal u with a triangular carrier c oscillating between −umax and umax follows:











u
PWM



(
t
)


=

{







-

u
max







if






c


(
t
)



>

u


(
t
)










u
max






if






c


(
t
)



<

u


(
t
)






=


u

max













sign






(


u


(
t
)


-

c


(
t
)



)









where






c


(
t
)


=

{





4



u
max



(


t
T

-
k
+

1
4


)







if






t
T




[


k
-

1
2


,
k

]









-
4




u
max



(


t
T

-
k
-

1
4


)







if






t
T




[

k
,

k
+

1
2



]













This is the natural sampling PWM demonstrated in FIG. 10 where the carrier is shown as continuous line c, the analog signal is shown as dashed line u and the PWM signal is shown as dotted line Upwm.


One of the disadvantages of the natural sampling PWM is that the pulses are not symmetrical. To address this issue, we can first sample the analog signal to obtain u[k]=u(kT) and then apply the PWM modulation on the sampled signal. With this PWM scheme we can check that











1
T







(

k
-

1
2


)


T



(

k
+

1
2


)


T






u
PWM



(
t
)



dt



=




1
T



(






(

k
-

1
2


)


T



(



u


[
k
]



4


u
max



+
k
-

1
4


)


T





u
max


dt


-

















(



u


[
k
]



4


u
max



+
k
-

1
4


)


T



(


-


(

u


[
k
]




4


u
max




+
k
+

1
4


)


T





u

ma

x



dt


+














(


-


u


[
k
]



4


u
max




+
k
+

1
4


)


T



(

k
+

1
2


)


T





u
max


dt


)






=





u
max

T



(



u


[
k
]



4


u
max



+

1
4

+

2



u


[
k
]



4


u
max




-

1
2

+














u


[
k
]



4


u
max



+

1
4


)






=



u


[
k
]









The expression of uPWM can be rewritten under the form uPWM=u+ũ with









u
~



(


t
T

,
u

)


=



u
max







sign


(

u
-

c


(

t
T

)



)



-
u


,





which is a zero-mean fast-varying periodic signal with a dependence on the control.


IV. Poly-Phase PWM

When controlling poly-phase electrical devices, n>1 analog references must be modulated.


In this case the s1 will be a vector with n lines and s1s1T is a n×n matrix.


Traditionally, to facilitate implementation, the n modulators use the same carrier. In this case, when two of the references are equal, this control scheme leads to two equal components in s1, which means that s1s1T, will not be invertible, which means that we do not obtain all the information in h′(z)g(z). Besides, when two components are close from one another s1s1T will be poorly conditioned, which complexities the signal processing.


To get more information and improve the conditioning of s1s1T, we can use a different carrier for each reference. In this case, the components of s1 are always independent. Consequently, the matrix s1s1T, is always invertible and well-conditioned.


V. Application to Sensorless Control of an Unsaturated Synchronous Reluctance Motor (SynRM)

Using Clarke transformation Matrices







𝒞
:=


2
3



(



1




-
1

/
2





-
1

/
2





0




3

/
2





-

3


/
2




)



,


𝒞

-
1


=

(



1


0






-
1

/
2





3

/
2







-
1

/
2





-

3


/
2




)







and the rotation










(
θ
)


:=

(




cos





θ





-
sin






θ






sin





θ




cos





θ




)






the model of the Synchronous Reluctant Motor (SynRM) is given by











d






ϕ
SDQ


dt

=






(

-
θ

)



𝒞






u
Sabc


-


R
s



L

-
1




ϕ
SDQ


-

J






ωϕ
SDQ











d





θ

dt

=
ω







t
Sabc

=


𝒞

-
1







(
θ
)




L

-
1




ϕ
SDQ









The state of this system is ϕSDQ, the vector of the stator flux in field-oriented DQ frame, and θ, the angular position of the rotor. The vector of stator voltages in physical abc frame, uSabc is the control input, while ω, the rotor speed, is a disturbance input, which must be obtained to achieve a proper control of the SynRM. When “sensorless” control is used the sole available measurement is the vector of stator currents in physical abc frame, tSabc. The parameters of the model are the stator resistance Rs and the matrix of inductances






L
=


(




L
D



0




0



L
Q




)

.





Since PWM is used, the voltage can be written uSabc(t)=ūSabc(t)+ũSabc(t/ϵ, ūSabc(t)).


Rewriting the system in the time scale σ:=t/ϵ, we obtain











d






ϕ
SDQ



d





σ


=

ϵ


(






(

-
θ

)



𝒞



u
_

Sabc


+





(

-
θ

)



𝒞




u
_

Sabc



(

σ
,


u
_

Sabc


)



-


R
s



L

-
1




ϕ
SDQ


-

J






ωϕ
SDQ



)















d





θ


d





σ


=
ϵω













t
Sabc

=


𝒞

-
1







(
θ
)




L

-
1




ϕ
SDQ










Which is like the standard form of averaging. Applying the averaging procedure, we can show that the PWM disturbance in the voltages creates a disturbance in the stator flux, which becomes ϕSDQ=ϕSDQcustom character(−θ)custom characterŨSabc(t/ϵ,ūSabc), where ŨSabc is the primitive of ũSabc, with zero-mean over a PWM method. The flux disturbance in turn creates a disturbance in the measured currents which becomes







t
Sabc

=



t
_

Sabc

+


ϵ𝒞

-
1









(
θ
)



L

-
1







(

-
θ

)






s


(
θ
)




𝒞




U
~

Sabc



(


t
/
ϵ

,


u
_

Sabc


)



+

O


(

ϵ
2

)







The undisturbed variables follow the original model











d



ϕ
_

SDQ


dt

=






(

-
θ

)



𝒞



u
_

Saβ


-


R
s



L

-
1





ϕ
_

SDQ


-

J





ω



ϕ
_

SDQ














d





θ


d





t


=
ω








t
_


S





αβ


=


𝒞

-
1







(
θ
)




L

-
1





ϕ
_

SDQ












Thanks to the proposed estimators, provided ŨSabcŨSabcT is the invertible (see “Poly-phase PWM” above), we can recover tSabc and custom character(θ) from tSabc, which allow to run the or control law, which computes ūSαβ from tSαβ, and retrieve θ using custom character(θ)=custom character(θ)L−1custom character(−θ), as can be done with HF injection, but without the need of an additional disturbance.


Adding Virtual Measurements by PWM-Induced Signal Injection

Abstract: We show that for PWM-operated devices, it is possible to benefit from signal injection without an external probing signal, by suitably using the excitation provided by the PWM itself. As in the usual signal injection framework conceptualized in [1], an extra “virtual measurement” can be made available for use in a control law, but without the practical drawbacks caused by an external signal.


I. Introduction

Signal injection is a control technique which consists in adding a fast-varying probing signal to the control input. This excitation creates a small ripple in the measurements, which contains useful information if properly decoded. The idea was introduced in [2], [3] for controlling electric motors at low velocity using only measurements of currents. It was later conceptualized in [1] as a way of producing “virtual measurements” that can be used to control the system, in particular to overcome observability degeneracies. Signal injection is a effective method, see e.g. applications to electromechanical devices along these lines in [4], [5], but it comes at a price; the ripple it creates may in practice yield unpleasant acoustic noise and excite unmodeled dynamics, in particular in the very common situation when the device is fed by a Pulse Width Modulation (PWM) inverter; indeed, the frequency of the probing signal may not be as high as desired so as not to interfere with the PWM (typically, it can not exceed 500 Hz in an industrial drive with a 4 kHz-PWM frequency).


The goal of this paper is to demonstrate that for PWM-operated devices, it is possible to benefit from signal injection without an external probing signal, by using the excitation provided by the PWM itself, as e.g. in [6]. More precisely, consider the Single-Input Single-Output system

{dot over (x)}=f(x)+g(x)u,  (1a)
y=h(x),  (1b)

where u is the control input and y the measured output. We first show in section II that when the control is impressed through PWM, the dynamics may be written as











x
.

=


f


(
x
)


+


g


(
x
)




(

u
+


s
0

(

u
,

t
ɛ


)


)




,




(
2
)








with s0 1-periodic and zero-mean in the second argument i.e. s0(u, σ+1)=s0(u, σ) and ∫01s0(u, σ)dσ=0 for all u; ε is the PWM period, hence assumed small. The difference with usual signal injection is that the probing signal s0 generated by the modulation process now depends not only on time, but also on the control input u. This makes the situation more complicated, in particular because s0 can be discontinuous in both its arguments. Nevertheless, we show in section III that the second-order averaging analysis of [1] can be extended to this case. In the same way, we show in section IV that the demodulation procedure of [1] can be adapted to make available the so-called virtual measurement

y0:=H1(x):=εh′(x)g(x),

in addition to the actual measurement y0:=H0(x):=h(x). This extra signal is likely to simplify the design of a control law, as illustrated on a numerical example in section V.


Finally, we list some definitions used throughout the paper, S denotes a function of two variables, which is T-periodic in the second argument, i.e. S(ν, σ+T)=S(ν, σ) for all ν:

    • the mean of S in the second argument is the function (of one variable)









S
_



(
v
)


:=


1
T





0
T




S


(

v
,
σ

)



d





σ




;





S has zero mean in the second argument if S is identically zero

    • if S has zero mean in the second argument, its zero-mean primitive in the second argument is defined by









S
1



(

v
,
τ

)


:=




0
τ




S


(

v
,
σ

)



d





σ


-


1
T





0
T





0
τ




S


(

v
,
σ

)



d





σ





d





τ






;





notice S1 is T-periodic in the second argument because S has zero mean in the second argument

    • the moving average M(k) of k is defined by








M


(
k
)




(
t
)


:=


1
ɛ






t
-
ɛ

t




k


(
τ
)



d





τ










    • custom character
      denotes the uniform “big O” symbol of analysis, namely ƒ(z, ε)=custom characterp) if |ƒ(z, ε)|≤Kεp for ε small enough, with K>0 independent of z and ε.





II. PWM-Induced Signal Injection

When the control input u in (1a) is impressed through a PWM process with period ε, the resulting dynamics reads











x
.

=


f


(
x
)


+


g


(
x
)





(

u
,

t
ɛ


)




,




(
3
)








with custom character 1-periodic and mean u in the second argument; the detailed expression for custom character is given below. Setting s0(u, σ):=custom character(u, σ)−u, (3) obviously takes the form (2), with s0 1-periodic and zero-mean in the second argument.


Classical PWM with the period ε and range [−um, um] is obtained by comparing the input signal u to the ε-periodic sawtooth carrier defined by







c


(
t
)


:=

{






u
m

+

4


w
(

t
ɛ

)







if




-


u
m

2




w
(

t
ɛ

)


0







u
m

-

4


w
(

t
ɛ

)







if





0



w
(

t
ɛ

)




u
m

2





;







the 1-periodic function







w


(
σ
)


:=



u
m



mod
(


σ
+

1
2


,
1

)


-


u
m

2







wraps the normalized time






σ
=


t
ɛ








to




[


-


u
m

2


,


u
m

2


]

.







If u varies slowly enough, it crosses the carrier c exactly once on each rising and filling ramp, at times t1u>t2u such that







u


(

t
1
u

)


=


u
m

+

4


w
(


t
1
u

ɛ

)










u


(

t
2
u

)


=


u
m

-

4



w
(


t
2
u

ɛ

)

.







The PWM-encoded signal is therefore given by








u
pwm



(
t
)


=

{





u
m





if




-


u
m

2


<

w
(

t
ɛ

)



w
(


t
1
u

ɛ

)







-

u
m






if






w
(


t
1
u

ɛ

)


<

w
(

t
ɛ

)



w
(


t
2
u

ɛ

)







u
m





if






w
(


t
2
u

ɛ

)


<

w
(

t
ɛ

)




u
m

2





.







FIG. 3 illustrates the signals u, c and upwm. The function













(

u
,
σ

)


:=



{




u
m





if




-

2


u
m



<

4


w


(
σ
)





u
-

u
m








-

u
m







if





u

-

u
m


<

4


w


(
σ
)






u
m

-
u







u
m






if






u
m


-
u

<

4


w


(
σ
)





2


u
m














=




u
m

+

sign


(

u
-

u
m

-

4


w


(
σ
)




)


+

sign


(

u
-

u
m

+

4


w


(
σ
)




)




,








which is obviously 1-periodic and with mean u with respect to its second argument, therefore completely describes the PWM process since








u
pwm



(
t
)


=



(


u


(
t
)


,

t
ɛ


)

.





Finally, the induced zero-mean probing signal is











s
0



(

u
,
σ

)


:=







(

u
,
σ

)


-
u








=




u
m

-
u
+

sign
(



u
-

u
m


4

-

w


(
σ
)



)

+

sign
(



u
-

u
m


4

-

w


(
σ
)



)



,








and its zero-mean primitive in the second argument is








s
1



(

u
,
σ

)


:=



(

1
-

u

u
m



)



w


(
σ
)



-





u
-

u
m


4

-

w


(
σ
)





+






u
-

u
m


4

-

w


(
σ
)





.






Remark 1: As s0 is only piecewise continuous, one might expect problems to define the “solutions” of (2). But as noted above, if the input u(t) of the PWM encoder varies slowly enough, its output








u
pwm



(
t
)


=


(


u


(
t
)


,

t
ɛ


)






will have exactly two discontinuities per PWM period. Chattering is therefore excluded, which is enough to ensure the existence and uniqueness of the solutions of (2), see [7], without the need for the more general Filipov theory [8]. Of course, we assume (without loss of generality in practice) that ƒ, g and h in (1) are smooth enough.


Notice also s1 is continuous and piecewise C1 in both its arguments. The regularity in the second argument was to be expected as s1(u, ·) is a primitive of s0(u, ·); on the other hand, the regularity in the first argument stems from the specific form of s0.


III. Averaging and PWM-Induced Injection

Section III-A outlines the overall approach and states the main Theorem 1, which is proved in the somewhat technical section III-B. As a matter of fact, the proof can be skipped without losing the main thread; suffice to say that if s0 were Lipschitz in the first argument, the proof would essentially be an extension of the analysis by “standard” second-order averaging of [1], with more involved calculations


A. Main Result


Assume we have designed a suitable control law

ū=α(η,Y,t)
{dot over (η)}=α(η,Y,t)1

where ηεcustom characterq, for the system









x
_

.

=


f


(

x
_

)


+


g


(

x
_

)




u
_




,






Y
_

=


H


(

x
_

)


:=


(




h


(

x
_

)







ɛ







h




(

x
_

)




g


(

x
_

)






)

.








By “suitable”, we mean the resulting closed-loop system

{dot over (x)}=ƒ(x)+g(x)α(η,H(x),t)  (4a)
{dot over (η)}=α(η,H(x),t)  (4b)

has the desired exponentially stable behavior. We have changed the notations of the variables with · to easily distinguish between the solutions of (4) and of (7) below. Of course, this describes an unrealistic situation:

    • PWM is not taken into account
    • the control law is not implementable, as it uses not only the actual output yα=h(x), but also the a priori not available virtual output yv=εh′(x)g(x).


Define now (up to custom character2)) the function

H(x,η,σ,t):=H(x−εg(x)s1(α(η,H(x),t),σ))+custom character2),  (5)

where s1 is the zero mean primitive of s0 in the second argument, and consider the control law









u
=

α
(

η
,


H
_

(

x
,
η
,

t
ɛ

,
t

)

,
t

)





(

6

a

)







η
.

=


a
(

η
,


H
_

(

x
,
η
,

t
ɛ

,
t

)

,
t

)

.





(

6

b

)








The resulting closed-loop system, including PWM, reads










x
.

=


f


(
x
)


+


g


(
x
)





(


α
(

η
,


H
_

(

x
,
η
,

t
ɛ

,
t

)

,
t

)

,

t
ɛ


)







(

7

a

)







η
.

=


a
(

η
,


H
_

(

x
,
η
,

t
ɛ

,
t

)

,
t

)

.





(

7

b

)








Though PWM is now taken into account the control law (6) still seems to contain unknown terms.


Nevertheless, it will turn out from the following result that it can be implemented.


Theorem 1: Let (x(t), η(t)) be the solution of (7) starting from (x0, η0), and define u(t):=α(η(t), H(x(t)), t) and y(t):=H(x(t)); let (x(t), η(t)) be the solution of (4) starting from (x0−εg(x0). s1(u(0), 0), η0), and define ū(t):=α(η(t), H(x(t)),t). Then, for t≥0,










x


(
t
)


=



x
_



(
t
)


+

ɛ






g


(


x
_



(
t
)


)





s
1

(



u
_



(
t
)


,

t
ɛ


)


+


𝒪




(

ɛ
2

)







(

8

a

)







η


(
t
)


=



η
_



(
t
)


+


𝒪




(

ɛ
2

)







(

8

b

)







y


(
t
)


=



H
0



(


x
_



(
t
)


)


+



H
1



(


x
_



(
t
)


)





s
1

(



u
_



(
t
)


,

t
ɛ


)


+



𝒪




(

ɛ
2

)


.






(

8

c

)







The practical meaning of the theorem is the following. As the solution (x(t), η(t))) is piecewise C1, we have by Taylor expansion using (8a)-(8b) that u(t)=ū(t)+custom character2). In the same way, as s1 is also piecewise C1, we have








s
1

(


u


(
t
)


,

t
ɛ


)

=



s
1

(



u
_



(
t
)


,

t
ɛ


)

+



𝒪




(

ɛ
2

)


.







As a consequence, we can invert (8a)-(8b), which yields











x
_



(
t
)


=


x


(
t
)


-

ɛ






g


(

x


(
t
)


)





s
1

(


u


(
t
)


,

t
ɛ


)


+


𝒪




(

ɛ
2

)







(

9

a

)








η
_



(
t
)


=


η


(
t
)


+



𝒪




(

ɛ
2

)


.






(

9

b

)








Using this into (5), we then get















H
_

(


x


(
t
)


,

η


(
t
)


,

t
ɛ

,
t

)

=




H
(


x


(
t
)


-

ɛ






g


(

x


(
t
)


)





s
1

(


u


(
t
)


,

t
ɛ


)



)

+


𝒪




(

ɛ
2

)




,






=




H


(


x
_



(
t
)


)


+



𝒪




(

ɛ
2

)


.









(
10
)








On the other hand, we will see in section IV that, thanks to (8c), we can produce an estimate Ŷ=H(x)+custom character2). This means the PWM-fed dynamics (3) acted upon by the implementable feedback

u=α(η,Ŷ,t)
{dot over (η)}=α(η,Ŷ,t).

behaves exactly as the closed-loop system (4) except for the presence of a small ripple (described by (8a)-(8b)).


Remark 2: Notice that, according to Remark 1, H0(x(t)) and H1(x(t)) in (8c) may be as smooth as desired (the regularity is inherited from only f, g, h, α, a); on the other hand







s
1

(


u


(
t
)


,

t
ɛ


)





is only continuous and piecewise C1. Nevertheless, this is enough to justify all the Taylor expansions performed in the paper.


Proof of Theorem 1


Because of the lack of regularity of s0, we must go hack to the fundamentals of the second-order averaging theory presented in [9, chapter 2] (with slow time dependence [9, section 3.3]). We first introduce two ad hoc definitions.


Definition 1: A function φ(X, σ) is slowly-varying in average if there exists λ>0 such that for ε small enough,

αα+T∥φ(p(εσ)+εkq(σ),σ)−φ(p(εσ),σ)∥dσ≤λTεk,

where p, q are continuous with q bounded; α and T>0 are arbitrary constants. Notice that if φ is Lipschitz in the first variable then it is slowly-varying in average. The interest of this definition is that it is satisfied by s0.


Definition 2: A function φ is custom character3) in average if there exists K>0 such that ∥∫0αϕ(q(s), s)ds∥≤k ε3σ for all σ≥0. Clearly, if ϕ is custom character3) then it is custom character3) in average.


The proof of Theorem 1 follows the same steps as [9, chapter 2], but with weaker assumptions. We first rewrite (7) in the fast timescale σ:=t/ε as











dX

d





σ


=


ɛ







F


(

X
,
σ
,
ɛσ

)


.




where






X

:=


(

x
,
η

)






and










F


(

X
,
σ
,
τ

)


:=


(





f


(
x
)


+


g


(
x
)







(

α


(

η
,


H
_



(

x
,
η
,
σ
,
τ

)


,
τ

)


)









a


(

η
,


H
_



(

x
,
η
,
σ
,
τ

)


,
τ

)





)

.






(
11
)








Notice F is 1-periodic in the second argument. Consider also the so-called averaged system











d


X
_



d





σ


=

ɛ








F
_



(


X
_

,
ɛσ

)


.






(
12
)








where F is the mean F in the second argument.


Define the near-identity transformation











X
=


X
~

+

ɛ






W
(


X
~

,
σ
,
ɛσ

)




,






where






X
~


:=


(


x
~

,

η
~


)






and










W
(


X
~

,
σ
,
τ

)

:=


(




g


(

x
~

)






0



)





s
1



(


α


(


η
~

,

H


(


x
~

,

η
~

,
σ
,
τ

)


,
τ

)


,
σ

)


.







(
13
)








Inverting (13) yields

{tilde over (X)}=X−εW(X,σ,εσ)+custom character2).  (14)

By lemma 1, this transformation puts (11) into












d


X
~



d





σ


=


ɛ







F

_



(


X
~

,
ɛσ

)


+


ɛ
2



Φ
(


X
~

,
σ
,
ɛσ

)


+

ϕ
(


X
~

,
σ
,
ɛσ

)



;




(
15
)








Φ is periodic and zero-mean in the second argument, and slowly-varying in average, and ϕ is custom character3) in average.


By lemma 2, the solutions X(σ) and {tilde over (X)}(σ) of (12) and (15), starting from the same initial conditions, satisfy

{tilde over (X)}(σ)=X(σ)+custom character3).


As a consequence, the solution X(σ) of (11) stating from X0 and the solution X(σ) of (12) starting from X0−εW(X0, 0, 0) are related by X(σ)=X(σ)+εW(X(σ), σ, εσ)+custom character2), which is exactly (8a)-(8b). Inserting (8a) in y=h(x) and Taylor expanding yields (8c).


Remark 3: If s0 were differentiable in the first variable, Φ would be Lipschitz and ϕ would be custom character on a in (15), hence the averaging theory of [9] would directly apply.


Remark 4. In the sequel, we prove for simplicity only the estimation {tilde over (X)}(σ)=X(σ)+custom character2) on a timescale 1/ε. The continuation to infinity follows from the exponential stability of (4), exactly as in [1, Appendix].


In the same way, lemma 2 is proved without slow-time dependence, the generalization being obvious as in [9, section 3.3].


Lemma 1: The transformation (13) puts (11) into (15), where Φ is periodic and zero-mean in the second argument, and slowly-varying in average, ϕ is custom character3) in average.


Proof: To determine the expression for d{tilde over (X)}/dσ, the objective is to compute dX/dσ as a function of {tilde over (X)} with two different methods. On the one hand we replace X with its transformation (13) in the closed-loop system (11), and on the other hand we differentiate (13) with respect to σ.


We first compute s0(α(η, H(x, η, σ, εσ), εσ), σ) as a function of {tilde over (X)}=({tilde over (x)}, {tilde over (η)}). Exactly as in (10), with ({tilde over (x)}, {tilde over (η)}) replacing (x, η), and (14) replacing (9), we have

H(x,η,σ,εσ)=H({tilde over (x)})+custom character2).

Therefore, by Taylor expansion

α(η,H(x,η,σ,εσ),εσ)=α({tilde over (η)},H({tilde over (x)}),εσ)+ε2Kα({tilde over (X)},σ),

with Kα bounded. The lack of regularity of s0 prevents further Taylor expansion; nonetheless, we still can write

s0(α(η,H(x,η,σ,εσ),εσ),σ)=s0(α({tilde over (η)},H({tilde over (x)}),εσ)+ε2Kα({tilde over (X)},σ),σ).

Finally inserting (13) into (11) and Taylor expanding, yields after tedious but straightforward computations,











dX

d





σ


=


ɛ







F
_

(


X
~

,
ɛσ

)


+

ɛ






G


(

X
~

)





s
0

a
,
+




(

·
~

)



+


ɛ
2




F
_

(


X
~

,
ɛσ

)



G


(
X
)





s
1
a



(

·
~

)



+


ɛ
2




G




(

X
~

)




G


(

X
~

)





s
1
a



(

·
~

)





s
0

a
,
+




(

·
~

)



+


𝒪




(

ɛ
3

)




;




(
16
)








we have introduced the following notations







(

·
~

)

:=

(


X
~

,
σ
,
ɛσ

)










s
i
a



(

·
~

)


:=


s
i



(


α


(


η
~

,

H


(

x
~

)


,
ɛσ

)


,
σ

)



,







s
0

a
,
+




(

·
~

)


:=


s
0

(



α


(


η
~

,

H


(

x
~

)


,
ɛσ

)


+


ɛ
2




K
a

(


X
~

,
σ

)



,
σ

)










Δs
0
a



(

·
~

)


:=



s
0

a
,
+




(

·
~

)


-


s
0



(

·
~

)










G


(
X
)


:=

(




g


(
x
)






0



)









F
_



(

X
,
ɛσ

)


:=


(





f


(
x
)


+


g


(
x
)




α


(

η
,

H


(
x
)


,
ɛσ

)









α


(

η
,

H


(
x
)


,
ɛσ

)





)

.





We now time-differentiate (13), which reads with the previous notations

X={tilde over (X)}+εG({tilde over (X)})s1α({tilde over (·)}).

This yields











dX

d





σ


=



d


X
~



d





σ


+




ɛ

G





(

X
~

)





d


X
~



d





σ





s
1
a



(

·
~

)



+



ɛ

G

(

X
~

)





1




s
1
α



(

·
~

)






d


X
~



d





σ



+



ɛ

G

(

X
~

)




s
0
a



(

·
~

)



+


ɛ
2



G


(

X
~

)






3




s
1
a



(

·
~

)






,




(
17
)








since ∂2s1α=s0α. Now assume {tilde over (X)} satisfies












d


X
~



d

σ


=


ɛ



F
_



(


X
~

,

ɛ

σ


)



+


ɛG


(

X
~

)






Δ

s

0
a



(

·
~

)



+


ɛ
2



Ψ


(

·
~

)





,




(
18
)








where Ψ({tilde over (·)}) is yet to be computed. Inserting (18) into (17),










dX

d





σ


=


ɛ



F
_



(


X
~

,

ɛ

a


)



+



ɛ

G

(

X
~

)




Δs
0
a



(

·
~

)



+


ɛ
2



Ψ


(

·
~

)



+


ɛ
2




G




(

X
~

)





F
_



(


X
~

,
ɛσ

)





s
1
a



(

·
~

)



+


ϵ
2




G




(

X
~

)




G


(

X
~

)





Δs
0
a



(

·
~

)





s
1
a



(

·
~

)



+


ɛ
2



G


(

X
~

)






1




s
1
a



(

·
~

)






F
_



(


X
~

,
ɛσ

)



+


ɛ
2



G
(

X
~

)





1




s
1
a



(

·
~

)





G


(

X
~

)





Δs
0
a



(

·
~

)



+



ɛ

G



(

X
~

)





s
0
a



(

·
~

)



+


ɛ
2



G


(

X
~

)






3




s
1
a



(

·
~

)




+



O




(

ɛ
3

)


.






(
19
)








Next, equation (19) and (16), Ψ satisfies










Ψ


(

·
~

)


=



[


F
_

,
G

]



(


X
~

,
ɛσ

)




s
1
a



(

·
~

)



+



G




(

X
~

)




G


(

X
~

)





s
0
a



(

·
~

)





s
1
a



(

·
~

)



-


G


(

X
~

)






1




s
1
a



(

·
~

)






F
_



(


X
~

,
ɛσ

)



-


G


(

X
~

)






3




s
1
α



(

·
~

)




-


G


(

X
~

)






1




s
1
a



(

·
~

)





G


(

X
~

)






Δs
0
a



(

·
~

)


.







(
20
)








This gives the expressions of Φ and ϕ in (15),








Φ


(

·
~

)


:=



[


F
_

,
G

]



(


X
~

,
ɛσ

)




s
1
a



(

·
~

)



+



G




(

X
~

)




G


(

X
~

)





s
0
a



(

·
~

)





s
1
a



(

·
~

)



-


G


(

X
~

)






1




s
1
a



(

·
~

)






F
_



(


X
~

,
ɛσ

)



-


G


(

X
~

)






3




s
1
a



(

·
~

)






,










ϕ


(

·
~

)


:=



ɛ
2




Ψ
1



(

·
~

)



+



ɛ

G

(

X
~

)



Δs
0
a




,








with













Ψ
1



(

·
~

)


:=


-

G


(

X
~

)







1




s
1
a



(

·
~

)





G


(

X
~

)






Δs
0
a



(

·
~

)


.







The last step is to check that Φ and ϕ satisfy the assumptions of the lemma. Since s0α, s1α, ∂1s1αand ∂2s1α are periodic and zero-mean in the second argument, and slowly-varying in average, so is Φ.There remains to prove that ϕ=custom character3) in average. Since Δs0α is slowly-varying in average,

0σ∥Δs0α({tilde over (·)})(s))∥ds≤λ0σε2.

with λ0>0, G being bounded by a constant cg, this implies

∥∫0σεG({tilde over (X)}(s))Δs0α({tilde over (·)})(s))dsμ≤cgλ0σε3.

Similarly, ∂1s1 being bounded by c11, Ψ1 satisfies

∥∫0σε2Ψ1({tilde over (·)}(s))ds∥≤cg2c11λ0σε0ε3.

Summing the two previous inequalities yields

∥∫0σϕ({tilde over (·)}(s))ds∥≤λ0cg(1+c11cgε0)σε3,

which concludes the proof.


Lemma 2: Let X(σ) and {tilde over (X)}(σ) be respectively the solutions of (12) and (15) starting at 0 from the same initial conditions. Then, for all σ≥0

{tilde over (X)}(σ)=X(σ)+custom character2).


Proof: Let E(σ):={tilde over (X)}(σ)−X(σ). Then,










E


(
σ
)


=





0
σ




[




d


X
~






(
s
)


-



d


X
_






(
s
)



]


ds








=




ɛ




0
σ




[


F


(


X
~



(
s
)


)


-

F


(


X
_



(
s
)


)



]


ds



+


ɛ
2





0
σ




Φ


(


·
~



(
s
)


)



ds



+












0
σ




ϕ


(


·
~



(
s
)


)



ds










As F Lipschitz with constant λF,

ε∫0σ∥F({tilde over (X)}(s))−F(X(s))∥ds≤ελF0σ∥E(s)∥ds.

On the other hand, there exists by lemma 3 c1 such that

ε2∥∫0σΦ({tilde over (·)})(s))ds∥≤c1ε2

Finally, as ϕ is custom character3) in average, there exists c2 such that

μ∫0σϕ({tilde over (·)}(s))ds∥≤c2ε3σ.

The summation of these estimations yields

E(σ)∥≤ελF0σ∥E(s)∥ds+c1ε2+c2ε3σ.

Then by Gronwall's lemma [9, Lemma 1.3.3]










E


(
σ
)







(



c
2


λ
p


+

c
1


)



e


λ
F


σ




ɛ
2



,





which means {tilde over (X)}=X+custom character2).


The following lemma is an extension of Besjes' lemma [9, Lemma 2.8.2] when φ is no longer Lipschitz, but only slowly-varying in average.


Lemma 3: Assume φ(X, σ) is T-periodic and zero-mean in the second argument, bounded, and slowly-varying in average. Assume the solution X(σ) of {dot over (X)}=custom character(ε) is defined for 0≤σ≤L/ε. There exists c1>0 such that

∥∫0σφ(X(s),s)ds∥≤c1.


Proof: Along the lines of [9], we divide the interval [0, t] in m subintervals [0, T], . . . , [(m−1)T, mT] and a remainder [mT, t]. By splitting the integral on those intervals, we write










0
σ




φ


(


ϰ


(
s
)


,
s

)



ds


=





i
=
0

m











(

i
-
1

)


T

iT




φ


(


ϰ


(


(

i
-
1

)


T

)


,
s

)



ds



+




i
=
0

m











(

i
-
1

)


T

iT




[


φ


(


ϰ


(
s
)


,
s

)


-

φ


(


ϰ


(


(

i
-
1

)


T

)


,
s

)



]


ds



+



mT
σ




φ


(


ϰ


(
s
)


,
s

)



ds




,





where each of the integral in the first sum are zero as φ is periodic with zero mean. Since φ is bounded, the remainder is also bounded by a constant c2>0. Besides










x


(
s
)


=


x


(


(

i
-
1

)


T

)


+





(

i
-
1

)


T






ϰ





.



(
τ
)


d





τ










=


ϰ


(


(

i
-
1

)


T

)


+


ɛ

q



(
s
)




,








with q continuous and bounded. By hypothesis, there exists λ>0 such that 0≤i≤m,

(i−1)TT∥φ(x(s),s)−φ(x((i−1)T),s)∥ds≤λTε

Therefore by summing the previous estimations,

∥∫0σφ(x(s),s)ds∥≤mλTε+o2,

with mT≤t≤L/ε, consequently mλTε+o2≤λL+o2; which concludes the proof.


IV. Demodulation

From (8c), we can write the measured signal y as








y


(
t
)


=



y
a



(
t
)


+



y
v



(
t
)





s
1



(


u


(
t
)


,

t
ɛ


)



+


O




(

ɛ
2

)




,





where the signal u feeding the PWM encoder is known. The following result shows yα and yν can he estimated from y, for use in a control law as described in section III-A.


Theorem 2: Consider the estimators ŷα and ŷu defined by









y
^

a



(
t
)


:=



3
2



M


(
y
)




(
t
)


-


1
2



M


(
y
)




(

t
-
ɛ

)











k
Δ



(
τ
)


:=


(


y


(
τ
)


-



y
^

n



(
τ
)



)




s
1



(


u


(
τ
)


,

τ
ɛ


)













y
^

v



(
t
)


:=



M


(

k
Δ

)




(
t
)





s
1
2

_



(

u


(
t
)


)




,





where M:ycustom characterε−10εy(τ)dτ is the moving average operator, and s12 the mean of s12 in the second argument (cf end of section I). Then,

ŷα(t)=yα(t)+custom character2)  (21a)
ŷν(t)=yν(t)′custom character2).  (21b)

Recall that by construction yν(t)=custom character(ε), hence (21b) is essentially a first-order estimation; notice also that s12(u(t)) is always non-zero when u(t) does not exceed the range of the PWM encoder.


Proof: Taylor expanding yα, yν, u and s1 yields








y
a



(

t
-
τ

)


=



y
a



(
t
)


-

r




y
.

a



(
t
)



+



O




(
τ
)


2










y
ν



(

t
-
τ

)


=



y
v



(
t
)


+



O




(
ɛ
)





O




(
τ
)















s
1



(


u


(

t
-
τ

)


,
σ

)


=


s
1



(



u


(
t
)


+


O




(
τ
)



,
σ

)









=



s
1



(


u


(
t
)


,
σ

)


+


O




(
τ
)




;








in the second equation, we have used yν(t)=custom character(ε). The moving average yα then reads














M


(

y
a

)




(
t
)


=


1
ɛ





0
ɛ





y
a



(

t
-
τ

)



dr









=


1
ɛ





0
ɛ




(



y
a



(
t
)


-

τ




𝓎
.

a



(
t
)



+


O




(

τ
2

)



)


d





τ









=



y
a



(
t
)


-


ɛ
2





𝓎
.

a



(
t
)



+



O




(

ɛ
2

)


.









(
22
)








A similar computation for








k
v



(
t
)


:=



y
v



(
t
)





s
1



(


u


(
t
)


,

t
ɛ


)








yields














M


(

k
ν

)




(
t
)


=


1
ɛ





0
ɛ





y
ν





(

t
-
τ

)




s
1



(


u


(

t
-
τ

)


,


t
-
r

ɛ


)




d

τ










=




y
ν



(
t
)




(




s
1

_



(

u


(
t
)


)


+


O




(
ɛ
)



)


+


O




(

ɛ
2

)










=


O




(

ɛ
2

)



,







(
23
)








since s1 is 1-periodic and zero mean in the second argument. Summing (22 and (23), we eventually find








M


(
y
)




(
t
)


=



y
a



(
t
)


-


ɛ
2





y
.

a



(
t
)



+



𝒪




(

ɛ
2

)


.







As a consequence, we get after another Taylor expansion

3/2M(y)(t)−½M(y)(t−ε)=yα(t)+custom character2),

which is the desired estimation (21a).


On the other hand, (21a) implies

kΔ(t)=yν(t)s12(u(t),t/ε)+custom character2).

Proceeding as for M(kν), we find











M


(

k
Δ

)




(
t
)


=




1
ɛ





0
ɛ





y
v



(

t
-
τ

)





s
1
2



(


u


(

t
-
τ

)


,


t
-
τ

ɛ


)



d





τ









=






y
v



(
t
)




(




s
1
2

_



(

u


(
t
)


)


+


𝒪




(
ɛ
)



)


+


𝒪




(

ɛ
2

)









=






y
v



(
t
)






s
1
2

_



(

u


(
t
)


)



+



𝒪




(

ɛ
2

)


.










Dividing by s12(u(t)) yields the desired estimation (21b).


V. Numerical Example

We illustrate the interest of the approach on the system

{dot over (x)}1=x2,
{dot over (x)}2=x3,
{dot over (x)}3=u+d,
y=x2+x1x3,

where d is an unknown disturbance; u will be impressed through PWM with frequency 1 kHz (i.e. ε=10−3) and range [−20, 20]. The objective is to control x1, while rejecting the disturbance d, with a response time of a few seconds. We want to operate around equilibrium points, which are of the form (x1eq, 0, 0; −deq, deq), for x1eq and deq constant. Notice the observability degenerates at such points, which renders not trivial the design of a control law.


Nevertheless the PWM-induced signal injection makes available the virtual measurement








y
v

=



ɛ


(




x
3



1



x
1




)




(



0




0




1



)


=

ɛ






x
1




,





from which it is easy to design a suitable control law, without even using the actual input yα=x2+x1x3. The system being now fully linear, we use a classical controller-observer, with disturbance estimation to ensure an implicit integral effect. The observes is thus given by










x
^

.

1

=



x
^

2

+


l
1

(



y
v

ɛ

-


x
^

1


)



,








x
^

.

2

=



x
^

3

+


l
2

(



y
v

ɛ

-


x
^

1


)



,








x
^

.

3

=

u
+

d
^

+


l
3

(



y
v

ɛ

-


x
^

1


)



,







d
^

.

=


l
d

(



y
v

ɛ

-


x
^

1


)


,





and the controller by

u=−k1{circumflex over (x)}1−k2{circumflex over (x)}2−k3{circumflex over (x)}3−kd{circumflex over (d)}+kx1ref.

The gains are chosen to place the observer eigenvalues (−1.19, −0.73, −0.49±0.57i) and the controller eigenvalues at (−6.59, −3.30±5.71i). The observer is slower than the controller in accordance with dual Loop Transfer Recovery, thus ensuring a reasonable robustness. Setting η:=({circumflex over (x)}1, {circumflex over (x)}2, {circumflex over (x)}3, {circumflex over (d)})T, this controller-observer obviously reads

u=−Kη+kx1ref  (24a)
{dot over (η)}=Mη+Nx1ref(t)+Lyν  (24b)

Finally, this ideal control law is implemented as











u
pwm



(
t
)


=


(




-
K






η

+

kx
1
ref


,

t
ɛ


)





(

25

a

)








η
.

=


M





η

+

Nx
1
ref

+

L




y
^

v

ɛ




,




(

25

b

)








where M is the PWM function described in section II, and ŷ84 obtained by the demodulation process of section IV.


The test scenario is the following: at t=0, the system start at rest at the origin; from t=2, a disturbance d=−0.25 is applied to the system; at t=14, a filtered unit step is applied to the reference x1ref. In FIG. 5 the ideal control law (24), i.e. without PWM and assuming yν known, is compared to the true control law (25): the behavior of (25) is excellent, it is nearly impossible to distinguish the two situations on the responses of x1 and x2 as by (8a) the corresponding ripple is only custom character2); the ripple is visible on x3, where it is custom character(ε). The corresponding control signals u and upwm are displayed in FIG. 6, and the corresponding measured outputs in FIG. 7.


To investigate the sensitivity to measurement noise, the same test was carried out with band-limited white noise (power density 1×10−9, sample time 1×10−5) added to y. Even though the ripple in the measured output is buried in noise, see FIG. 8, the virtual output is comedy demodulated and the control law (25) still behaves very well.


CONCLUSION

We have presented a method to take advantage of the benefits of signal injection in PWM-fed systems without the need for an external probing signal. For simplicity, have restricted to Single-Input Single-Output systems, but then are no essential difficulties to consider Multiple-Input Multiple-Output systems. Besides, though we have focused on classical PWM, the approach can readily be extended to arbitrary modulation processes, for instance multilevel PWM; in fact, the only requirements is that s0 and s1 meet the regularity assumptions discussed in remark 1.


REFERENCES



  • [1] P. Combes, A. K. Jebai, E Malrait, P. Martin, and P. Rouchon, “Adding virtual measurements by signal injection,” in American Control Conference, 2016, pp. 999-1005.

  • [2] P. Jansen and R. Lorenz, “Transducerless position and velocity estimation in induction and salient AC machines,” IEEE Trans. Industry Applications, vol. 31, pp. 240-247, 1995.

  • [3] M. Corley and R. Lorenz, “Rotor position and velocity estimation for a salient-pole permanent magnet synchronous machine at standstill and high speeds,” IEEE Trans. Industry Applications, vol. 34, pp. 784-789, 1998.

  • [4] A. K. Jebai, E Malrait, P. Martin, and P. Rouchon, “Sensorless position estimation and control of permanent-magnet synchronous motors using a saturation model,” International Journal of Control, vol. 89, no. 3, pp. 535-549, 2016.

  • [5] B. Yi, R. Ortega, and W. Zhang, “Relaxing the conditions for parameter estimation-based observers of nonlinear systems via signal injection,” Systems and Control Letters, vol. 111, pp. 18-26, 2018.

  • [6] C. Wang and L. Xu, “A novel approach for sensorless control of PM machines down to zero speed without signal injection or special PWM technique,” IEEE Transactions on Power Electronics, vol. 19, no. 6, pp. 1601-1607, 2004.

  • [7] B. Lehman and R. M. Bass, “Extensions of averaging theory for power electronic systems,” IEEE Transactions on Power Electronics, vol. 11, no. 4, pp. 542-553, July 1996.

  • [8] A. Filippov, Differential equations with discontinuous righthand sides. Control systems, set Mathematics and its Applications. Kluwer, 1988.

  • [9] J. Sanders, F. Verhulst, and J. Murdock, Averaging methods in nonlinear dynamical systems, 2nd ed. Springer, 2005.



Sensorless Rotor Position Estimation by PWM-Induced Signal Injection

Abstract: We demonstrate how the rotor position of a PWM-controlled PMSM can be recovered from the measured currents, by suitably using the excitation provided by the PWM itself. This provides the benefits of signal injection, in particular the ability to operate even at low velocity, without the drawbacks of an external probing signal. We illustrate the relevance of the approach by simulations and experimental results.


Index Terms—Sensorless control, PMSM, signal injection, PWM-induced ripple.


Nomenclature



  • PWM Pulse Width Modulation

  • xdq Vector (xd, xq)T in the dq frame

  • xαβ Vector (xα, xβ)T in the αβ frame

  • xabc Vector (xa, xb, xc) in the abc frame

  • Rs Stator resistance


  • custom characterRotation matrix with angle π/2;









(



0



-
1





1


0



)





  • I Moment of inertia

  • n Number of pole pairs

  • ω Rotor speed

  • Tl Load torque

  • θ, {circumflex over (θ)} Actual, estimated rotor position

  • ϕm Permanent magnet flux

  • Ld, Lq d and q-axis inductances

  • C Clarke transformation:








2
3



(



1




-
1

/
2





-
1

/
2





0




3

/
2





-

3


/
2




)






  • custom character(θ) Rotation matrix with angle θ:









(




cos





θ





-
sin






θ






sin





θ




cos





θ




)





  • ε PWM period

  • um PWM amplitude

  • S(θ) Saliency matrix

  • O “Big O” symbol of analysis: k(z, ε)=O(ε) means ∥k(z, ε)∥≤Cε, for some C independent of z and ε.



I. Introduction

Sensorless control of AC motors in the low-speed range is a challenging task. Indeed, the observability of the system from the measurements of the currents degenerates at standstill, which limits the performance at low speed of any fundamental-model-based control law.


One now with widespread method to overcome this issue is the so-called signal injection technique. It consists in superimposing a fast-varying signal to the control law. This injection creates ripple on the current measurements which carries information on the rotor position if properly decoded. Nonetheless, introducing a fast-varying signal increases acoustic noise and may excite mechanical resonances. For systems controlled through Pulse Width Modulation (PWM), the injection frequency in moreover inherently limited by the modulation frequency. That said, inverter-friendly waveforms can also be injected to produce the same effect, as in the so-called INFORM method [1], [2]. For PWM-fed Permanent Magnet Synchronous Motors (PMSM), the oscillatory nature of the input may be seen as a kind of generalised rectangular injection on the three input voltages, which provides the benefits of signal injection, in particular the ability to operate even at low velocity, without the drawbacks of an external probing signal.


We build on the quantitative analysis developed (3) to demonstrate how the rotor position of a PWM-controlled PMSM can be recovered from the measured currents, by suitably using the excitation provided by the PWM itself. No modification of the PWM stage nor injection a high-frequency signal as in [4] is required.


The paper runs as follows: we describe in section II the effect of PWM on the current measurements along the lines of [3], slightly generalizing to the multiple-input multiple output framework. In section III, we show how the rotor position can be recovered for two PWM schemes schemes, namely standard single-carrier PWM and interleaved PWM. The relevance of the approach is illustrated in section IV with numerical and experimental results.


II. Virtual Measurement Induced by PWM

Consider the state-space model of a PMSM in the dq frame












d






ϕ
s
dq


dt

=


u
x
dq

-


R
s



l
s
dq


-

ω𝒥ϕ
s
dq



,




(

1

a

)









J
n




dt


=



w
x

dq
τ




𝒥ϕ
s
dq


-

T
l



,




(

1

b

)









d





θ


d





t


=
ω

,




(

1

c

)








where ϕsdq is the stator flux linkage, ω the rotor speed, θ the rotor position, tsdq the stator current, usdq the stator voltage, and Tl the load torque; Rs, J, and n are constant parameters (see nomenclature for notations). For simplicity we assume no magnetic saturation, i.e. linear current-flux relations

Ldlsdsd−ϕm  (2a)
Lqlsqsq,  (2b)

with ϕm the permanent magnet flux; see [5] for a detailed discussion of magnetic saturation in the context of signal injection. The input is the voltage usabc through the relation

usdq=custom character(−θ)Cusabc.   (3)

In an industrial drive, the voltage actually impressed is not directly usabc, but its PWM encoding








(


u
s
abc

,

t
ɛ


)

,





with ε the PWM period. The function custom character describing the PWM is 1-periodic and mean usabc in the second argument, i.e. custom character(usabc, τ+1)=custom character(usabc, τ) and ∫01custom character(usabc, τ)dτ=usabc; its expression is given in section III. Setting s0abc(usabc, σ):=(custom character(usabc, σ)−usabc, the impressed voltage thus reads








u
pwm
abc

=


u
s
abc

+


s
0
abc



(


u
s
abc

,

t
ɛ


)




,





where s0abc is 1-periodic and zero mean in the second argument; s0abc can be seen as a PWM-induced rectangular probing signal, which creates ripple but has otherwise no effect. Finally, as we are concerned with sensorless control, the only measurement is the current isabc=CTcustom character(θ)lsdq, or equivalently isαβ=custom character(θ)lsdq since isa+isb+isc=0.


A precise quantitative analysis of signal injection is developed in [3], [6]. Slightly generalizing these results to the multiple-input multiple-output case, the effect of PWM-induced signal injection can be analyzed thanks to second-order averaging in the following way. Consider the system








x
.

=


f


(
x
)


+


g


(
x
)




(

u
+


s
0

(

u
,

t
ɛ


)


)




,





y
=

h


(
x
)



,





where u is the control input, ε is a the (assumed small) PWM period, and s0 is 1-periodic in the second argument, with zero mean in the second argument; then we can extract from the actual measurement y with an accuracy of order ε the so-called virtual measurement (see [3], [6])

yv(t):=h′(x(t))g(x(t))custom character(u(t)),

i.e. we can compute by a suitable filtering process an estimate

custom character(t)=yv(t)+O(ε).

The matrix custom character, which can be computed online, is defined by

custom character(ν):=∫01s1(ν,τ)s1T(ν,τ)dτ,

where s1 is the zero-mean primitive in the second argument of s0, i.e.

s1(ν,τ):=∫01s0(ν,τ)dσ−∫010τs0(ν,σ)dσdτ.

The quantity






ɛ







h




(

x


(
t
)


)




g


(

x


(
t
)


)





s
1

(


u


(
t
)


,

t
ɛ


)






is the ripple caused on the output y by the excitation signal








s
0

(


u


(
t
)


,

t
ɛ


)

;





though small, it contains valuable information when properly processed.


For the PMSM (1)-(3) with output isαβ, some algebra yields








y
v

=




[








(
θ
)




(




1

L
d




0




0



1

L
q





)





0

2
×
1












(
θ
)




t
dq





]



[








(

-
θ

)



𝒞






0

1
×
2







0

1
×
2





]





𝒜
abc



(

u
abc

)



=


𝒮


(
θ
)





𝒞𝒜
abc



(

u
abc

)





,








where














𝒜
abc



(

v
abc

)


:=



0
1





s
1
abc



(


v
abc

,
τ

)





s
1

abc
τ




(


v
abc

,
τ

)



d





τ



,






and S(θ) is the co-called saliency matrix introduced in [5],







𝒮


(
θ
)


=




L
d

+

L
q



2


L
d



L
q






(




1
+




L
q

-

L
d




L
d

+

L
q




cos





2

θ








L
q

-

L
d




L
d

+

L
q




sin





2

θ









L
q

-

L
d




L
d

+

L
q




sin





2

θ




1
-




L
q

-

L
d




L
d

+

L
q




cos





2

θ





)

.







If the motor has sufficient geometric saliency, i.e. if Ld and Lq are sufficiently different, the rotor position θ can be extracted from yv as explained in section III. When geometric saliency is small, information on θ is usually still present when magnetic saturation is taken into account, see [5].


III. Extracting θ from the Virtual Measurement

Extracting the rotor position θ from yv depends on the rank of the 2×3 matrix Ccustom characterabcabc). The structure of this matrix, hence its rank, depends on the specifies of the PWM employed. After recalling the basics of single-phase PWM, we study two cases: standard three-phase PWM with a single carrier, and three-phase PWM with interleaved carriers.


Before that, we notice that Ccustom characterabcabc) has the same rank as the 2×2 matrix

custom characterαβabc):=Ccustom characterabcabc)CT=∫01s1αβabc,τ)s1αβTabc,τ)dτ,

where s1αβabc, τ):=Cs1abcabc, τ). Indeed,

custom characterαβabc)custom characterαβTabc)=Ccustom characterabcabc)CTCcustom characterabcTabc)CT=Ccustom characterabcabc)(Ccustom characterabcabc))T,

which means that custom characterαβabc and Ccustom characterabcabc) have the same singular values, hence the same rank. There is thus no loss of information when considering S(θ)custom characterαβ(uabc) instead of the original virtual measurement yv.


A. Single-Phase PWM


In “natural” PWM with period ε and range [−um, um], the input signal u is compared to the ε-periodic triangular carrier







c


(
t
)


:=

{





u
m

+

4


w
(

t
ɛ

)





if




-


u
m

2




w
(

t
ɛ

)


0







u
m

-

4


w
(

t
ɛ

)





if



0


w


(

t
ɛ

)





u
m

2











the 1-periodic function







w


(
σ
)


:=



u
m



mod


(


σ
+

1
2


,
1

)



-


u
m

2







wraps the normalized time






σ
=


t
ɛ








to




[


-


u
m

2


,


u
m

2


]

.







If u varies slowly enough, it crosses the carrier c exactly once on each rising and falling ramp, at times t1u<t2u such that







u


(

t
1
u

)


=


u
m

+

4


w
(


t
1
u

ɛ

)










u


(

t
2
u

)


=


u
m

-

4



w
(


t
2
u

ɛ

)

.








The PWM-encoded signal is therefore given by








u
pwm



(
t
)


=

{





u
m



if




-


u
m

2


<

W


(

t
ɛ

)




W


(


t
1
u

ɛ

)








-

u
m




if




W


(


t
1
u

ɛ

)


<

W


(

t
ɛ

)




(


t
2
u

ɛ

)







u
m



if




W


(


t
2
u

ɛ

)


<

W


(

t
ɛ

)





u
m

2





.







FIG. 10 illustrates the signals u, c and upwm. The function













(

u
,
σ

)


:=



{




u
m



if





-
2



u
m


<

4


w


(
σ
)





u
-

u
m








-

u
m




if




u
-

u
m


<

4


w


(
σ
)






u
m

-
u







u
m



if





u
m

-
u

<

4


w


(
σ
)





2


u
m


















=




u
m

+


u
m







sign


(

u
-

u
m

-

4


w


(
σ
)




)



+












u
m







sign


(

u
-

u
m

+

4


w


(
σ
)




)



,









which is obviously 1-periodic and with mean u with respect to its second argument, therefore completely describes the PWM process since








u
pwn



(
t
)


=





(


u


(
t
)


,

t
ɛ


)


.





The induced zero-mean probing signal is then









s
0



(

u
,
σ

)


:=






(

u
,
σ

)


-
u

=


u
m

-
u
+


u
m







sign


(



u
-

u
m


4

-

w


(
σ
)



)



+


u
m







sign


(



u
-

u
m


4

+

W


(
σ
)



)






,





and its zero-mean primitive in the second argument is








s
1



(

u
,
σ

)


:=



(

1
-

u

u
m



)



w


(
σ
)



-





u
-

u
m


4

-

w


(
σ
)





+






u
-

u
m


4

+

w


(
σ
)





.







The signals s0, s1 and w are displayed in FIG. 11. Notice that by construction s0(±um, σ)=s1(±um, σ)=0, so there is no ripple, hence no usable information, at the PWM limits.


B. Three-Phase PWM with Single Carrier


In three-phase PWM with single carrier, each component usk, k=a, b, c, of uxabc is compared to the same carrier, yielding

s0k(usabc,σ):=s0(usk,σ)
s1k(usabc,σ):=s1(usk,σ),

with s0 and s1 as in single-phase PWM. This is the most common PWM in industrial drives as it is easy to implement.


Notice that if exactly two components of usabc are equal, for instance usc=usb≠usa, then

s1c(usabc,σ)=s1b(usabc,σ)≠s1a(usabc,σ),

which implies in turn that custom characterαβ(uabc) has rank 1 (its determinant vanishes); it can be shown this is the only situation that results in rank 1. If all three comments of usabc are equal, then custom characterαβ(uabc) has rank 0 (i.e. all its entries are zero); this is a rather exceptional condition that we rule out here. Otherwise custom characterαβ(uabc) has rank 2 (i.e. is invertible). FIG. 12 displays examples of the shape of s1αβ, in the rank 2 case (top), and in the rank 1 case where usc=usb≠usa.


As the rank 1 situation very often occurs, it must be handled by the procedure for extracting θ from S(θ)custom characterαβ(uabc). This can be done by linear least squares, thanks to the particular structure of S(θ). Setting







(



λ


μ




μ


v



)

:=


𝒜

α





β




(

u
abc

)









(




y
11




y
12






y
21




y
22




)

:=



2


L
d



L
q




L
d

+

L
q






y
v

.







and







L
:=



L
d

+

L
q




L
q

-

L
d




,





we can rewrite yv =S(θ)custom characterαβ(uabc) as









(



λ


μ




μ


v





-
μ



λ





-
v



μ



)




:=
P





(




cos





2

θ






sin





2





θ




)


=

L




(





y
11

-
λ







y
12

-
μ







y
21

-
μ







y
22

-
v




)




:=
d



.







The least-square solution of this (consistent) overdetermined linear system is







rCl


(




cos





2

θ






sin





2





θ




)


=




L


[


P
T


P

]



-
1




P
T


d

=


L


λ
2

+

2


μ
2


+

v
2





P
T









d
=


L


λ
2

+

2


μ
2


+

v
2






(





λ






y
11


+

μ


(


y
12

-

y
21


)


-

vy
22

-

λ
2

+

v
2








λ






(


y
11

+

y
22


)


+

vy
12

+

λ






y
21


-

2


μ


(

λ
+
v

)







)

.






Estimates custom character, custom character for cos 2θ, sin 2θ are obtained with the same formulas, using instead of the actual yij the estimated







(










)

:=




2


L
d



L
q




L
d

+

L
q





=




2


L
d



L
q




L
d

+

L
q





y
v


+


𝒪


(
ɛ
)


.








We thus have






:=


L



+

μ


(

-

)


-

v


-

λ
2

+


v
2






λ
2

+

2


μ
2


+

v
2




=


cos





2

θ

+

𝒪


(
ɛ
)










:=


L




μ


(

+

)


+

v


+

λ


-

2


μ


(

λ
+
v

)






λ
2

+

2


μ
2


+

v
2




=


sin





2

θ

+


𝒪


(
ɛ
)


.








Finally, we get an estimate {circumflex over (θ)} of θ by

{circumflex over (θ)}:=½ atan 2(custom character,custom character)+kπ=θ+O(ε),

where kεcustom characteris the number of turns.


C. Three-Phase PWM with Interleaved Carriers


At the cost of a more complicated implementation, it turns out that a PWM scheme with (regularly) interleaved carries offers several benefits over single-carrier PWM. In this scheme, each component of usabc is compared to a shifted version of the same triangular carrier (with shift 0 for axis a, ⅓ for axis b, and ⅔ axis c), yielding











s
0
a



(


u
s
abc

,
σ

)


:=


s
0



(


u
s
a

,
σ

)








s
1
a



(


u
s
abc

,
σ

)


:=


s
1



(


u
s
a

,
σ

)










s
0
b



(


u
s
abc

,
σ

)


:=


s
0



(


u
s
b

,

σ
-

1
3



)








s
1
b



(


u
s
abc

,
σ

)


:=


s
1



(


u
s
b

,

σ
-

1
3



)










s
0
c



(


u
s
abc

,
σ

)


:=


s
0



(


u
s
c

,

σ
-

2
3



)








s
1
c



(


u
s
abc

,
σ

)


:=



s
1



(


u
s
c

,

σ
-

2
3



)


.









FIG. 13 illustrates the principle of this scheme. FIG. 14 displays an example of the shape of s1αβ, which always more or less looks like two signals in quadrature.


Now, even when two, or even three, components of usabc are equal, custom characterαβ(uabc) remains invertible (except of course at the PWM limits), since each component has, because of the interleaving, a different PWM pattern. It is therefore possible to recover all four entries of the saliency matrix S(θ) by

custom character:=custom character·[custom characterαβ(uabc)]−1=S(θ)+O(ε).

Notice now that thanks to the structure of S(θ)=(sij)ij, the rotor angle θ be computed from the matrix entries by








s
12

+

s
21


=




L
q

-

L
d




L
d



L
q




sin





2





θ









s
11

-

s
22


=




L
q

-

L
d




L
d



L
q




cos





2





θ








θ
=



1
2


atan





2


(



s
12

+

s
21


,


s
11

-

s
22



)


+

k





π



,





θ=½ atan2(s12+s21,s11s22)+kπ,

where kεcustom character is the number of turns. An estimate {circumflex over (θ)} of θ can therefore be computed from the entries (custom character)ij of custom character by

{circumflex over (θ)}=½ atan 2(custom character+custom character,custom charactercustom character)+kπ=θ+O(ε),

without requiring the knowledge the magnetic parameters Ld and Lq, which is indeed a nice practical feature.


IV. Simulations and Experimental Results

The demodulation procedure is tested both in simulation and experimentally. All the tests, numerical and experimental, use the rather salient PMSM with parameters listed in Table 1. The PWM frequency is 4 kHz.


The test scenario is the following: starting from rest at t=0 s, the motor remains there for 0.5 s, then follows a velocity ramp from 0 to 5 Hz (electrical), and finally stays at 5 Hz from t=8.5 s; during all the experiment, it undergoes a constant load torque of about 40% of the rated torque. As this paper is only concerned with the estimation of the rotor angle θ, the control law driving the motor is allowed to use the measured angle. Besides, we are not yet able to process the data in real-time, hence the data are recorded and processed offline.









TABLE 1





RATED PARAMETERS



















Rated power
400
W



Rated voltage (RMS)
400
V



Rated current (RMS)
1.66
A



Rated speed
1800
RPM



Rated torque
2.12
N.m










Number of pole pairs n
2











Moment of inertia J
6.28
kg.cm2



Stator resistance Ra
3.725
Ω



d-axis inductance Ld
33.78
mH



q-axis inductance Lq
59.68
mH











A. Single Carrier PWM.


The results obtained in simulation by the reconstruction procedure of section III-B for cos 2θ, sin 2θ, and θ, are shown in FIG. 15 and FIG. 16. The agreement between the estimates and the actual values is excellent.


The corresponding results on experimental data are shown in FIG. 19 and FIG. 20. Though of course not as good as in simulation, the agreement between the estimates and the ground truth is still very satisfying. The influence of magnetic saturation may account for part of the discrepancies.



FIG. 17 displays a close view of the ripple envelope s1αβ in approximately the same conditions as in FIG. 12 when the rank of custom characterαβ(yabc) is 2 case (top) and when the rank is 1 case with usc=usb≠usa. They illustrate that though the experimental signals are distorted, they are nevertheless usable for demodulation.


Finally, we point out an important difference between the simulation and experimental data. In the experimental measurements, we notice periodic spikes in the current measurement, see FIG. 18; these are due to the discharges of the parasitic capacitors in the inverter transistors each time a PWM commutation occurs. As it might hinder the demodulation procedure of [3], [6], the measured currents were first preprocessed by a zero-phase (non-casual) moving average with a short window length of 0.01ε. We are currently working on an improved demodulation procedure not requiring prefiltering.


B. Interleaved PWM (Simulation)


The results obtained in simulation by the reconstruction procedure of section III-C for the saliency matrix and S(θ) and for θ are shown in FIG. 21 and FIG. 22. The agreement between the estimates and the actual values is excellent. We insist that the reconstruction does not require the knowledge of the magnetic parameters.


V. Conclusion

This paper provides an analytic approach for the extraction of the rotor position of a PWM-fed PSMM, with signal injection provided by the PWM itself. Experimental and simulations results illustrate the effectiveness of this technique.


Further work includes a demodulation strategy not requiring prefiltering of the measured currents, and suitable for real-time processing. The ultimate goal is of course to be able to use the estimated rotor position inside a feedback loop.


REFERENCES



  • [1] M. Schroedl, “Sensorless control of ac machines at low speed and standstill based on the “inform” method,” in IAS '96. Conference Record of the 1996 IEEE Industry Applications Conference Thirty-First IAS Annual Meeting, vol. 1, 1996, pp. 270-277 vol. I.

  • [2] E. Robeischl and M. Schroedl, “Optimized inform measurement sequence for sensorless pm synchronous motor drives with respect to minimum current distortion,” IEEE Transactions on Industry Applications, vol. 40, no. 2, 2004.

  • [3] D. Surroop, P. Combes, P. Martin, and P. Rouchon, “Adding virtual measurements by pwm-induced signal injection,” in 2020 American Control Conference (ACC), 2020, pp. 2692-2698.

  • [4] C. Wang and L. Xu, “A novel approach for sensorless control of PM machines down to zero speed without signal injection or special PWM technique,” IEEE Transactions on Power Electronics, vol. 19, no. 6, pp. 1601-1607, 2004.

  • [5] A. K. Jebai, F. Malrait, P. Martin, and P. Rouchon, “Sensorless position estimation and control of permanent-magnet synchronous motors using a saturation model,” International Journal of Control, vol. 89, no. 3, pp. 535-549, 2016.

  • [6] P. Combes, A. K. Jebai, F. Malrait, P. Martin, and P. Rouchon, “Adding virtual measurements by signal injection,” in American Control Conference, 2016, pp. 999-1005.



The present disclosure also relates to the following subject-matter:

  • Clause 1: A method for controlling an actuator, comprising providing a control signal for the actuator and modulating the control signal by a modulation signal.
  • Clause 2: The method of clause 1, further comprising determining a zero-mean primitive of the modulated control signal, obtaining measurement signals from the actuator, obtaining virtual measurements by demodulating the measurement signals based on the zero-mean primitive of the modulated control signal, adapting the control signal in response to the obtained virtual measurements.
  • Clause 3: The method of clause 1 or 2, wherein the modulation signal comprises pulse-width modulation.
  • Clause 4: The method of any one of clauses 1 to 3, wherein the actuator is an electric motor.
  • Clause 5: A control system for controlling an actuator, comprising a control module generating a control signal, a PWM-module generating a modulated control signal by pulse-width modulation and a zero-mean primitive of the modulated control signal, a measurement unit for obtaining measurement signals from the actuator, and an estimator module for obtaining virtual measurements by demodulating the measurement signals based on the zero-mean primitive of the modulated control signal, wherein the control module is arranged for adapting the control signal based on feedback in the form of the obtained virtual measurements.
  • Clause 6: The system of clause 5, wherein the modulation signal comprises pulse-width modulation.
  • Clause 7: The system of clause 5 or 6, wherein the actuator is an electric motor.


This disclosure is not limited to the specific embodiments described here, which are only examples. The invention encompasses every alternative that a person skilled in the art would envisage when reading this text.

Claims
  • 1. A variable speed drive for the closed loop control of the operation of an AC electric motor based on a given control law, the variable speed drive comprising: an output terminal for delivering a controlled alternating drive voltage (upwm) to the controlled AC electric motor;a solid-state power inverter for generating the drive voltage;a drive controller for controlling the generation of the drive voltage by the power inverter; anda drive current sensing device for measuring the instantaneous intensity of the drive current taken up by the controlled AC electric motor and for providing the resulting measurements as a drive current intensity signal to the drive controller,wherein the drive controller includes:a pulse-width modulation generator;a control law module storing the given control law; anda state variable estimation module for estimating the instantaneous value of at least one state variable of the controlled AC electric motor,wherein the control law module is adapted to, based on the stored control law and state variable estimates provided by the estimation module, compute a target voltage signal and output the computed target voltage signal to the pulse-width modulation generator,wherein the pulse-width modulation generator is adapted to:approximate the received target voltage signal with a pulse-width modulated inverter control signal;control the operation of the power inverter using the inverter control signal, thereby obtaining the drive voltage;compute, based on the deviation between the inverter control signal and the target voltage signal, a state variable estimation support signal; andoutput the computed state variable estimation support signal to the state variable estimation module, andwherein the state variable estimation module is adapted to:estimate the instantaneous value of a state variable of the AC electric motor based on the received state variable estimation support signal and the drive current intensity signal provided by the drive current sensing device; andoutput the resulting state variable estimate to the control law module.
  • 2. The variable speed drive of claim 1, wherein the pulse-width modulation generator is adapted to compute the state variable estimation support signal based on a pulse-width modulation inherent disturbance signal, which is obtained by subtracting the target voltage signal from the inverter control signal.
  • 3. The variable speed drive of claim 2, wherein the pulse-width modulation generator is adapted to compute the state variable estimation support signal by integrating the disturbance signal to obtain the primitive of the disturbance signal.
  • 4. The variable speed drive of claim 1, wherein the variable speed drive is adapted to rely on a single feedback to perform closed loop control of the AC electric motor, namely the drive current intensity signal provided by the drive current sensing device.
  • 5. The variable speed drive of claim 1, wherein the variable speed drive is adapted to control the operation of the AC electric motor without the injection of a dedicated probing signal into the drive voltage.
  • 6. The variable speed drive of claim 1, wherein the drive controller further includes an analog-to-digital converter for converting the drive current intensity signal into a digital signal prior to its input into the state variable estimation module.
  • 7. The variable speed drive of claim 1, wherein the state variable estimation module is adapted to estimate the instantaneous value of the rotor position of the electric motor based on the received state variable estimation support signal and the drive current intensity signal provided by the drive current sensing device.
  • 8. The variable speed drive of claim 1, wherein the pulse-width modulation generator is adapted to apply three-phase pulse-width modulation with single carrier to generate the inverter control signal.
  • 9. The variable speed drive of claim 1, wherein the pulse-width modulation generator is adapted to apply three-phase pulse-width modulation with interleaved carriers to generate the inverter control signal.
  • 10. An electric drive assembly comprising a synchronous reluctance motor and a variable speed drive of claim 1 for controlling the synchronous reluctance motor.
  • 11. An electric drive assembly comprising a permanent-magnet synchronous motor and a variable speed drive of claim 1 for controlling the permanent-magnet synchronous motor.
  • 12. A method of controlling, in a closed loop, the operation of an AC electric motor based on a given control law, the method comprising the following steps: a) measuring the instantaneous intensity of the drive current taken up by the controlled AC electric motor;b) estimating the instantaneous value of a state variable of the AC electric motor using the measured drive current intensity;c) computing, based on the given control law and the estimated state variable, a target voltage signal;d) approximating the computed target voltage signal with a pulse-width modulated inverting control signal;e) computing, based on the deviation between the inverting control signal and the target voltage signal, a state variable estimation support signal;f) generating, by voltage inversion, a controlled alternating drive voltage using the inverting control signal; andg) delivering the generated drive voltage to the controlled AC electric motor;wherein the state variable estimation according to step b) relies on the state variable estimation support signal computed in step e) as an additional input together with the drive current intensity measured in step a).
Priority Claims (1)
Number Date Country Kind
20305748 Jul 2020 EP regional
Parent Case Info

The present application claims priority to U.S. provisional utility patent application Ser. No. 62/905,663 filed on Sep. 25, 2019 and to European application serial no. 20305748.4 filed on Jul. 2, 2020, which are both incorporated herewith in their entirety.

US Referenced Citations (1)
Number Name Date Kind
9252698 Kume Feb 2016 B2
Foreign Referenced Citations (1)
Number Date Country
102014106667 Apr 2015 DE
Non-Patent Literature Citations (2)
Entry
Wang C et al: “A Novel Approach for Sensorless Control of PM Machines Down to Zero Speed Without Signal Injection or Special PWM Technique”, IEEE Transactions on Power Electronics, Institute of Electrical and Electronics Engineers, USA, vol. 19, No. 6, Nov. 1, 2004 (Nov. 1, 2004), pp. 1601-1607, XP011121751, ISSN: 0885-8993, DOI: 10.1109/TPEL.2004.836617.
Extended European Search Report for Appln No. 20305748.4-1202 dated Nov. 10, 2020, 11 pages.
Related Publications (1)
Number Date Country
20210091703 A1 Mar 2021 US
Provisional Applications (1)
Number Date Country
62905663 Sep 2019 US