1. Field of the Invention
The present invention relates to a control device for a stepping motor, and, more particularly to a technique for lead angle control.
2. Description of the Related Art
In general, a control device for a stepping motor uses a pulse signal as a command signal. In other words, the control device commands a position with a pulse number and commands speed with a pulse frequency. Examples of techniques in the past for setting a lead angle value corresponding to the torque of the stepping motor in such a control device are disclosed in Japanese Patent No. 3715276 and Japanese Patent Application Laid-Open No. 11-113289. In a technique 1 disclosed in Japanese Patent No. 3715276 and a technique 2 disclosed in Japanese Patent Application Laid-Open No. 11-113289, a current phase θi of each phase winding is set as described below.
Technique 1
When δθ<90°
θi=θcom
When δθ>90°
θi=θfb+90°+KV·ω+Ke·ω·δθ
where θcom is a position command, θfb is a rotor position, δθ is a positional deviation, θi is a current phase, KV is a proportional constant, Ke is a proportional constant, and ω is rotor speed.
Technique 2
When δθ<90°+KV·ωfb
θi=θcom
When δθ>90°
θi=θfb+90°+KV·ωfb
where ωfb is rotor speed.
According to the techniques in the past, the rotor position command and the rotor position are compared. When the positional deviation is within a predetermined range, an excitation phase is set with the position command as a stable point. When the positional deviation exceeds the predetermined range, a lead angle value is set to an optimum value. The optimum lead angle value in the techniques in the past means a lead angle value with which maximum torque can be generated with respect to the speed ωfb.
However, in the techniques in the past, when the positional deviation exceeds the predetermined range, a motor is accelerated by the maximum torque that can be generated. Therefore, rotational speed of the rotor rotating to a position of the position command (a target position) may substantially exceed speed of a speed command (target speed) to cause a deficiency described below.
For example, after a rotor shaft is rotated by an external force, when the rotor shaft is opened, the rotor rotates to return to an original position with the maximum torque. In returning to the original position, it is likely that the rotational speed of the rotor reaches an abnormal speed. Since the rotor is not decelerated until the rotor reaches near the original position, because of the inertia of the rotor and a load, the rotor may pass over a position where the rotor should stop. When the inertia is large, the rotor may be unable to stop while repeatedly passing over the position and moving back. A similar phenomenon can occur because of insufficient acceleration torque during operation, fluctuation in a load, and the like.
The present invention has been devised in view of the problems in the past and it is an object of the present invention to provide a control device for a stepping motor that can reduce torque generated by a motor and control the expansion of a speed deviation when the rotational speed of a rotor exceeds a speed command.
In order to attain the object, the present invention provides a control device for a stepping motor that determines, on the basis of a rotor position command (θcom) for indicating a position of a rotor and a rotor position (θfb) as an actual position of the rotor, a phase (θi) of a winding current command, which commands an electric current fed to a winding, and forms current commands (Iacom and Ibcom) for respective phases on the basis of the winding current command phase (θi). The control device includes positional-deviation calculating means (30) for calculating a deviation (δθ) between the position command and the rotor position, rotor-speed-command calculating means (21) for calculating a rotor speed command (ωcom) on the basis of the position command, rotor-speed calculating means (22) for calculating rotor speed (ωfb) on the basis of the rotor position, speed-deviation calculating means (31) for calculating a deviation (δω) between the rotor speed command and the rotor speed, fixed-value generating means (24) for generating a positive fixed value (+K) and a negative fixed value (−K) when the positional deviation is positive and negative, respectively, first judging means (27) for judging whether the positional deviation is within a predetermined range, second judging means (28) for judging whether a sign of the positional deviation and a sign of the speed deviation coincide with each other, and phase setting means (34 to 35) for setting the winding current command phase on the basis of the rotor position command, when the positional deviation is within the predetermined range, setting the winding current command phase on the basis of a value obtained by adding up the rotor position, the fixed value, and a lead angle correction value corresponding to the rotor speed when the positional deviation exceeds the predetermined range and a sign of the positional deviation and a sign of the speed deviation coincide with each other, and setting the winding current command phase on the basis of a value obtained by adding up the rotor position, the fixed value, a lead angle correction value corresponding to the rotor speed, and the speed deviation multiplied by a predetermined constant (Kdo) when the positional deviation exceeds the predetermined range and a sign of the positional deviation and a sign of the speed deviation do not coincide with each other.
It is desirable that the fixed value is a value equivalent to an electrical angle 90°.
For example, the predetermined range is set to have a lower limit value obtained by adding up the negative fixed value and a value defined by a function (f(ωfb)) of the rotor speed and have an upper limit value obtained by adding up the positive fixed value and a value defined by the function of the rotor speed.
For example, the predetermined range is set to have a lower limit value obtained by adding up the negative fixed value and a value obtained by multiplying the rotor speed by a predetermined coefficient (KV) and have an upper limit value obtained by adding up the positive fixed value and a value obtained by multiplying the rotor speed by the predetermined coefficient. In this case, the predetermined coefficient (KV) may be 0.
The lead angle correction value is set to a value defined by the function (f(ωfb)) of the rotor speed. The lead angle correction value may be a value obtained by adding up a value as a product of the predetermined coefficient (KV) and the rotor speed or a value as a product of the predetermined coefficient (KV) and the rotor speed and a value as a product of the predetermined coefficient (Ke), the rotor speed, and the positional deviation.
The winding current command phase set on the basis of the rotor position command may include the speed deviation.
According to the present invention, an excitation phase for generating maximum torque is set when rotor rotational speed is lower than a speed command. The excitation phase is set to reduce torque generated by a motor and control the expansion of a speed deviation when the rotor rotational speed exceeds the speed command. Therefore, it is possible to prevent excessive rotational speed of the rotor and a hunting action at the time when a positional deviation exceeds a predetermined range and stably and quickly position the rotor.
In
The arithmetic unit 20 calculates an A-phase current command Iacom and a B-phase current command Ibcom on the basis of the position command θcom and the rotor position θfb, as described later. A current amplifying unit 40 includes a well-known PWM inverter and outputs electric currents corresponding to the current commands Iacom and Ibcom to respective phase windings of the stepping motor 50.
In
A second subtractor 31 subtracts the rotor rotational speed ωfb from the speed command ωcom and outputs speed deviation δω. A first adder 32 adds up the fixed value K or −K generated by the fixed value generator 24 and an output KV·ωfb of the speed compensator 23.
A first speed difference compensator 25 and a second speed difference compensator 26 multiply the speed deviation δω outputted from the subtractor 31 by proportional constants Kdi and Kdo for speed compensation, respectively.
A first judging device 27 performs comparative judgment of the positional deviation δθ and an output K+KV·ωfb or −K+KV·ωfb of the first adder 32. When −K+KV·ωfb<δθ<K+KV·ωfb, the first judging device 27 connects a first switch element 35 to a terminal “a” side. When this condition is not satisfied, the first judging device 27 connects the switch element 35 to a terminal “b” side. A second judging device 28 turns off a second switch element 36 only when signs (positive or negative) of the positional deviation δθ and the speed deviation δω coincide with each other.
A second adder 33 adds up the position command θcom and an output Kdi·δω of the first speed difference compensator 25 and applies a result of the addition to the terminal “a” of the first switch element 35. A third adder 34 adds up an output Kdo·δω of the second speed difference compensator 26 applied via the second switch element 36, the output K+KV·ωfb or −K+KV·ωfb of the first adder 32, and the rotor position θfb and applies a result of the addition to the terminal “b” of the first switch element 35. A coordinate converter 29 outputs current commands Iacom=Ki·sin θi and Ibcom=Ki·cos θi on the basis of a current command phase θi described later given via the first switch element 35.
Specific actions of the control device according to this embodiment are explained below.
As described below, the control device according to this embodiment calculates the current command phase θi on the basis of the rotor position command θcom and the rotor position θfb and forms the A-phase current command Iacom and the B-phase current command Ibcom from the current command phase θi. The use of the current command phase θi calculated on the basis of the position command θcom is basically the same as the use of the current command phase θi in the case of a normal open-loop stepping motor control system.
It is judged on the basis of a range of the positional deviation δθ whether the current command phase θi is calculated on the basis of the rotor position command θcom or the rotor position θfb.
In the arithmetic unit 20 shown in
−K+KV·ωfb<δθ<+K+KV·ωfb (1)
Consequently, as indicated by the following formula (2), a result of the addition by the adder 33 is outputted from the switch element 35 as the current command phase θi. In this way, when the positional deviation δθ is in the range indicated by Formula (1), the current command phase θi is calculated on the basis of the position command θcom (see an area E in
θi=θcom+Kdi·δω (2)
As the fixed value K in Formula (1), it is desirable to use a value equivalent to an electrical angle 90°. However, the fixed value K is not limited to this. The current command phase θi may be set as θi=θcom. However, if a term Kdi·δω based on the current deviation δω is added as in Formula (2), this is effective for controlling vibration during rotation.
The current command phase θi calculated on the basis of the rotor position θfb is explained below.
The first judging device 27 connects the switch element 35 to the terminal “b” side when a range of the positional deviation θδ exceeds the range of Formula (1), i.e., when δθ>+K+KV·ωfb or δθ<−K+KV·ωfb. In this case, the second judging device 28 turns off the switch element 36 only when signs (positive or negative) of the positional deviation δθ and the speed deviation δω coincide with each other. Thus, eventually, four current command phases θi (see areas A to D in
Condition “a”: δθ>+K+KV·ωfb, δθ>0, δω>0 (the switch element 36 is off)
θi=θfb+K+KV·ωfb (3)
Condition “b”: δθ>+K+KV·ωfb, δθ>0, δθ<0 (the switch element 36 is on)
θi=θfb+K+KV·ωfb+Kd0·δω (4)
Condition “c”: δθ<−K+KV·ωfb, δθ<0, δθ<0 (the switch element 36 is off)
θi=θfb−K+KV·ωfb (5)
Condition “d”: δθ<−K+KV·ωfb, δθ<0, δθ>0 (the switch element 36 is on)
θi=θfb−K+KV·ωfb+Kd0·δω (6)
The current command phases θi calculated by Formula (2) and Formulas (3) to (6) are inputted to the coordinate converter 29 and converted into the current commands Iacom and Ibcom for the respective phases. The motor 50 is not limited to a two-phase motor and may be, for example, a three-phase or five-phase motor. In this case, the coordinate converter 29 converts the current command phase θi into current commands in a number corresponding to the number of phases of the motor 50.
According the current command phase θi calculated by Formula (2), the motor 50 is accelerated to follow command speed at maximum torque. In this case, since the term KV·ωfb of speed compensation is included in the judgment formula (1), switching at a maximum torque generation point that compensates for a delay in an electric current and a delay in calculation due to winding inductance is possible.
On the other hand, according to the current command phases θi determined on the basis of the rotor position θfb, i.e., the current command phases θi calculated by Formulas (3) to (6), the following effect is obtained.
For example, when the motor 50 is excessively rotates in a CW direction, the speed deviation δω is negative and the positional deviation δθ is positive. Thus, the current command phase θi is determined on the basis of Formula (4). In this case, since a third term Kd0·δω of Formula (4) is a negative value, a lead angle with respect to the rotor position θfb is reduced. As a result, the torque decreases.
In this way, in the example described above, an excitation phase is set to reduce generated torque and control a speed deviation. Thus, it is possible to prevent excessive rotation of the rotor and a hunting action (overshoot and undershoot) due to the expansion of the speed deviation and stably and quickly position the rotor. The stable and quick positioning of the rotor is also possible according to the current command phase θi determined by Formula (6).
When the term of Kd0·δω in Formula (4) is larger than the fixed value K, torque in the opposite direction is generated. Thus, a value of the coefficient Kd0 is adjusted to obtain an appropriate speed deviation control effect.
According to the current command phases θi determined by Formula (3) and (5), a lead angle value, with which the motor generates maximum torque, is set.
The gist of the present invention is to use a lead angle value for generating maximum torque on the basis of a result of judgment of polarities of the positional deviation δθ and the speed deviation δω at the time when the rotor rotational speed ωfb does not reach the speed command ωcom and add a value obtained by multiplying the speed deviation δω by a coefficient to the lead angle value for generating the maximum torque (since polarity of δω is opposite to that of δθ, the lead angle value is reduced by this addition) on the basis of a result of the judgment of polarities at the time when the rotor rotational speed ωfb exceeds the speed command ωcom. Thus, there is no limitation on a method of approximately obtain the lead angle value for generating the maximum torque. Therefore, as a lead angle correction value (in the embodiment described above, KV·ωfb), not only a proportional function of the rotor speed ωfb but also a quadric function and a cubic function f·(ωfb) and the like may be used.
In the embodiment described above, the rotor speed ωfb is used as the lead angle correction value. However, the positional deviation δθ can also be used in addition to the rotor speed ωfb.
The arithmetic unit 20′ is different from the arithmetic unit 20 according to the first embodiment in that a speed/positional deviation compensator 37 is provided and an output of the fixed value generator 24 is inputted to the second judging device 8.
In the arithmetic unit 20′, the first judging device 27 connects the switch element 35 to the terminal “a” side when a range of the positional deviation δθ satisfies the following Formula (7). In this case, the current command phase θi=θcom+Kdi·δω indicated by Formula (2) is outputted via the switch element 35 as in the first embodiment. As in the first embodiment, the current command phase θi can be set as θi=θcom.
−K<δθ<+K (7)
When a range of the positional deviation δθ exceeds the range of Formula (7), since the switch element 35 is connected to a terminal B side, the current command phase θi is set on the basis of the rotor position θfb. The speed/positional deviation compensator 37 inputs the rotor rotational speed ωfb and the rotor positional deviation δθ, executes an arithmetic operation for multiplying the rotor rotational speed ωfb and the rotor positional deviation δθ by a predetermined coefficient Ke, and inputs a result of the arithmetic operation Ke·ωfb·δθ to the adder 32. Therefore, in the arithmetic unit 20′, four current command phases θi are calculated according to the following conditions “a” to “d” and outputted from the switch element 35 according to the conditions “a” to “d”.
Condition “a”: δθ>K, δθ>0, δω>0 (the switch element 36 is off)
θi=θfb+K+KV·ωfb+Ke·ωfb·δθ (8)
Condition “b”: δθ>K, δθ>0, δω<0 (the switch element 36 is on)
θi=θfb+K+KV·ωfb+Ke·ωfb·δθ+Kd0·δω (9)
Condition “c”: δθ<−K, δθ<0, δω<0 (the switch element 36 is off)
θi=θfb−K+KVωfb+Ke·ωfb·δθ (10)
Condition “d”: δθ<−K+KV·ωfb, δθ<0, δθ>0 (the switch element 36 is on)
θi=θfb−K+KV·ωfb+Ke·ωfb·δθ+Kd0·δω (11)
An operational effect obtained by using the arithmetic unit 20′ is the same as the operational effect obtained by using the arithmetic unit 20. Therefore, an explanation of the operational effect is omitted.
Number | Date | Country | Kind |
---|---|---|---|
2006-147353 | May 2006 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
4803414 | Kato | Feb 1989 | A |
5523634 | Takahashi et al. | Jun 1996 | A |
6850027 | Kuwano et al. | Feb 2005 | B2 |
Number | Date | Country |
---|---|---|
11-113289 | Apr 1999 | JP |
3715276 | Sep 2005 | JP |
Number | Date | Country | |
---|---|---|---|
20080272730 A1 | Nov 2008 | US |