Various example embodiments relate to control of industrial processes.
In synchronous electric motors, the rotation of the motor shaft (i.e., of the rotor) is synchronized with the frequency of the supply current at steady state so that the rotation period is exactly equal to an integral number of alternating current (AC) cycles. One common way for controlling synchronous electric motors is the so-called vector control where the torque of the motor is controlled by controlling a stator current vector. To enable said vector control, the angular position of the rotor needs to be estimated (e.g., using voltage injection). This estimation is mainly dependent on the saliency of the motor. One of the main challenges for any saliency-based sensorless method is overcoming the error introduced by differential cross coupling between the d- and q-axes in the rotating reference frame.
U.S. Pat. No. 10,224,851 B2 discloses a system and a method for sensorless control of electric machines using magnetic alignment signatures. WO 00/25418 A1 discloses a system and a method for speed-sensorless control of an induction machine. SILVERIO BOLOGNANI ET AL: “Sensorless quasi-standstill and very low-speed position detection in non-salient PMSMs based on current injection and back-EMF observer”, SENSORLESS CONTROL FOR ELECTRICAL DRIVES (SLED), 2012 IEEE SYMPOSIUM ON, IEEE, 21 Sep. 2012 (2012 Sep. 21), pages 1-7, P032322100, DOI: 10.1109/SLED.2012.6422813, ISBN: 978-1-4673-2966-8 discloses methods for position detection of a permanent magnet synchronous motor based on the detection of torque production by signal injection. Specifically, two different application cases are disclosed: an initial high-accuracy position detection at quasi-standstill and a position and speed tracking for closed-loop sensorless speed control.
According to an aspect, there is provided the subject matter of the independent claims. Embodiments are defined in the dependent claims.
One or more examples of implementations are set forth in more detail in the accompanying drawings and the description below. Other features will be apparent from the description and drawings, and from the claims.
Some embodiments provide an apparatus, a method, and computer readable media for performing angular position error estimation for a synchronous motor.
In the following, example embodiments will be described in greater detail with reference to the attached drawings, in which
The following embodiments are only presented as examples. Although the specification may refer to “an”, “one”, or “some” embodiment(s) and/or example(s) in several locations of the text, this does not necessarily mean that each reference is made to the same embodiment(s) or example(s), or that a particular feature only applies to a single embodiment and/or example. Single features of different embodiments and/or examples may also be combined to provide other embodiments and/or examples.
A synchronous motor is an electric motor where the rotation of the motor shaft (i.e., of the rotor) is synchronized with the frequency of the supply current at steady state so that the rotation period is equal to an integral number of alternating current (AC) cycles. Synchronous motors may contain either multiphase AC electromagnets or permanent magnets on the stator of the motor that create a magnetic field which rotates in phase with the oscillations of the line current. The rotor with permanent magnets or electromagnets turns in step with the stator field at the same rate and as a result, provides the second synchronized rotating magnet field of any AC motor. Some alternative synchronous motors, namely synchronous reluctance motors, generate torque through magnetic reluctance. In synchronous reluctance motors, the stator consists of multiple projecting (salient) electromagnet poles while the rotor consists of soft magnetic material having multiple projections acting as salient magnetic poles through magnetic reluctance. Synchronous reluctance motors have an equal number of stator and rotor poles.
One common way for controlling synchronous motors is the so-called vector control where the torque of the machine is controlled by controlling a stator current and/or voltage vector. The stator current/voltage vector is a vector comprising two orthogonal stator current/voltage components derived from stator currents/voltages of a three-phase AC electric machine. One of said components defines the magnetic flux of the motor, the other the torque of the motor. These stator current/voltage components may be written either in a stationary reference frame as α- and β-axis stator currents/voltages or in a moving reference frame (moving in sync with the rotor) as d- and q-axis stator currents/voltages, respectively. The actual control in the vector control is typically performed for the d- and q-axis stator currents or voltages while the α- and β-axis stator currents or voltages are used for actually driving the synchronous motor. The d- and q-axis currents/voltages may be converted to the α- and β-axis currents/voltages using inverse Park transform while an opposite transformation is possible using Park transform.
For performing the Park and inverse Park transforms, the angular position of the rotor (i.e., the rotation angle of the rotor) needs to be known. The voltage injection methods may be used for the estimation of the angular position of the rotor. This estimation is dependent on the saliency of the motor (i.e., the variation of the inductance at the motor terminal according to the rotor position). One of the main challenges in any saliency-based sensorless method for angular position estimation is overcoming the error introduced by the differential cross coupling between the d- and q-axes (i.e., direct and quadrature axes) in the rotating reference frame. The d- and q-axes are the single-phase representations of the flux contributed by the three separate sinusoidal phase quantities (denoted conventionally with letters “U”, “V” and “W”) at the same angular velocity. The d-axis is the magnetic axis of the rotor while the q-axis is the axis along which torque is produced (i.e., the torque may be directly controlled by adjusting the q-axis current). By convention, the quadrature axis always will lead the direct axis electrically by 90° or, in a more general case where the number of magnetic pole pair may be larger than one, by 180° /(2p), where p is the number of magnetic polar pairs. The cross-coupling between d- and q-axes is typically described in the voltage equation as an inductance, as will discussed below.
In the following, the problem of error in angular position estimation in synchronous motors controlled using vector control with voltage injection is discussed in a general sense and studied analytically before discussing solutions to said problem according to embodiments in detail. The following voltage equations describe the voltage balance in a non-hysteretic magnetic system where the only losses are related to metal losses (e.g., copper losses):
where ud and ud are stator voltages associated with the d- and q-axes, id and iq are stator currents associated with the d- and q-axes, Rs is a resistance associated with resistive losses in the metal, λd and λq are flux linkage components for d- and q-axes and ωme is the angular speed (or equally angular frequency) of the rotor. The flux linkages may be written as λd=λm+Ldid and λq=Lqiq, where λm is a magnet flux.
In cases where the magnetic relation between the d-axis currents and the d-axis magnetic fluxes is also affected by the q-axis current (and vice versa, when the q-axis quantities are affected by the d-axis current), an inductive cross-coupling term Ldq is introduced into the voltage equations. In such cases, the voltage equation may be written (in matrix form) as:
For a high-frequency injection in the d-axis, the following voltage waveform may be used:
where udh is an amplitude of the d-axis stator voltage signal, ωh is the (high) angular frequency of the d-axis voltage signal and t is time. While in the above equation high-frequency voltage injection is carried out for the d-axis, it should be noted high-frequency voltage injection may be equally carried out for the q-axis by defining
By applying high-frequency voltage injection in the previous equation to the voltage equation including the inductive cross-coupling term and by further assuming that the high-frequency voltage injection is applied at relatively high frequencies (meaning that Rs is close to zero and can be thus neglected) and at very low speeds (meaning that ωme is close to zero and can be thus neglected), the voltage equation may be written as
Extracting the currents as function of the voltages, it follows that:
As the supplied injected voltage is given in the estimated dq reference frame, an estimated angular position θobserver, which is not necessarily equal to the actual angular position, is considered. In presence of an angular position error Δθ, the relation between the estimated angular position θobserver and the actual angular position θm is θobserver=θme+Δθ. The difference between the estimated and the actual dq reference frames may be written in the form of a rotating matrix:
Therefore, the high-frequency currents in the actual dq reference frame may be written as:
Furthermore, the term îqh may be demodulated (to remove the term sin (ωht)) and used for extracting the rotor position:
By setting îqh=0, the angular position error Δθ may be derived. Said angular position error may be written as
In the presence of a non-zero Ldq, by setting Δθ=0, the magnitude of the error signal ϵ may be written as (based on the above equation for îqh):
While in the special case where Ldq is equal to zero and thus the angular position error is also equal to zero, the rotor position can be extracted by controlling îqh without errors, in most practical cases, this is not true and a compensation for the angular position error needs to be arranged so as to accurately estimate the angular position of the rotor. However, this is not a simple task as measuring the inductances Kdq, Ld and Lq directly is not feasible. The embodiments provide a solution enabling accurate evaluation of the position error without a position sensor and without (substantially) rotating the synchronous motor.
In the following, the operation of the system of
Initially, the Δθ estimator state machine may maintain, in a database, only information on one or more pre-defined pulsating torque signals, each of which corresponds to a particular torque operating point (i.e., a particular torque level). The goal of the angular position error estimation procedure to be discussed below is to gather information on the error in the estimated angular position of the rotor of the synchronous motor 111 (as estimated by the illustrated system using high-frequency voltage injection) at one or more torque operating points by operating the synchronous motor 111 according to each of the one or more pre-defined pulsating torque signals in sequence. Preferably, the one or more torque operating points comprises a plurality of torque operating points and cover the whole operational range of the synchronous motor 111. Said error in the estimated angular position is caused by the cross-coupling inductance Ldq associated with the d- and q-axis stator currents, as discussed above. Further, the plurality of pre-defined pulsating torque signals corresponding to the plurality of torque operating points are, preferably, applied sequentially in order of increasing torque operating point (i.e., starting from the lowest torque operating point and ending with the highest torque operating point). In other embodiments, another order may be employed (e.g., order of a decreasing torque operating point or a random order). The spacing between consecutive torque operating points may be the same for all consecutive torque operating points.
Each of the one or more pre-defined pulsating torque signals defined in the database of the Δθ estimator state machine 101 may comprise one or more positive pulses (e.g., positive square pulses) and one or more negative pulses (e.g., negative square pulses). Each of said one or more positive pulses have preferably the same peak amplitude. A peak amplitude of each pre-defined pulsating torque signal corresponds to a torque operating point of the synchronous motor. Further, each pre-defined pulsating torque signal has a zero mean so that the total movement of the rotor of the synchronous motor 111 when the synchronous motor 111 is driven according to the pre-defined pulsating torque signal is minimized. In other words, the initial angular position of the rotor before the application of the pre-defined pulsating torque signal should be approximately the same as the final angular position of the rotor following the application of the pre-defined pulsating torque signal. Preferably, said one or more positive pulses and said one or more negative pulses should also be arranged in such a manner that the total movement of the rotor caused by the application of the pre-defined pulsating torque signal is minimized. In some embodiments, the pre-defined pulsating torque signal may, for example, consist of a first positive (square) pulse having a first duration tstep, a negative (square) pulse having a second duration 2tstep (i.e., being twice the first duration) and a second positive (square) pulse having the first duration tstep. These three pulses may be in the described order (or in some other order) and/or they may or may not directly follow each other (i.e., there is zero or non-zero time separation between consecutive pulses). All three pulses may have the same peak amplitude. One such example of a pre-defined pulsating torque signal is shown in
In order to estimate the error in the estimated angular position of the rotor for a given torque operating point, the synchronous motor 111 is operated according to the pre-defined pulsating torque signal corresponding to said torque operating point using a sensorless vector control method employing high-frequency voltage injection (i.e., using elements 101 to 110, 112 to 124).
First, the pre-defined pulsating torque signal Tref(n) produced by the Δθ estimator state machine 101 is processed in a maximum torque per ampere (MTPA) element 102 implementing a MTPA control method to form. The MTPA control method produces the desired torque while minimizing current magnitude. The MTPA element 102 generates d- and q-axis stator current signals i*d and i*q based on the pre-defined pulsating torque pulse signal Tref(n) using said MTPA control method. In other embodiments, other means for converting the pre-defined pulsating torque signal to the d- and q-axis stator current signals may be employed.
Then, a first difference signal is calculated, in element 103, as a difference between a generated d-axis stator current signal i*d and a measured d-axis stator current signal i′d of the synchronous motor 111. Correspondingly, a second difference signal is calculated as a difference between a generated q-axis stator current signal id+ and a measured q-axis stator current signal i′q of the synchronous motor 111 also in element 103. The first and second difference signals quantify the error between desired stator currents and the actual measured stator currents. How the measured d- and q-axis stator current signals i′d and i′q are actually measured, in elements 112, 113, is discussed later.
A d-axis stator voltage signal ud is calculated, by a first proportional-integral (PI) controller 106, based on the first difference signal. Correspondingly, a q-axis stator voltage signal ud is calculated, also by the PI controller 106, based on the second difference signal.
Optionally in order to increase the dynamics of the control, the d- and q-axis stator voltage signals ud and ud may be combined (i.e., summed together), in a combining (i.e., summing) element 108, respectively, with first optional d- and q-axis voltage stator signal components, second optional d- and q-axis stator voltage signal components or both. Specifically, the first optional d- and q-axis voltage stator signal components may be calculated by an integral (I) controller 104 fed by the generated d- and q-axis stator current signals i*d and i*q and the second optional d- and q-axis voltage stator signal components may be calculated by a proportional (P) controller 105 fed by the generated d- and q-axis stator current signals i*d and i*q. If both the first and second optional d- and q-axis voltage stator signal components are calculated, they may be combined in a combining (i.e., summing) element 107 before the resulting signal is combined in the combining element 108 with the d- and q-axis stator voltage signals uq and uq. All of the operations discussed in this paragraph are carried out separately for d-axis signals and for q-axis signals (e.g., d-axis signals are combined only with other d-axis signals and q-axis signals are combined only with other q-axis signals).
To switch from the rotating reference frame defined by the d- and q-axes to a stationary reference frame of the stator of the synchronous motor 111, the d- and a q-axis stator voltage signals ud and uq are transformed, in vector rotation (VR) element 109, to α- and β-axis stator voltage signals uα and uβ using inverse Park transform. The inverse Park transform requires knowledge of the current angular position (i.e., rotation angle) of the rotor. The current angular position may be estimated continuously during the running of the angular position error estimation procedure, as will be described in detail below.
The α- and β-axis stator voltage signals uα and uβ are injected in a combining element 110 together with high-frequency α- and β-axis stator voltage signals uαh and uβh (according to a high-frequency voltage injection principles), and the respective combinations of these signals are fed to the stator of the synchronous motor 111.
Said high-frequency α- and β-axis stator voltage signals uαh and uβh are generated as follows. Initially, a signal generation element 121 in the position estimation unit 124 generates a high-frequency square-wave d-axis stator voltage signal having a frequency larger than a frequency of the pre-defined pulsating torque signal. Preferably, the frequency of the high-frequency square-wave d-axis stator voltage signal should be much larger (e.g., one or more orders of magnitude larger or two or more orders of magnitude larger) than the frequency of the predefined pulsating torque signal so that the high-frequency component may be easily isolated, by high-pass filtering, from the main stator voltage/current signals to which it has been inserted. For example, the frequency of the high-frequency square-wave d-axis stator voltage signal may be at least larger than the frequency of the pre-defined pulsating torque signal multiplied by ten or one hundred. Then, the high-frequency square-wave d-axis stator voltage signal is converted to said high-frequency α- and β-axis stator voltage signals using inverse Park transform in vector rotation element 122. Similar to as discussed in relation to vector rotation element 109, it is assumed here, at this point, that the angular position of the rotor required for performing the inverse Park transform is simply known. How it is known (i.e., how it is evaluated) is discussed in detail below. As mentioned also above, a high-frequency square-wave q-axis stator voltage signal may be equally used for the high-frequency voltage injection, instead of the high-frequency square-wave d-axis stator voltage.
The synchronous motor 111 produces α- and β-axis output stator current signals iα and iβ which may be measured to produce an output. These current signals are used for two different purposes. Firstly, the α- and β-axis output stator current signals iα and iβ are converted, in a vector rotation element 113 using Park transform, to d- and q-axis output stator current signals id and iq which are subtracted, after taking an average in element 112, from the generated d- and q-axis output stator current signals i*d and i*q, respectively. The average which may be calculated for each of the d- and q-axis output stator current signals id and iq in element 112 may be specifically two-sample average. The purpose of calculating the average is to eliminate the high-frequency components (i.e., signal components resulting from the voltage injection) from the d- and q-axis stator current signals id and iq. Similar to as discussed above in relation to elements 109, 122,
Park transform in element 113 may be calculated based on a previously estimated (or pre-defined) value of the angular position of the rotor maintained in the database of the Δθ estimator state machine 101.
Secondly, the α- and β-axis output stator current signals iα and iβ are used for estimating the angular position of the rotor and the angular speed of the rotor in the position estimation unit 124. In this case, the α- and β-axis output stator current signals iα and iβ are first converted, in a vector rotation element 114, using Park transform to a q-axis output stator current signal iq. Also in element 114, Park transform may be calculated based on a previously estimated or pre-defined value of the angular position of the rotor, as will be described in detail below. Then, the q-axis output stator current signal iq is high-pass filtered in elements 115, 116 so as to isolate a high-frequency q-axis output stator current signal component iqh. Specifically, a unit delay is applied to the q-axis output stator current signal, in the unit delay element 115, and the resulting delayed current signal is subtracted, in the subtraction element 116, from the q-axis output stator current signal iq without such a delay. The high-frequency q-axis output stator current signal corresponds, here, to a response of the synchronous motor 111 to the high-frequency square-wave d-axis stator voltage signal fed (or injected) to the synchronous motor 111, i.e., it is the signal component resulting from the voltage injection.
A product of the high-frequency q-axis output stator voltage component and a signal formed by applying a signum function, in element 120, to the high-frequency square-wave d-axis stator voltage signal is calculated in multiplication element 117.
Based on said product, a first signal corresponding to the estimated angular speed ωest is calculated using a second PI controller 118. As this signal may be quite noisy, it is low-pass filtered, at least in some embodiments, in low-pass filter (LPF) 119, to form a second signal corresponding to the estimated angular speed ωfilteredest. Specifically, the values of this second signal ωfilteredest are used in the angular position error estimation. The cut-off frequency of the LPF 119 may be defined based on Δt and the response time of the phase-locked loop (PLL) of the position estimation unit 124, where Δt denotes a (pre-defined) time separation of first measurements performed by the system at a first time instance while the pre-defined pulsating torque signal is being applied and subsequent second measurements performed by the system at a second time instance when the pre-defined pulsating torque signal is no longer applied. Preferably, Δt should be as small as possible. A plurality of values of the (final) estimated angular speed may be stored to a lookup table maintained in a database of the Δθ estimator state machine 101. Specifically, said plurality of values of the (final) estimated angular speed may comprise one or more of:
In addition to the aforementioned measurements of the estimated angular position and the estimated angular speed, coinciding values of the desired torque (i.e., a value of the pre-defined pulsating torque signal) may also be measured and stored to the lookup table. In other words, one or more of the following values may be measured and stored to the lookup table:
One example of measurements carried out for calculating the error in the estimated angular position of the rotor is illustrated in
Based on the values of the estimated angular position and the estimated angular speed, the Δθ estimator state machine 101 calculates an estimate for the error in the estimated angular position (at the first time instance associated with non-zero torque) for the torque operating point defined the pre-defined pulsating torque signal. Specifically, the calculated error corresponds the error in the first value of the estimated angular position. Subsequently, the calculated error is stored to the lookup table in the database of the Δθ estimator state machine 101. Specifically, this calculation is performed as follows. As described above, during each Δθ estimation procedure for a single torque level (i.e., for a single torque operating point), measurements may be taken of the desired torque τref, the estimated angular position θest and low-pass-filtered estimated angular speed ωrest. At minimum, the following three measured values are needed for the position error estimation:
The measured estimated angular position is a linear combination of the actual angular position ϕr and Δθ in the estimation. However, it may be assumed, without considerably sacrificing accuracy, that at zero torque (τref=0), the error in estimated angular position is negligible Δθ(0)≈0. Thus, the three measurements for the estimated angular position relate to the actual angular position according to the following equations:
θ0est≈ϕr
θ1est(τrf)≈ϕr
θ2est≈ϕr
According to the middle equation shown above, the actual angular position ϕr
ϕr
where the angular speed of the rotor is assumed to be constant. Thus, the error in the estimated angular position may be written as
Δθ=θ1est−θ2est+ωr
Notably, the above calculation of the error in the estimated angular position only employs measurements carried out at first and second time instances. The reliability of this procedure may be improved by taking advantage of measurements carried out at the zeroth time instance (i.e., before the pre-defined pulsating torque signal is applied). According to an embodiment, the initial estimated angular position θ0est (at the zeroth time instance) and the angular position ϕr
During the angular position error estimation, the error in the estimated angular position is obviously not yet known. However, in order to accurately perform the Park and inverse Park transforms in elements 109, 113, 114, 122 and thus to accurately perform the measurements and calculate said error, the error in the estimated angular position should preferably be evaluated in some way. This correction of the error in the estimated angular position during the angular position error estimation may be arranged, for example, as follows.
Here, it may be assumed that the one or more pre-defined pulsating torque signals are applied in increasing or decreasing order of torque operation point. For nth torque operating point τ(n) of the one or more torque operating points, a corrected estimated angular position is calculated, in a subtraction element 125, according to
θcorrest(τ(n))=θest−Δθ(τ(n−1))x,
where θest is a value of a current estimated angular position as evaluated by the vector control method (specifically, by the position estimation unit 124), τ is a value of torque associated with the torque operating point, Δθ(τ(n−1)) is a value of the error in the estimated angular position calculated for a previous torque operating point in sequence (i.e., the previously calculated value of the error in the estimated angular position corresponding most closely to the current torque operating point) and maintained in the lookup table and x is defined as
For the first torque operating point in sequence τ(1), the corrected estimated angular position may be calculated assuming a pre-defined value (e.g., zero) for the term Δθ(τ(0)). Preferably, the first torque operating point in sequence τ(1) corresponds to the lowest torque operation point so that Δθ(τ(0))≈0 is a fair assumption. The corrected estimated angular position is subsequentially used in the sensorless vector control method (specifically, in the inverse Park transforms therein).
In some more general embodiments where pre-defined pulsating torque signals corresponding to different torque operating points may be applied in any order, the following equation may be used for calculating a corrected estimated angular position:
θcorrest(τ(n))=θest−Δθ(τclosest)x.
Here, the term Δθ(τ(n−1)) has been replaced with a term Δθ(τclosest) which is a value of the error in the estimated angular position calculated for a previous torque operating point τclosest which is closest to the current torque operating point and is maintained in the lookup table. Thus, the term τclosest corresponds to an index smaller or equal to n−1.
Even by using the above equations for correcting value of the estimated angular position during the deployment, the estimated angular position may not be completely corrected. To further improve the correction, the previously calculated values of the error in the estimated angular position may be linearly extrapolated or interpolated to calculate an estimated angular position for τ(n) (i.e., for the current torque operating point). For example, if the one or more pre-defined pulsating torque signals are applied in the order of increasing or decreasing torque operation point, extrapolation may be used. Interpolation may be used in cases where the value of the error in the estimated angular position to be calculated corresponds to a torque operating point which lies between two torque operating points for which said error has already been evaluated. A corrected estimated angular position is calculated, in a subtraction element 125, for nth torque operating point τ(n) of the one or more torque operating points, according to
θcorrest(τ(n))=θest−Δθ(τ(n))x.
This option may be especially beneficial for synchronous motors having linear Δθ, e.g., synchronous reluctance motors (SynRM). However, for synchronous motors with non-linear Δθ such as interior permanent magnet (IPM) motors and permanent magnet assisted synchronous reluctance motors (PMaSynRM), it may lead to significant error between θcorrest and θr. Another option for further improving the correction is reducing the torque step size (i.e., the separation between nearest torque operating points or levels). Reducing the torque step size has many benefits such as higher resolution of torque-to-Δθ lookup tables and smaller error between estimated and actual reference frames.
The processes discussed above for a single torque operating point (i.e., for a single pre-defined pulsating torque signal) may be repeated for a plurality of torque operating points (i.e., for a plurality of corresponding pre-defined pulsating torque signals). Preferably, the plurality of torque operating points should cover the whole operational range of the synchronous motor and be evaluated sequentially in increasing order. The result of these repetitions is a lookup table comprising a plurality of values for the error in the estimated angular position, where each of the plurality of values for the error correspond to a particular torque operating point. This lookup table, is, then used during the normal operation of the system for the compensation of the error in the estimated angular position. Ideally, the torque levels (i.e., torque operating points) are applied, during the repetitions, in such a pattern that the rotor comes back to its starting position.
During the normal operation (i.e., the operation following the angular position error estimation phase where the errors are calculated and stored to the lookup table), the system of
During the normal operation (i.e., the operation following the deployment or angular position error estimation phase where the errors are calculated and stored to the lookup table), a corrected estimated angular position for use in the sensorless vector control method may be calculated, in a subtraction element 125, for the nth torque operating point τ(n) of the one or more torque operating points, according to
θcorrest(τ(n))=θest−Δθ(τ(n))x,
wherein θest is a value of a current estimated angular position as evaluated by the vector control method, τ is a value of torque associated with the torque operating point, Δθ(τ(n)) is a value of the error in the estimated angular position for the current torque operating point maintained in the lookup table (or specifically the value of the error in the lookup table corresponding to a torque operating point which most closely matches the current torque operating point) and x is defined as
The corrected estimated angular position is subsequentially used in the sensorless vector control method (specifically, in the inverse Park transforms therein).
In practice, the synchronous motor may not be operated at a given time with torque corresponding exactly to any of the one or more pre-defined torque operating points. Thus in practice, the value of the error in the estimated angular position which is closest to the current torque operating point may be used during the normal operation (i.e., the operation following the angular position error estimation) for estimating the error in estimated angular position. In some embodiments, interpolation and/or extrapolation may be used to derive a more accurate estimate based on the values in the lookup table (i.e., to estimate values of the error for torque operating points between the one or more torque operating point for which data is stored to the lookup table).
Different types of synchronous motors use different dq conventions. The system of
As implied above, the synchronic machines of the first type comprise at least SynRMs and PMaSynRMs while the synchronic machines of the second type comprise at least IPM motors. In all other aspects, the system of
As mentioned above, the rotor of the synchronous motor should preferably move as little as possible during the angular position error estimation procedure. In other words, the initial angular position of the rotor before applying a pre-defined pulsating torque signal should be as close as possible to the final angular position of the rotor after the applying the pre-defined pulsating torque signal. However, it may occur in some circumstances that there is a significant deviation between these two positions and thus the accuracy of the calculated error in the estimated angular position is compromised.
Referring to
Then, the apparatus measures, in block 502, a zeroth value of an estimated angular position of the rotor of the synchronous motor θ0est (at a zeroth time instance). This measurement is specifically performed before any torque signal is applied to the synchronous motor. The measurement may be performed based on the high-frequency voltage injected to the stator of the synchronous motor, as described above. Also as described above, a corresponding zeroth value of desired torque and/or an estimated angular speed of the rotor may also be measured in some embodiments.
After measuring the zeroth value(s), the apparatus applies, in block 503, the pre-defined pulsating torque corresponding to the selected torque operating point to the synchronous motor. This may be carried out as described in relation to
Also similar to as described in relation to
θcorrest(τ(n))=θest−Δθ(τ(n−1)x or
θcorrest(τ(n))=θest−Δθ(τ(n))x
may be employed (with extrapolation being used for calculating Δθ(τ(n)) in the latter equation).
At a second time instance, the apparatus measures, in block 506, both a second value of the estimated angular position θ2est and a second value of the estimated angular speed ωr
The apparatus compares, in block 508, an absolute difference between the zeroth value of the estimated angular position and an error-corrected first value of the estimated angular position against a first pre-defined threshold (i.e., a tolerance threshold). The error-corrected first value of the estimated angular position is defined as ϕr
|ϕr
where θthreshold is the first pre-defined threshold.
In response to the absolute difference failing to exceed the first pre-defined threshold (|ϕr
In response to said absolute difference exceeding the first pre-defined threshold (|ϕr
In some embodiments, the check in block 509 may be omitted. In some simpler embodiments, also the tolerance checking functionalities in block 502, 508 may omitted so that it is assumed that all the calculated Δθ(τref) in block 507 are valid and are thus stored in block 511 to the lookup table.
After the angular position error estimation process of
The apparatus performs, sequentially for each of one or more torque operating points of a synchronous motor, angular position error estimation of the synchronous motor in the following manner (blocks 601 to 606). The one or more torque operating points and the associated one or more pre-defined pulsating torque signals and the order in which they are applied in the angular position error estimation may be defined as described in relation to
To perform the angular position error estimation for a particular torque operating point, the apparatus operates, in block 601, the synchronous motor according to a pre-defined pulsating torque signal using a sensorless vector control method employing high-frequency voltage injection. Here, a peak amplitude of the pre-defined pulsating torque signal corresponds to a torque operating point of the synchronous motor and the pre-defined pulsating torque signal has a zero mean for minimizing movement of a rotor of the synchronous motor during the operating. The operating in block 601 may correspond, for example, to blocks 503, 505 of
The apparatus estimates, in block 603, an error in the first value of the estimated angular position of the rotor based on the plurality of values and stores at least the error in the estimated angular position to a lookup table in a database. Specifically, the error (Δθ) in the first value of the estimated angular position may be evaluated in block 603 according to Δθ=θ1est−θ2est+ωr
After the storing of the error to the lookup table in block 604, the apparatus selects, in block 608, the next torque operating point for angular position error estimation (if any exist in block 607). The angular position error estimation loop (blocks 601 to 606) is repeated for each of the one or more torque operating points.
After the angular position error estimation has been carried out for all of the one or more torque operating points in blocks 601 to 606, the apparatus operates, in block 607, the synchronous motor at the one or more torque operating points (or specifically within a range covered by the one or more torque operating points) using the sensorless vector control method with high-frequency voltage injection. In the operating, any error in the angular position of the synchronous motor is corrected according to the lookup table.
The blocks, related functions, and information exchanges described above by means of
Any of the features described above in connection with the more detailed embodiments of
The apparatus 701 may comprise one or more control circuitry 720, such as at least one processor, and at least one memory 730, including one or more algorithms 731, such as a computer program code (software) wherein the at least one memory and the computer program code (software) are configured, with the at least one processor, to cause the apparatus to carry out any one of the exemplified functionalities of the apparatus (i.e., of the system of
Referring to
Referring to
Referring to
As used in this application, the term ‘circuitry’ may refer to one or more or all of the following: (a) hardware-only circuit implementations, such as implementations in only analog and/or digital circuitry, and (b) combinations of hardware circuits and software (and/or firmware), such as (as applicable): (i) a combination of analog and/or digital hardware circuit(s) with software/firmware and (ii) any portions of hardware processor(s) with software, including digital signal processor(s), software, and memory(ies) that work together to cause an apparatus, such as a terminal device or an access node, to perform various functions, and (c) hardware circuit(s) and processor(s), such as a microprocessor(s) or a portion of a microprocessor(s), that requires software (e.g. firmware) for operation, but the software may not be present when it is not needed for operation. This definition of ‘circuitry’ applies to all uses of this term in this application, including any claims. As a further example, as used in this application, the term ‘circuitry’ also covers an implementation of merely a hardware circuit or processor (or multiple processors) or a portion of a hardware circuit or processor and its (or their) accompanying software and/or firmware. The term ‘circuitry’ also covers, for example and if applicable to the particular claim element, a baseband integrated circuit for an access node or a terminal device or other computing or network device.
In an embodiment, at least some of the processes described in connection with
Embodiments as described may also be carried out in the form of a computer process defined by a computer program or portions thereof. Embodiments of the methods described in connection with
Even though the embodiments have been described above with reference to examples according to the accompanying drawings, it is clear that the embodiments are not restricted thereto but can be modified in several ways within the scope of the appended claims. Therefore, all words and expressions should be interpreted broadly, and they are intended to illustrate, not to restrict, the embodiment.
Number | Date | Country | Kind |
---|---|---|---|
20170391.5 | Apr 2020 | EP | regional |