The invention relates to a method for operating an electronically commutated motor (10) that comprises a rotor (12), a stator (14) having a multi-strand winding arrangement (16) for whose energization a power stage (18) is provided, a first lead (30) and a second lead (32) for connecting the power stage (18) to a voltage source (24), and a first controller. A first signal (U—34; U—38) is sensed, which signal characterizes a current (I_IN; I_IN′; I_M; I_M′) flowing through at least one of the leads (30; 32); the first controller generates at least one clocked signal (PWM) and outputs it to the power stage (18) in order to influence the first value, permitted current. The invention also relates to a corresponding motor (10).
|
1. A method of operating an electronically commutated motor (10) that comprises:
a rotor (12);
a stator (14) having a multi-strand winding arrangement (16) for whose energization
a power stage (18) is provided;
a first lead (30) and a second lead (32) for connecting power stage (18) of said motor to a voltage source (24), and
a first controller (23) controlling power applied to said power stage (18),
said method comprising the steps of:
A) sensing a first signal (U_34; U_38) which, during operation, characterizes a current (I_IN; I_IN′; I_M; I_M′) flowing through at least one of said first and second leads (30; 32);
B) as a function of the first signal (U_34; U_38), ascertaining a first value (I_ave_i) which characterizes an average value of the current (I_IN; I_IN′; I_M; I_M′) flowing through at least one of the leads (30; 32);
C) in the first controller, generating a first control signal (TV), based upon the first value (I_ave_i) applied to an input of said controller as an actual value, and a second value (I_ave_s) applied to an input of said controller as a target value;
D) generating (280) at least one clocked signal (PWM; PWM*; PWM**) as a function of the first control signal (TV), and
E) applying said at least one clocked signal to the power stage (18), in order to influence the first value (I_ave_i) and to thereby reduce fluctuations of said average value of the current flowing through at least one of the leads.
15. A motor (20) comprising
a permanent magnet rotor (12),
a stator (14) with a multi-strand winding arrangement (16) equipped with winding terminals (45, 55, 65);
a power stage (18) for powering said multi-strand winding arrangement, said power stage having a first lead (30) and a second lead (32) for connecting the power stage (18) to a dc voltage source (24),
an upper switch (41, 51, 61) connected intermediate said first lead (30) and said terminals (45, 55, 65), and
a lower switch connected intermediate said second lead (32) and said terminals (45, 55, 65);
a current measuring element (36) adapted for measuring a first voltage signal (U_34; U_38) characterizing the current (I_IN; I_IN′; I_M; I_M′) flowing through at least one of said first and second leads (30, 32),
a first apparatus (272, 92) adapted to ascertain, as a function of the first voltage signal (U_34; U_38), a first value (I_ave_i) characteristic of the average value of the current (I_IN; I_IN′; I_M; I_M′) flowing through at least one of the leads (30, 32),
said first apparatus includes an analog-to-digital converter which, during motor operation, receives said first voltage signal (U_34; U_38) and generates therefrom a corresponding digital output value (I_on)
wherein
a clocked signal applied to the upper switch (41, 51, 61) has a first state s_i_on) during a first time interval (T_I_on) and a second state s_i_off) during a second time interval (T_I_off) a current being permitted to flow via the first lead (30),
a corresponding upper switch (41, 51, 61), and the second lead (32) only during said first state (s_i_on),
a third value (87) is generated, characterizing an average value of said first voltage signal (U_34, U_38) during said first state (s_i_on),
and the first value (I_ave_i) is ascertained as a function of the third value (87), a first time duration (T_I_on) and a second time duration (T_I_off);
said first apparatus (272, 92), during said first time interval (T_I_on), performing an analog-to-digital conversion of said first voltage signal (U_34, U_38) and, as a function of the result, supplying said first value (I_ave_i); and
further comprising
a first controller (93, 90) which receives, as inputs, the first value (I_ave_i) as an actual value and a second value (I_ave_s) as a target value, and generates therefrom, at its output,
a first control value (TV), and
a first control apparatus (280) having an input coupled to receive said first control value (TV), and an output supplying a clocked signal for application to an input of said power stage (18), in order to influence said first value (I_ave_i) and thereby to reduce fluctuations of said average value of the current flowing through at least one of the leads.
4. A motor (20) comprising
a permanent magnet rotor (12),
a stator (14) with a multi-strand winding arrangement (16) equipped with winding terminals (45, 55, 65);
a power stage (18) for powering said multi-strand winding arrangement, said power stage having a first lead (30) and a second lead (32) for connecting the power stage (18) to a dc voltage source (24),
an upper switch (41, 51, 61) connected intermediate said first lead (30) and said terminals (45, 55, 65), and
a lower switch connected intermediate said second lead (32) and said terminals (45, 55, 65);
a current measuring element (36) adapted for measuring a first voltage signal (U_34; U_38) characterizing the current (I_IN; I_IN′; I_M; I_M′) flowing through at least one of said first and second leads (30, 32),
a first apparatus (272, 92) adapted to ascertain, as a function of the first voltage signal (U_34; U_38), a first value (I_ave_i) characteristic of the average value of the current (I_IN; I_IN′; I_M; I_M′) flowing through at least one of the leads (30, 32),
said first apparatus includes an analog-to-digital converter which, during motor operation, receives said first voltage signal (U_34; U_38) and generates therefrom a corresponding digital output value (I_on) and said first apparatus is configured to specify the duty ratio (TV) of a clocked signal (PWM) during a period of the clocked signal, as a function of a value characteristic of an average value of current flowing in one of said leads (30,32) during a preceding predetermined time span of the clocked signal (PWM);
said motor (20) being so configured that, during operation, a clocked signal applied to said upper switch (41, 51, 61) has a first state (S-I_on) during a first time interval and a second state (S-I_off) during a second time interval, a current being permitted to flow only during said first state (S-I_on) via said first lead (30), a corresponding upper switch (41, 51, 61), and said second lead (32);
said first apparatus (272, 92) during said first time interval (T_I_on) performing an analog-to-digital conversion of first signal (U_34, U_38) and, as a function of the result, supplying said first value (I_ave_i);
further comprising
a first controller which receives, as inputs, the first value (I_ave_i) as an actual value and a second value (I_ave_s) as a target value, and generates therefrom, at its output, a first control value (TV), and
a first control apparatus (280) having an input coupled to receive said first control value (TV), and an output supplying a clocked signal for application to an input of said power stage (18), in order to influence said first value (I_ave_i) and thereby to reduce fluctuations of said average value of the current flowing through at least one of the leads.
2. The method according to
wherein the motor includes an analog-to-digital converter and further comprising the steps of
applying, at a plurality of times, said first signal (U_34; U_38) to an input (231) of said converter (272, 92) and
generating therefrom, at a plurality of times, corresponding digital output values, the first value (I_ave_i) being ascertained by averaging (92) the plurality of digital output values.
3. The method according to
wherein the first value (I_ave_i) is ascertained in such a way that it characterizes the average value of the current (I_IN; I_IN′; I_M; I_M′) flowing through at least one of the leads (30; 32) during a predetermined time segment (T_PWM).
5. The motor according to
a capacitor (22) arranged between said first lead (30) and said second lead (32) and
wherein said current measuring element (36) is associated with a segment of the leads (30, 32) between said capacitor (22) and power stage (18).
6. The motor according to
a capacitor (22) arranged between said first lead (30) and said second lead (32) and
wherein said current measuring element (36) is associated with a segment of the leads (30, 32) coupled to a power-stage-remote side of said capacitor (22).
7. The motor according to
8. The motor according to
said first apparatus (272, 92), said first controller (93, 90) and said first control apparatus (280) are implemented within a microcontroller (23) using a program associated therewith.
9. The motor according to
wherein said power stage (18) serves as a setting element for said first controller (93, 90).
10. The motor according to
11. The motor according to
12. The motor of
13. The motor of
14. The motor of
a second controller (95) used to regulate the instantaneous motor speed (n_i) toward a target motor speed (n_s),
said second controller generating a second control value (I_ave_s) which is applied to the first controller (90) as said second value (I_ave_s) thereto.
16. The motor of
17. The motor of
18. The motor of
|
The present application is a section 371 of PCT/EP08/09797, filed 20 Nov. 2008, which in turn claims priority from our German application DE 10 2007 063 259.4, filed 18 Dec. 2007, the entire content of which is hereby incorporated by reference.
The invention relates to an electronically commutated motor, in particular for driving a fan.
In the telecommunications sector in particular, the line-conducted emissions emitted from a fan can result in disruptions that are perceptible, for example, as troublesome noise during telephone calls. The telecommunications sector therefore requires fans having a low level of low-frequency line-conducted emissions. This is advantageous for standard motors as well.
An object is therefore to make available a novel low-emission electronically commutated motor (ECM).
This object is achieved by a method which employs several controllers to smooth fluctuations in motor current by adjustment of the duty ratio of a Pulse Width Modulation (PWM) driving signal for the power stage. Such a method and an electric motor of this kind decrease fluctuations in the average current consumed by the power stage. This also has a positive effect on the line-conducted emissions. Fewer current peaks occur because of the current controller, and as a result the power supply section can be better utilized by the customer.
Further details and advantageous refinements of the invention are evident from the exemplifying embodiments, in no way to be understood as a limitation of the invention, that are described below and depicted in the drawings, in which:
A link circuit voltage U_ZK is present at link circuit capacitor 22, and the latter is connected, via an optional polarity protection diode 26, to a DC voltage source 24 having a voltage U_B.
A microprocessor or microcontroller, hereinafter called microcontroller μC 23, is likewise connected to DC link circuit 20, and serves to control motor 10.
Power stage 18 serves for current flow through winding arrangement 16, and has three bridge arms 40, 50, 60 having three upper switches 41, 51, 61 that connect upper lead 30 to three terminal nodes 45, 55, 65 for winding arrangement 16, and having three lower switches 42, 52, 62 that connect the three terminal nodes 45, 55, 65 to a common bottom node 34 that in turn is connected via a current measuring resistor 36 to lower lead 32 (GND). The upper and lower switches are, for example, n-channel MOSFETS, model IRFR3710Z, of the International Rectifier company.
Switches 41, 51, 61, 42, 52, 62 are n-channel MOSFETs (Metal Oxide Semiconductor Field Effect Transistors), and associated with each of them are respective recovery diodes 46, 56, 66, 47, 57, 67 to allow a current flow oppositely to the normal current direction that may occur.
Terminal nodes 45, 55, 65 are connected to winding arrangement 16, which is connected as a delta circuit; other configurations, such as star circuits, are also possible.
Rotor 12, which interacts with winding arrangement 16, is embodied with four poles (other numbers of poles are also possible), and associated with said rotor are three rotational position sensors (e.g. Hall elements) 71, 72, 73 whose output signals are delivered to inputs 230 of μC 23 in order to determine the rotational position of rotor 12. Sensorless commutation, as described in
A resistor 37 is connected to bottom node 34 and to a node 38 that is in turn connected via a capacitor 39 to lower lead 32 and additionally to input 231 of μC 23. RC element 37, 39 is connected as a low-pass filter, and filters out interference.
μC 23 is connected via an output 241 to switch 41, via an output 251 to switch 51, via an output 261 to switch 61, via an output 242 to switch 42, via an output 252 to switch 52, and via an output 262 to switch 62. μC 23 can thus control the commutation of power stage 18.
Commutation
The diagram shows the driving of switches 41, 42, 51, 52, 61, 62 over one electrical revolution (360° el.), i.e. over one complete commutation cycle. For a four-pole motor, the electrical period begins again after half a mechanical revolution (180° mech.), since these two rotor positions are magnetically equivalent, and cannot be distinguished. In the angle range from 0° el. to 60° el., lower switch 42 is always closed, and upper switch 51 is driven with a clocked signal PWM having a predetermined duty cycle TV in order to generate a current through strand 48. A clocked signal is a signal that switches back and forth between at least two states such as, for example, HIGH and LOW. Lower switch 52 is driven with the inverse signal /PWM of switch 51, so that when upper switch 51 is switched off, current looping through node 55, strand 48, node 45, switch 42, and switch 52 back to node 55 becomes possible, since otherwise the current would flow through recovery diode 57, which would result in higher losses. The term “active current looping” is used when the corresponding lower switch is driven with the inverse signal /PWM, and “passive current looping” when current looping occurs through the recovery diode.
After 60° el., current delivery through switch 51 is terminated, and the clocked signal having a predetermined duty cycle TV is applied to switch 61. Correspondingly, the inverse clocked signal /PWM of switch 61 is applied to lower switch 62. After 120° el., lower switch 42 is switched off and lower switch 52 is instead switched on, so that current can now flow through switch 61, winding arrangement 16, and lower switch 52. Commutation is continued in accordance with the diagram until the initial state is reached again after 360° el. Because of the six commutation states (0, 2, 4, 6, 8, 10), this type of commutation is referred to as six-step commutation.
Between 0° el. and 30° el., both lower switch 42 and lower switch 62 are switched on, and upper switch 51 is being driven with a clocked signal PWM having a predetermined duty cycle TV, and lower switch 52 with the inverse signal /PWM of switch 51. In the state “switch 51 on and switch 52 off,” a current I_on flows from upper lead 30 through switch 51 on the one hand through strand 48, switch 42, and measuring resistor 36 to lower lead 32, and on the other hand through strand 58, switch 62, and measuring resistor 36 to lower lead 32; the corresponding current flow I_on and the corresponding switch positions are depicted as solid lines.
When switch 51 is switched off by clocked signal PWM and switch 52 is switched on by the inverse clocked signal /PWM, however, current can no longer flow out of DC link circuit 30, 32 because of the inductance of strands 48, 58, but a current continues to flow through the latter, and two current loops I_off are produced, one proceeding through strand 48, switch 42, and switch 52 back to strand 48, and the other through strand 58, switch 62, and switch 52 back to strand 58. The corresponding current flows I_off and the corresponding switch positions of switches 51 and 52 are depicted with dashed lines. If power stage 18 is driven with passive current looping or if a delay is necessary between the switching off of upper switch 51 and the switching on of lower switch 52, current I_off flows through recovery diode 56.
After 30° el., lower switch is switched off so that only lower switch 42 now remains permanently switched on. This means that the entire current I_on must flow through strand 48 and lower switch 42, through which hitherto only approximately half the current I_on has flowed. Because the current in a strand cannot (because of the latter's inductance) be increased immediately, whenever a change takes place in the current flow through the strands of power stage 16, a current gap occurs that leads to a fluctuation in input current I_in. Because, in the context of the twelve-step commutation operation shown in
After 60° el., in addition to upper switch 51, upper switch 61 is driven with the clocked signal PWM, and both lower switch 52 and lower switch 62 are driven with the inverse clocked signal /PWM.
After 90° el., upper switch 51 is then completely switched off, so that only upper switch 61 is now being driven with the clocked signal PWM. Commutation is then continued in accordance with the diagram. Unlike in
It is difficult (or, with some types of motor, impossible) to start up motor 10 using twelve-step commutation, and it is therefore preferred to start using six-step commutation, and change over to twelve-step commutation after startup and once a predetermined minimum rotation speed has been reached.
Twelve-step commutation, or commutation with overlapping switching on and off of the transistors, is not possible with a one-strand motor, and the latter therefore always has, as a matter of principle, large current gaps during commutation as compared with a three-strand motor.
Current Measurement
During time period T_I_on between times t_81 and t_82, upper switch 51 is switched on and lower switches 42 and 62 are likewise switched on (“S-I_on” state), as they are in the entire rotation angle range between 0° el. and 30° el. A current I_on as shown in
At time t_82, upper switch 51 is switched off and lower switch 52 is switched on (“S-I_off” state), and what results therefrom during the time period T_I_off is current looping within power stage 18 with the currents I_off according to
At time t_83, upper switch 51 is switched on again and voltages U_34 and U_38 rise again because of the rising current I_on.
At time t_81 it is evident that voltage U_34 has peaks, which result in particular from the switching operation. RC element 37, 39 of
The current through an inductance L having a resistance R rises over time t, for a predetermined voltage U, in accordance with
I=U/R(1−e−Rt/L) (1)
and thus approaches the value U/R. After the voltage source is switched off in a circuit having a resistance R, it drops back down again, starting from a current I0, in accordance with
I=I0e−tR/L (2).
As is evident in the case of signal U_34, the current through winding arrangement 16 rises during the S-I_on state starting at time t_81; and during the S-I_off state, starting at time t_82, in which the current through winding arrangement 16 is not mapped at measuring resistor 36, the current then drops back slightly so that it is lower at time t_83 than at time t_82.
Current Measurement—Approximation
Average value 87 of voltages U_34 and U_38, respectively, between times t_81 and t_82 can be ascertained approximately by measuring the voltage U_34 and U_38, respectively, at a time t_81′ that is located centeredly between times t_81 and t_82. With an approximately linear profile for voltages U_34 and U_38, this measurement yields average value 87 of voltage U_38 between times t_81 and t_82. This can be derived graphically, since the area of triangle 85 corresponds to the area of triangle 86.
The following general equations apply:
I—36=U—34/R—36 (3)
and
I—36=U—38/R—36 (4)
given the ohmic resistance R_36 of resistor 36, which is equal to, for example, 0.15 ohm. Because of the proportionality between current I_36 or I_M and voltage U_34 or U_38, an average value of voltage U_34 or U_38 also correspondingly characterizes the average value of current I_36 or I_M, and a method is described below for ascertaining average value 88 of voltages U_34 and U_38.
The averaged voltage U_87 between times t_81 and t_82 is equivalent to
U—87=U—38(t—81)′ (5),
where U_38 (t_81′) is voltage U_38 at time t_81′, and voltage U_87, for example in
The corresponding current I_on_ave is equal to
I_on_ave=U—87/R—36=370 mV/0.15 ohm=2.47 A (6).
The average current I_on_ave ascertained in this fashion also flows, approximately, during current looping in power stage 16, and it could therefore be used, for example, to determine the torque proportional to the current through winding arrangement 16, and also to determine the dissipated power generated in the power stage.
The current value I_on_ave does not, however, correspond to the total current consumed during one period (e.g. t_81 to t_83) of the clocked signal from DC link circuit 20, since no current is consumed from DC link circuit 20 between times t_82 and t_83.
The average voltage U_88 over the entire period t_81 to t_83 of voltage U_38 is obtained by multiplying the value I_on_ave by duty cycle TV of clocked signal U_38 or PWM, yielding
U—88=U—87*TV=U—38(t_81′)*TV (7),
and the average current I_ave flowing through the DC link circuit is obtained as
I_ave=U—87*TV/R—36=I_ave_on*TV (8).
The duty cycle TV of a clocked signal is, in general,
TV=T_on/(T_on+T_off) (9),
where T_on is the duration of the I_on pulse during one period of the clocked signal.
The duty cycle TV of a PWM signal having a period length T_PWM=T_on+T_off and a variable pulse duration T_on_PWM is
TV=T_on—PWM/T—PWM (10).
PWM signals having a constant or a variable period length T_PWM can be used. A constant period length T_PWM is used for the PWM signals in
The average current value I_ave for current I_M flowing through DC link circuit 20, and thus also voltage U_88, can therefore be completely different, for the same average current value I_on_ave or average voltage value U_87 between times t_81 and t_82, and thus for the same torque of motor 10, as a function of duty cycle TV.
An average value determination using an analog RC low-pass filter was carried out as an experiment. In order to smooth the clocked voltage signal U_34 using the RC low-pass filter, the time constant tau=R*C must be very high. The consequence of this, however, is that effective control of input current I_M, I_IN is no longer possible. This can be explained by the fact that because of the high time constant of the RC low-pass filter, the past history of voltage signal U_34 plays too great a role in terms of control engineering.
In contrast to the solution in which an average value is calculated with an RC low-pass filter, here the average value U_88 of voltage U_38 is ascertained for each PWM period, or in general for a predetermined time span or period of the clocked signal, and it is in fact defined before the following PWM period begins and can therefore be used for good and fast control. It is also possible to ascertain a value characterizing the average value of the input current over multiple periods, e.g. over two, three, or four PWM periods, and a different weighting can, for example, be performed in each case, such that the average value of the PWM period presently being measured accounts for 70%, and the average value of the preceding PWM period for 30%. Alternatively, this can also be taken into consideration in the controller.
The value U_88 characterizing the average value of input current I_IN, I_M could also be ascertained by frequent A/D conversion of signal U_38 at short time intervals (with a high sampling frequency), in combination with a subsequent averaging of the measured values. This requires an extremely fast A/D converter, however, and such devices are usually expensive.
One special aspect of average current value controller 90 is that regulation to the average value of the current flowing into power stage 18 is carried out. This average value can differ, as a function of the clocked signal, from the current flowing in power stage 18.
A further special aspect of average current value controller 90 is the fact that power stage 18 of motor 10, or switches 41, 51, 61, 42, 52, 62 of said stage, are used as setting element 18 for controller 90 in order to influence the value I_ave_i and to equalize the value I_ave_i with the value I_ave_s. The motor can thus be operated without an additional setting element in the input lead to the power stage of motor 10.
It is evident from the measurement diagrams presented that a considerable reduction in line-conducted emissions can be achieved by average current value control.
An external device 278, for example a computer, is connected via a data line 279 to an input/output unit I/O 274 of μC 23. A target rotation speed n_s, for example, can be specified via computer 278 to the fan, and that speed is then stored in memory MEM 276. An output of data via motor 10 to the computer can also occur. Target rotation speed value n_s can also be determined via an NTC resistor 277 and an A/D converter 275 in combination with a temperature/rotation speed characteristic curve (not shown). Target rotation speed value n_s is delivered to rotation speed controller RGL_n 95 as a target value.
In this exemplifying embodiment a sensorless commutation is carried out, and inputs 230′, 230″, 230′″ are connected via an evaluation apparatus 120 (depicted in
Rotation speed n_i is delivered to rotation speed controller 95 as an actual value, and said controller ascertains a control input I_ave_s for control purposes.
The average current value target value I_ave_s is delivered to average current value controller RGL_I_ave 90 as a target value, and an average current value I_ave_i as an actual value, and the controller calculates therefrom a duty cycle TV for commutation arrangement COMMUT 280. Voltage U_38 characterizing current I_M in DC link circuit 20 is delivered via an input 231 to an A/D routine AD_I 272 that, for example at predetermined points in time, carries out an A/D conversion in order to generate a current value I_on. The value I_on, and a duty cycle TV′ outputted by the COMMUT routine and usually corresponding to duty cycle TV, are delivered to the CALC_I_ave_i routine 92, and the CALC_I_ave routine 92 calculates, as a function of these values, the present average current value I_ave_i, which is delivered to average current value controller 90 as an actual value. Delivery of the duty cycle TV′ allows any change in duty cycle TV as a result of the COMMUT routine 280 to be taken into account.
The absolute value of current I_on or I_ave_i is not necessary in many application instances, for example, superimposed rotation speed control, and it is then possible to work directly with voltage values U_87 and U_88 from
The COMMUT routine 280 determines, as a function of rotational position PHI and duty cycle TV, which signals are outputted through outputs 241, 251, 261, 242, 252, 262 to switches 41, 51, 61, 42, 52, 62 (see
Lead 130 is connected to the negative inputs of comparators 131, 132, and 133. The open collector outputs of comparators 131, 132, and 133 are connected to inputs 230′, 230″, and 230′″, respectively, of μC 23, and a respective pull-up resistor 137, 138, 139 is provided at each of the outputs.
Resistors 124, 125 and 126, 127 and 128, 129 are implemented as voltage dividers, and divide the voltages at terminals 45, 55, 65 down in order to make possible processing using comparators 131, 132, 133. The voltages at leads 121, 122, and 123 are combined via resistors 134, 135, and 136 into one common voltage U_130 (average value) that corresponds to the voltage at a virtual neutral point in a neutral point winding arrangement. In comparators 131, 132, and 133, a comparison takes place between voltages U_121, U_122, and U_123, and voltage U_130. It is thus possible to read off, at inputs 230′, 230″, and 230′″ of μC 23, whether voltages U_121, U_122, and U_123, respectively, are greater or less than voltage U_130, and the corresponding point in time of a change in the output signals of comparators 131, 132, and 133 can be ascertained by continuous monitoring or by an interrupt control system.
Examples of values for the components used:
Resistors 124, 126, 128
22 kilohm
Resistors 125, 127, 129
10 kilohm
Resistors 134, 135, 136
10 kilohm
Resistors 137, 138, 139
33 kilohm
Comparators 131, 132, 133
LM2901
In this exemplifying embodiment, the frequency of the PWM signal is 22 kHz, so that one PWM period T_PWM lasts 45 μs. During the first half (22.5 μs), a signal or value 140 is increased linearly with the aid of a PWM timer, and in the second half (22.5 μs) signal 140 is lowered linearly in the same fashion so that, after 45 μs, it has arrived again at zero. A second value 142 is used to determine the width of pulse 149 of the PWM signal. PWM signal 141 is always in the High state (Pulse or S-I_on) when signal 140 is greater than value 142. If it is less, on the other hand, PWM signal 143 is then in the LOW state 148, 150 (Pause, S-I_off1 or S-I_off2), as may be seen between times t_145 and t_146.
The value 142 is lower between times t_146 and t_147, and the consequence of this is that the pulse of PWM signal 143 becomes wider, and duty cycle TV thus becomes greater.
An advantage of this PWM mode is that some microprocessors, for example the PIC18F1330 of the MICROCHIP company, offer the capability, for example after half the PWM period T_PWM, of triggering an interrupt or calling an A/D conversion with a subsequent interrupt. The respective points in time are labeled 151. As a result, the measurement of voltage U_34 or U_38 can be carried at the center of pulse 149, as explained in the description of
In order to allow an updating of value 142 before the next PWM period begins, thus making possible a fast and good average current value controller, the necessary steps in μC 23 must be carried out within a time span of 22.5 μs. With the aforementioned μC, A/D conversion lasts 12.5 μs, and calling the interrupt routine after completion of the A/D conversion takes 2 μs, so that less than 8 μs remain for calculating the new value 142. When using the PIC18F1330, which is clocked at 32 MHz, calculation of the new value 142, including average current calculation, control, and updating of duty cycle TV, must occur using a maximum of 60 one-cycle instructions. In the present case, this was possible only using assembler programming; the result of the A/D conversion was limited to 8 bits, and the maximum value of duty cycle TV was likewise limited to 8 bits. With a higher-performance μC, on the other hand, for example a digital signal processor (DSP), dsPIC33FJ12MC201, these optimizations are not absolutely necessary.
PWM signal 143 is shown for the angle range from 0° el. to 60° el. with twelve-step commutation according to
The PWM frequency is equal to 22 kHz, and the PWM period length is thus T_PWM=45 μs. At the already relatively high rotation speed of 5556 rpm, approximately 9 to 10 PWM pulses are therefore present in the electrical angle range of 30° el. PWM signal 143 is generated, as in
Depicted above the LA and LT interrupt calls are the HT1 and HCOMP interrupt calls for calling the High_ISR high-priority interrupt routine according to
The cooperation between a normal current controller RGL_I_ave_1 and two special current controllers RGL_I_ave_2 and RGL_I_ave_3 is controlled via a so-called delay counter DELAY_CNT, for improved compensation for the current gaps after a commutation by switching-off of an upper or a lower switch.
Upon commutation at time t_160 (transition from state 10 to state 11),
At time t_160, in the High_ISR high-priority interrupt routine, the Timer1 timer is set to a value BEMF_TIME, and after that time has elapsed, an HT1 interrupt is triggered at time t_161 and the next commutation from state 11 to state 0 takes place. Because (as shown in
In state 11, a check is made at each LA interrupt as to whether the next commutation at time t_161 is imminent. If so, current controller RGL_I_ave_1 is disabled (DISABLE RGL_I) and LA interrupts are also disabled (DISABLE LA), since they are correspondingly no longer needed, and since the A/D converter can then be used for other purposes.
In the context of the commutation at time t_161, lower switch 62 is switched off in the High_ISR interrupt routine (see
In addition, the DELAY_CNT variable is set to a starting value DELAY_CNT_START of, for example, 4; the LA interrupt is enabled again (ENABLE LA); duty cycle TV is set, for the first PWM period (DELAY_CNT==4) to a value PWM_LOW previously calculated by controller RGL_I_ave_3; and current control is enabled again (ENABLE RGL_I). Control of the average current value I_ave can be considerably improved by carrying out a special control operation after this commutation, since the normal controller would be overwhelmed in terms of control engineering with the extreme change after commutation, and control would therefore be poorer.
At the LA interrupt occurring during the first PWM period (DELAY_CNT==4), a duty cycle TV_START for the second PWM period (DELAY_CNT==3) is specified in the Low_ISR interrupt routine to the normal current controller RGL_I_ave_1 in order to initialize it, and duty cycle TV is set to that value, duty cycle TV_START being specified by a starting value controller RGL_TV_START. The DELAY_CNT variable is lowered to three.
At the LA interrupt occurring during the second PWM period (DELAY_CNT==3), sensing of the zero transition of induced voltage 165 is started (BEMF_SENSE_START). The purpose of starting sensing after commutation is to prevent incorrect sensing of the zero transition of induced voltage 165 from taking place as a result of commutation interferences. Normal current controller RGL_I_ave_1 is called, in order to calculate the duty cycle for the third PWM period (DELAY_CNT==2), and special controller RGL_I_ave_3 is called, in order to control or improve the specified value PWM_LOW as a function of the present system deviation of the current controller. If the present system deviation I_ave_s−−I_ave_i is equal to zero, the current gap is being effectively controlled with the PWM_LOW duty cycle. A new starting value is thus available for the next commutation when a lower switch is switched off.
At the LA interrupt occurring during the fourth PWM period (DELAY_CNT==1), a controller for determining the starting value for duty cycle TV_START is implemented, and said controller calculates the starting value for initializing average current value controller RGL_I_ave_1 for the first PWM period.
At the zero transition of induced voltage 165 at time t_163, the HCOMP interrupt is generated; and in the associated High_ISR interrupt routine, the present time t_COMP is stored (STORE t_COMP) so that at the next zero transition the time difference can be determined; the value BEMF_TIME for the time required for 30° el. can be calculated by calculating half the time length calculated (as indicated above) for 60° el. The value COM_TIME, for the time between the present zero transition at time t_163 and the next commutation t_162, is calculated, and the Timer1 timer is set accordingly. The ignition advance is also determined by way of COM_TIME, and in a simple exemplifying embodiment this time can be selected to be constant; the result of this is that a small ignition advance takes place at low rotation speeds, and a large advance at high speeds.
In the upper section a MOTSTATE motor variable having corresponding values (28, 14, 12, 30, and 22) is indicated, and the High_ISR interrupt routine stores the present state of the motor, using these state variables.
An advantage of this sensorless twelve-step commutation is that measurement of the zero transitions of the induced voltages is carried out, in the winding terminals 45, 55, and 65 predetermined by the respective angle region, only in six of the twelve commutation periods. When six-step commutation is used for startup, this makes possible a simpler program structure, and thus a more economical processor.
The meanings of the symbols used in all the flow charts are:
The main program begins in step S400. In step S402, the μC is initialized, the Mainstate state variable of a state machine is set to a value of zero, the Timer0 timer is initialized so that every millisecond it triggers an interrupt that is processed by the Low_ISR routine S500. The Timer1 timer is initialized in such a way that when it overflows, an interrupt is triggered that is processed by the High_ISR interrupt routine S600. A DELAY_CNT_START variable is initialized to a value between 3 and 5, and this value is used as a starting value for a DELAY_CNT delay counter that determines the delay between an even-numbered commutation and the start of BEMF sensing.
The main loop begins in step S404, and the Maintimer timer is set to 100. This determines that the main loop will be cycled through every 100 ms as a function of the Timer0 timer. Step S406 checks whether Mainstate has a value of 2. If Yes, in step S408 execution waits for ADC release of the A/D converter by current controller I_RGL, since the A/D converter of the μC is used for both tasks and thus cannot perform the tasks simultaneously. Execution then branches to step S410. If the response in step S406 is No, execution branches directly to step S410. In step S410, a value CTRL_VAL is read in via the A/D converter; this value is specified, for example, by an external or integrated NTC resistor, a control voltage from 0 to 10 V, or an external PWM signal. In step S412 link circuit voltage UZK is sensed with A/D converter ADC. In step S414, the target rotation speed n_s is calculated, for example by means of a temperature/rotation speed characteristic curve, from the value CTRL_VAL.
Step S416 then checks the Mainstate state of the main program. If the Mainstate state is equal to 0 (target rotation speed n_s is so far equal to zero), execution then branches to step S418. Step S420 checks whether the value UZK for the link circuit voltage is in the permitted range. If No, execution branches directly to step S480. If Yes, step S422 then checks whether target rotation speed n_s is greater than zero. If No, execution branches to step S480. If Yes, the Timer1 timer for startup of the motor is initialized in step S424. Duty cycle TV for the PWM signal is set for startup. Step S428 defines that a six-step commutation is to be carried out for startup.
In step S430, the Startup variable is then set to 1, the Motstate state variable to 6, and the Mainstate state variable to 1. Execution then branches to step S480.
If, however, the Mainstate state in step S416 is equal to 1 (“Startup” state), execution then branches to step S440. Step S442 checks whether the startup rotation speed n_start has already been reached. If No, execution branches to step S452 and the duty cycle TV of the PWM signal is increased. If Yes, execution branches to step S444, where the Startup value is set to zero. Twelve-step commutation is then enabled in step S446, the Mainstate state is set to 2 (“Control” state) in step S448, and current controller RGL_I_ave_1 is enabled in step S450. Execution then branches to step S480.
If the Mainstate state was equal to 2 in step S416 (“Control” state), execution then branches to step S460. Step S462 checks whether target rotation speed n_s is greater than a shutdown rotation speed n_stop. If No, in step S468 the Mainstate state is set to 3 (“Shutdown” state) and execution branches to step S480. If Yes, execution branches to step S464, where rotation speed controller RGL_n (95 in
In step S466, A/D conversion of voltage U_38 at the center of the PWM pulse is then enabled, and branching to S480 occurs. The current controller of
If the Mainstate state in step S416 was equal to 3 (“Shutdown” state), execution then branches to step S470. In step S472, the Motstate state is set to 2, and the Mainstate state to zero. In step S474 the current controller is then disabled, and execution branches to step S480. Step S480 checks whether the Maintimer value has a value of zero, i.e. whether the Timer0 timer, which decrements the Maintimer value by 1 every millisecond, has already been called a hundred times. If No, execution continues to wait and branches to step S480. If Yes, then 100 ms have elapsed since the last call of the main loop beginning in step S404, and execution branches back to step S404.
Step S502 identifies the reason why interrupt routine S500 was triggered. In the event of a triggering by the Timer0 timer, execution branches to step S504, the Maintimer timer is decreased by 1 in step S506, and execution leaves the interrupt routine in step S508. The result is that the Maintimer value used to time the main program is decremented after every millisecond.
If, on the other hand, the interrupt was triggered after completion of a requested A/D conversion (initialized in step S466,
If, on the other hand, the value DELAY_CNT was equal to the value DELAY_CNT_START in step S512 (which is the case directly after a commutation from an odd-numbered state to an even-numbered state), execution then branches to step S514, where duty cycle TV is set to the starting value TV_START and execution then branches to step S520. In simpler microprocessors, program steps S516 and S518 must be written in the assembler for speed reasons.
Step S520 checks the DELAY_CNT delay counter, and execution branches to one of steps S522, S530, S550, S560, or S570 as a function of the check. Execution branches to step S522 when the DELAY_CNT delay counter has the same value as DELAY_CNT_START. In step S524 the DELAY_CNT value is decreased by 1 and execution then leaves the interrupt routine in step S526. At the next pass through the interrupt routine, the DELAY_CNT variable has the value DELAY_CNT_START minus 1, and execution branches to step 530. In step S532, sensing of the induced BEMF (back electromagnetic force) voltage is started, and a determination is made of the zero transition (from + to − or vice versa, winding terminal 45, 55, or 65 [see
If, on the other hand, the response in step S536 was NO, execution then branches to step S540 where current controller RGL_I_ave_3, which is optimized for controlling in the context of a current gap occurring after commutation from an odd-numbered state to an even-numbered state, with switch-off of one of the lower switches 42, 52, 62, is called. The present system deviation e1 of current controller RGL_I_ave_1 is used as system deviation e3, and this is delivered to an optimized I-controller.
The control input PWM_LOW is limited as applicable, and is used after the next corresponding commutation as a control input for the first PWM period. Execution then leaves the interrupt routine in step S542.
The next time routine S500 is called, the DELAY_CNT variable is still greater than 1, and execution branches from step S550 to step S552 and the DELAY_CNT variable is decreased by 1. This produces a further delay. Execution then leaves the interrupt routine in step S554.
If the DELAY_CNT variable has a value of 1 at one of the subsequent calls, execution then branches from step S520 to step S560, and in step S562 a controller RGL_TV_START is then called, in which a starting value e1 for current controller RGL_I_ave_1 S518 is ascertained with the aid of a controller. For this, the difference between duty cycle TV and the previous starting value TV_START of the current controller is determined as a system deviation, and delivered to an I-controller. The resulting control input is then limited as applicable, and allocated to the TV_START variable. In step S564 the DELAY_CNT variable is set to zero, and in step S566 execution leaves the interrupt routine.
The next time interrupt routine S500 is called, execution branches from step S520 to step S570, since the DELAY_CNT variable has a value of zero. Step S572 checks whether the next commutation is an even-numbered commutation. If No, execution immediately leaves the interrupt routine in step S580. If Yes, step S574 checks whether the Timer1 timer is about to overflow, for example, by checking whether the Timer1 timer is greater than a predetermined value. If No, execution leaves the routine in step S580. If Yes, then in step S576 current controller I_CTRL is disabled, and in step S578, the A/D converter for the main program is released so that with it, the value CTRL_VAL in step S410 and then the value UZK for the link circuit voltage in step S412 can be measured in the main program. No further current control takes place until the next commutation. This has only a minor influence on input current I_IN, I_M, since changes in the current shortly before commutation are minor. Execution then leaves the interrupt routine in step S580.
If the Motstate state variable has a value of 2 (“Brake fan” state), execution branches from step S610 to step S612, and the upper power stage transistors 41, 51, 61 are switched off. The lower power stage transistors 42, 52, 62 are then switched on in step S614 in order to produce current looping in the lower portion of the power stage, and to decrease the current in stator arrangement 16. Execution leaves the interrupt routine in step S615.
If the Motstate state variable has a value of 4 (“BEMF sensing A positive” state), execution branches from step S616 to step S618, which checks whether a positive signal is present at the comparator at which the induced voltage is compared. If YES, branching to step S620 occurs; if NO, branching to step S634. Step S620 checks the rotation direction. If the rotation direction is forward, then in step S622 the Motstate state variable is set to 34 and execution branches to step S630. If, on the other hand, the rotation direction is backward, execution branches to step S624. Step S624 checks as to which type of commutation is to be carried out. In the case of a six-step commutation, the Motstate state variable is set to 36 in step S626. If a twelve-step commutation is to be performed, the Motstate state variable is set to 38 in step S628. Execution then branches to step S630, in which a calculation of the BEMF and COM times occurs; and execution leaves the interrupt routine in step S632. Step S634 checks the value of the Startup variable. If the value is 1 (startup operation), then in step S636 the Timer1 timer for startup is initialized and execution then branches to step S620.
If, on the other hand, the value is zero, execution leaves the interrupt routine in step S638.
If the Motstate state variable has a value of 6 in step S602 (“Start BEMF sensing A positive” state), execution branches to step S640 and step S642 then checks which type of commutation is to be carried out. For a six-step commutation, branching occurs to step S644 and BEMF sensing A positive is started. The Motstate state variable is then set to 4 in step S648, and execution leaves the interrupt routine in step S650. If, however, the check in S642 sets a twelve-step commutation, step S646 then determines that this is an even-numbered commutation, i.e. a change from the odd-numbered state=3 to the even-numbered state=4. The rotation direction is then checked in step S652. If it is forward, the State variable is then set to 4 in step S654, and execution then branches to step S660. If, on the other hand, the rotation direction is backward, then in step S656 the State variable is set to 10 and execution branches to step S660. Step S660 prepares “BEMF sensing A positive”, i.e. defines that an HCOMP interrupt (
If the Motstate state variable has a value of 28 in step S602, branching to step S1000 (“Commutation” state 11) occurs. Step S1002 checks how commutation is to be performed. For a six-step commutation, the State variable is set to zero in step S1004, and execution branches to step S1008.
For a twelve-step commutation, the State variable is set to 11 in step S1006, thereby modifying the current flow through power stage 16 according to
For illustration, the sequence according to
The next Timer1 interrupt follows at time t_161, and in the High_ISR routine execution branches to step S760 (Motstate=14). In step S774 the commutation state is set to 0, with the result that (according to
At the change in induced voltage 165 at time t_163, the High_ISR routine S600 is once again called by the HCOMP interrupt, and execution branches to step S736 (State=12). In step S746 the Motstate state variable is set to 30, in step S753 the time values BEMF Time and COM Time are calculated, and execution then leaves the routine in step S754.
At the subsequent Timer1 interrupt, execution in the High_ISR routine S600 branches to step S1020, and the next commutation occurs.
At times t_170 and t_175, a respective commutation takes place from an odd-numbered state (State 1, 3, 5, 7, 9, 11) to an even-numbered state (State 0, 2, 4, 6, 8, 10), and it is evident that at this high rotation speed, after the commutation operation, a duty cycle TV of 100% is specified respectively for two entire PWM periods in order to minimize the current gaps. At time t_176 a commutation takes place from an even-numbered state (State 0, 2, 4, 6, 8, 10) to an odd-numbered state (State 1, 3, 5, 7, 9, 11). Because an upper or a lower switch is additionally switched on in the context of this type of commutation, no current gap is created.
Input current I_IN is largely constant during time periods T_171 and T_173, but after the commutation operations at times t_170 and t_175 it rises during a time T_172. This can be referred to as an overshoot of input current I_IN. This overshoot is not sensed by measuring resistor 36 (
Examples of values for the components:
Capacitors 22, 22′
220 μF, max. 75 V
Coil 21
33 μH, max. 3 A.
A reduction in line-conducted emissions is achieved with the use of the Pi filter. Accommodating the additional components on a circuit board is, however, difficult in some cases for space reasons, and the resulting costs are higher than without a Pi filter.
For example, duty cycle TV* of driving signal PWM* is decreased, in ramped fashion in each case, in the range from 60° el. to 90° el. for switch HB, in the range from 180° el. to 210° el. for switch HC, and in the range from 300° el. to 330° el. for switch HA, in this case e.g. in steps of approximately TV*=70%, 52.5%, 35%, and 17.5%. The corresponding lower switches are driven with the inverse signal /PWM*.
The switching off of lower switches LA, LB, LC occurs similarly in ramped fashion, and duty cycle TV** of driving signal PWM**, which in the case of the lower, switched-on switches was consistently 100% switched on, is reduced in ramped fashion in the range 0° el. to 30° el. for switch LC, in the range from 120° el. to 150° el. for switch LA, and in the range from 240° el. to 270° el. for switch LB, in this case e.g. in steps TV**=90%, 67.5%, 45%, 22.5%.
This type of commutation with a “smooth shutdown” requires that the corresponding switches 41, 51, 61, 42, 52, 62, and the three bridge branches 40, 50, 60 of power stage 18, be capable of being driven with different duty cycles TV, TV*, TV**.
In the case where the PWM signals are generated in a μC 23, it is preferred to use a μC 23 in which the duty cycle at the corresponding outputs 241, 251, 261, 242, 252, 262 is adjustable. Slow shutdown allows current controller RGL_I_ave 90 (
Smooth shutdown can be brought about, for example, by counting the number of PWM periods for each 30°-el. time period in the Low_ISR interrupt routine (
DELTA—TV=TV/PWM_COUNTER.
It is then possible, for each PWM period in the corresponding call of the Low_ISR routine for current control, to decrease the duty cycle for the corresponding switch by the value DELTA_TV.
A linear ramp is thereby implemented.
The respective duty cycles TV and TV* of PWM signals PWM and PWM* of upper switches 41, 51, 61 differ in the angle ranges of States 1, 5, and 9. When the PWM signals are generated in center-aligned mode, however, both PWM signals have a pulse in the context of a duty cycle greater than zero, and a measurement of voltage U_34 or U_38 at this point in time still yields a good approximation of average value U_37 87 of voltage U_38 during the pulse. In order to calculate average value U_88 for the entire PWM period, value U_87 is then, to a good approximation according to equation (7), multiplied by the duty cycle TV of the particular switch that is not being shut down in ramped fashion.
Examples of Possible Modifications
Numerous modifications are of course possible, within the scope of the invention. The current measuring resistor or current measuring element 36 can also be arranged in upper lead 30, and can measure input current I_M there; care must be taken that none of the potentials corresponds to GND potential.
Current measuring element 36 can also be arranged outside DC link circuit 20, i.e. in
The current flowing in power stage 16 can also be ascertained by measuring the currents flowing in the individual branches; the currents flowing in the strands during current looping must then not be taken into account computationally or by way of an electronic circuit.
Torque control is also possible with the motor, since the torque is proportional to the current through the winding. For this, the target current value I_ave_s corresponding to the desired torque is specified, and multiplication by duty cycle TV′ is omitted when calculating the actual current value I_ave_i in S516.
Patent | Priority | Assignee | Title |
9083269, | Oct 06 2010 | Robert Bosch GmbH | Method for operating an electric machine |
9787229, | Jun 01 2007 | EBM-Pabst St. Georgen GmbH & Co. KG; EBM-PAPST ST GEORGEN GMBH & CO KG | Method of operating a single-stranded electronically commutated motor from a DC voltage source, and motor for carrying out such a method |
9906182, | Aug 27 2014 | China University of Mining and Technology | Three-phase switched reluctance motor torque ripple two-level suppression method |
Patent | Priority | Assignee | Title |
4446414, | Nov 19 1981 | General Electric Company | Terminal voltage limit regulator for a load commutated inverter |
5420492, | Jan 14 1993 | Nidec Motor Corporation | Method and apparatus of operating a dynamoelectric machine using DC bus current profile |
5457375, | May 27 1994 | Nidec Motor Corporation | Sensorless commutation controller for a poly-phase dynamoelectric machine |
5463299, | Jun 07 1989 | Hitachi, Ltd. | Current controller for controlling a current flowing in a load using a PWM inverter and method used thereby |
5933573, | Apr 22 1995 | EBM-PAPST ST GEORGEN GMBH & CO KG | Method of controlling an electric motor and apparatus for carrying out the method |
6366483, | Jul 24 2000 | Rockwell Automation Technologies, Inc. | PWM rectifier having de-coupled power factor and output current control loops |
6448724, | Oct 28 1999 | Steering Solutions IP Holding Corporation | Apparatus and method for commutation noise reduction |
6759820, | Feb 07 2000 | EBM-PAPST ST GEORGEN GMBH & CO KG | Arrangement for supplying a user, especially a D.C motor, that consumes power in a non-continuous manner from a D.C. system |
7102327, | Mar 28 2002 | Infineon Technologies Americas Corp | Motor current reconstruction via DC bus current measurement |
20050206341, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Nov 20 2008 | EBM—Papst St. Georgen GmbH & Co. KG | (assignment on the face of the patent) | / | |||
Jun 01 2010 | HOGG, GERALD, MR | EBM-PAPST ST GEORGEN GMBH & CO KG | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 024467 | /0489 | |
Jun 01 2010 | KARWATH, ARNO, MR | EBM-PAPST ST GEORGEN GMBH & CO KG | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 024467 | /0489 |
Date | Maintenance Fee Events |
Jul 21 2017 | REM: Maintenance Fee Reminder Mailed. |
Jan 08 2018 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Dec 10 2016 | 4 years fee payment window open |
Jun 10 2017 | 6 months grace period start (w surcharge) |
Dec 10 2017 | patent expiry (for year 4) |
Dec 10 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Dec 10 2020 | 8 years fee payment window open |
Jun 10 2021 | 6 months grace period start (w surcharge) |
Dec 10 2021 | patent expiry (for year 8) |
Dec 10 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Dec 10 2024 | 12 years fee payment window open |
Jun 10 2025 | 6 months grace period start (w surcharge) |
Dec 10 2025 | patent expiry (for year 12) |
Dec 10 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |