The disclosure of Japanese Patent Applications No. 2009-261958 filed on Nov. 17, 2009, No. 2010-096374 filed on Apr. 19, 2010, and No. 2010-205920 filed on Sep. 14, 2010, each including the specification, drawings and abstract is incorporated herein by reference in its entirety.
1. Field of the Invention
The invention relates to a motor control unit used to drive a brushless motor, and a vehicle steering system, for example, an electric power steering system, which includes the motor control unit.
2. Description of the Related Art
A motor control unit that controls driving of a brushless motor is usually configured to control the electric current that is supplied to a motor based on the output from a rotational angle sensor that detects the rotational angle of a rotor. As a rotational angle sensor, a resolver that outputs a sine-wave signal and a cosine-wave signal that correspond to the rotational angle (electrical angle) of a rotor is usually used. However, a resolver is expensive, and needs a large number of wires and a large installation space. Therefore, using a resolver as a rotational angle sensor hinders reduction in cost and size of a unit that includes a brushless motor.
To address this problem, a sensorless drive method for driving a brushless motor without using a rotational angle sensor has been proposed. According to the sensorless drive method, the induced voltage that is caused due to the rotation of a rotor is estimated in order to estimate the phase of a magnetic pole (electrical angle of the rotor). When the rotor is at a standstill or rotating at a considerably low speed, it is not possible to estimate the phase of the magnetic pole. Therefore, the phase of the magnetic pole is estimated by another method. More specifically, a sensing signal is input in a stator, and a response of the motor to the sensing signal is detected. Then, the rotational position of the rotor is estimated based on the response of the motor.
For example, Japanese Patent Application Publication No. 10-243699 (JP-A-10-243699) and Japanese Patent Application Publication No. 2009-124811 (JP-A-2009-124811) describe the related art.
According to the sensorless drive method described above, the rotational position of the rotor is estimated based on the induced voltage or the sensing signal, and the motor is controlled based on the estimated rotational position. However, this drive method is not suitable for all uses. There has not been established a method suitable for a control of a brushless motor that is used as a drive source for, for example, a vehicle steering system such as an electric power steering system that supplies a steering assist force to a vehicle steering mechanism. Accordingly, a sensorless control executed by another method has been demanded.
The invention provides a motor control unit that controls a motor according to a new control method that does not require a rotational angle sensor, and a vehicle steering system that includes the motor control unit.
A first aspect of the invention relates to a motor control unit that controls a motor that includes a rotor and a stator that faces the rotor. The motor control unit includes a current drive unit, a control angle calculation unit, a torque detection unit, a command torque setting unit, an addition angle calculation unit, and a command current setting unit. The current drive unit drives the motor based on an axis current value of a rotating coordinate system that rotates in accordance with a control angle that is a rotational angle used in a control. The control angle calculation unit obtains a present value of the control angle by adding an addition angle to an immediately preceding value of the control angle in predetermined calculation cycles. The torque detection unit detects a torque other than a motor torque, which is applied to a drive target that is driven by the motor. The command torque setting unit sets a command torque that is a torque that is other than the motor torque and that is to be applied to the drive target. The addition angle calculation unit calculates the addition angle based on a torque deviation that is a deviation of a detected torque that is detected by the torque detection unit from the command torque that is set by the command torque setting unit. The command current setting unit sets a command current value that is a target value of the axis current value based on the torque deviation. The command current setting unit sets a present value of a command current by correcting an immediately preceding value of the command current by a correction amount that corresponds to the torque deviation.
The foregoing and further objects, features and advantages of the invention will become apparent from the following description of example embodiments with reference to the accompanying drawings, wherein like numerals are used to represent like elements and wherein:
Hereafter, example embodiments of the invention will be described in detail with reference to the accompanying drawings.
The motor control unit 5 drives the motor 3 based on the steering torque detected by the torque sensor 1, the steering angle detected by the steering angle sensor 4, and the vehicle speed detected by the vehicle speed sensor 6, thereby providing appropriate steering assistance based on the steering state and the vehicle speed. In the first embodiment, the motor 3 is a three-phase brushless motor. As illustrated in
A three-phase fixed coordinate system (UVW coordinate system), where the direction in which the U-phase stator coil 51 extends, the direction in which the V-phase coil 52 extends, and the direction in which the W-phase coil 53 extends are used as the U-axis, the V-axis and W-axis, respectively, is defined. In addition, a two-phase rotating coordinate system (dq coordinate system: actual rotating coordinate system), where the direction of the magnetic poles of the rotor 50 is used as the d-axis (axis of the magnetic poles) and the direction that is perpendicular to the d-axis within the rotary plane of the rotor 50 is used as the q-axis (torque axis), is defined. The dq coordinate system is a rotating coordinate system that rotates together with the rotor 50. In the dq coordinate system, only the q-axis current contributes to generation of torque by the rotor 50. Therefore, the d-axis current may be set to 0 and the q-axis current may be controlled based on a desired torque. The rotational angle (rotor angle) θM of the rotor 50 is a rotational angle of the d-axis with respect to the U-axis. The dq coordinate system is an actual rotating coordinate system that rotates in accordance with the rotor angle θM. With the use of the rotor angle θM, coordinate conversion may be made between the UVW coordinate system and the dq coordinate system.
In the first embodiment, the control angle θC that indicates the rotational angle used in the control is employed. The control angle θC is an imaginary rotational angle with respect to the U-axis. An imaginary two-phase rotating coordinate system (γδ coordinate system: hereafter, referred to as “imaginary rotating coordinate system”), where the imaginary axis that forms the control angle θC with the U-axis is used as the γ-axis, and the axis that is advanced 90 degrees from the γ-axis is used as the 8-axis, is defined. When the control angle θC is equal to the rotor angle θM, the γδ coordinate system, which is the imaginary rotating coordinate system, and the dq coordinate system, which is the actual rotating coordinate system, coincide with each other. That is, the γ-axis, which is the imaginary axis, coincides with the d-axis, which is the actual axis, and the δ-axis, which is the imaginary axis, coincides with the q-axis, which is the actual axis. The γδ coordinate system is an imaginary rotating coordinate system that rotates in accordance with the control angle θC, Coordinate conversion may be made between the UVW coordinate system and the γδ coordinate system with the use of the control angle θC.
The load angle θL (=θC−θM) is defined based on the difference between the control angle θC and the rotor angle θM. When the γ-axis current Iγ is supplied to the motor 3 based on the control angle θC, the q-axis component of the γ-axis current Iγ (orthogonal projection to the q-axis) is used as the q-axis current Iq that contributes to generation of torque by the rotor 50. That is, the relationship expressed by Equation 1 is established between the γ-axis current Iγ and the q-axis current Iq.
I
q
=I
γ×sin θL Equation 1
Referring again to
The current detection unit 13 detects the U-phase current IU, the V-phase current IV and the W-phase current IW that flow through the U-phase stator coil 51, the V-phase stator coil 52, and the W-phase stator coil 53 of the motor 3, respectively, (these phase currents will be collectively referred to as “three-phase detected current IUvw” where appropriate). The U-phase current IU, the V-phase current IV and the W-phase current IW are the current values in the directions of the axes of the UVW coordinate system. The microcomputer 11 includes a CPU and memories (a ROM, a RAM, etc.), and serves as multiple function processing units by executing predetermined programs. The multiple function processing units include a steering torque limiter 20, a command steering torque setting unit 21, a torque deviation calculation unit 22, a PT (proportional-integral) control unit 23, an addition angle limiter 24, a control angle calculation unit 26, a command current value preparation unit 30, current deviation calculation unit 32, a PI control unit 33, a γδ/UVW conversion unit 34, a PWM (Pulse Width Modulation) control unit 35, and a UVW/γδ conversion unit 36.
The command steering torque setting unit 21 sets the command steering torque T* based on the steering angle detected by the steering angle sensor 4 and the vehicle speed detected by the vehicle speed sensor 6. For example, as shown in
The steering torque limiter 20 limits the output from the torque sensor 1 within a range between a predetermined upper saturation value +Tmax (+Tmax>0 (e.g. +Tmax=7 Nm)) and a predetermined lower saturation value −Tmax (−Tmax<0 (e.g. −Tmax=−7 Nm)). More specifically, as shown in
The torque deviation calculation unit 22 calculates the deviation (torque deviation) ΔT (T−T*) of the steering torque T that is detected by the torque sensor 1 and then subjected to the limitation process by the steering torque limiter 20 (hereinafter, will be referred to as “detected steering torque T”) from the command steering torque T* set by the command steering torque setting unit 21. The PI control unit 23 executes the PI calculation on the torque deviation ΔT. That is, the torque deviation calculation unit 22 and the PI control unit 23 constitute a torque feedback control unit that brings the detected steering torque T to the command steering torque T*. The PI control unit 23 calculates the addition angle α for the control angle θC by executing the PI calculation on the torque deviation ΔT. Therefore, the torque feedback control unit constitutes an addition angle calculation unit that calculates the addition angle α.
The addition angle limiter 24 imposes limitations on the addition angle α obtained by the PI control unit 23. More specifically, the addition angle limiter 24 limits the addition angle α to a value within a range between a predetermined upper limit UL (positive value) and a predetermined lower limit LL (negative value). The upper limit UL and the lower limit LL are determined based on a predetermined limit ωmax (ωmax>0: e.g. preset value of ωmax=45 degrees). The preset value of the predetermined limit ωmax is determined based on, for example, the maximum steering angular speed. The maximum steering angular speed is the maximum assumable value of the steering angular speed of the steering wheel 10, and, for example, approximately 800 deg/sec.
The rate of change in the electrical angle of the rotor 50 (angular speed in the electrical angle: maximum rotor angular speed) at the maximum steering angular speed is expressed by the product of the maximum steering angular speed, the speed reduction ratio of the speed reduction mechanism 7, and the number of pole pairs of the rotor 50, as indicated by Equation 2. The number of pole pairs is the number of magnetic pole pairs (pair of north pole and south pole) of the rotor 50.
Maximum rotor angular speed =maximum steering angular speed×speed reduction ratio×number of pole pairs Equation 2
The maximum value of the amount of change in the electrical angle of the rotor 50 between the calculations (in the calculation cycle) of the control angle θC is expressed by the value obtained by multiplying the maximum rotor angular speed by the calculation cycle, as indicated by Equation 3.
Maximum value of amount of change in rotor angle =maximum rotor angular speed×calculation cycle =maximum steering angular speed×speed reduction ratio×number of pole pairs×calculation cycle Equation 3
This maximum value of the amount of change in the rotor angle is the maximum amount of change in the control angle θC that is permitted within one calculation cycle. Therefore, the maximum value of the amount of change in the rotor angle may be used as the preset value of the limit ωmax. With the use of the limit ωmax, the upper limit UL and the lower limit LL for the addition angle α are expressed by Equation 4 and Equation 5, respectively.
UL=+ωmax Equation 4
LL=−ωmax Equation 5
The addition angle α obtained through the limitation process executed by the addition angle limiter 24 is added to the immediately preceding value θc(n−1) (n is the number of the present calculation cycle) of the control angle θC by an addition unit 26A of the control angle calculation unit 26 (“Z−1” indicates the immediately preceding value indicated by a signal). Note that, the initial value of the control angle θC is a prescribed value (e.g. 0).
The control angle calculation unit 26 includes the addition unit 26A that adds the addition angle α provided from the addition angle limiter 24 to the immediately preceding value θC(n−1) of the control angle θC. That is, the control angle calculation unit 26 calculates the control angle θC in predetermined calculation cycles. The control angle calculation unit 26 uses the control angle θc in the immediately preceding calculation cycle as the immediately preceding value θc(n−1), and obtains the present value θC(n) that is the control angle θC in the present calculation cycle based on the immediately preceding value θC(n−1). The command current value preparation unit 30 prepares, as command current values, values of electric currents that should be supplied to the coordinate axes (imaginary axes) of the γδ coordinate system, which is the imaginary rotating coordinate system that corresponds to the control angle θC that is a rotational angle used in the control. More specifically, the command current value preparation unit 30 prepares the γ-axis command current value Iγ* and the δ-axis command current value Iδ* (hereinafter, these values will be collectively referred to as “two-phase command current value Iγδ*” where appropriate). The command current value preparation unit 30 sets the γ-axis command current value Iγ* to a significant value, and sets the δ-axis command current value Iδ* to 0. More specifically, the command current value preparation unit 30 sets the γ-axis command current value Iγ* based on the command steering torque T* that is set by the command steering torque setting unit 21 and the detected steering torque T that is detected by the torque sensor 1. That is, the command current value preparation unit 30 is a command current setting unit that sets the two-phase command current value Iγδ.
The command current value preparation unit 30 includes a command current increase/decrease amount calculation unit 30A, an addition unit 30B and an upper/lower limiter 30C. The command current increase/decrease amount calculation unit 30A calculates the current increase/decrease amount ΔIγ* for the command current value Iγ* based on the command steering torque T* and the detected steering torque T in predetermined calculation cycles. More specifically, the command current increase/decrease amount calculation unit 30A calculates the current increase/decrease amount ΔIγ* based on the sign of the command steering torque T* and the deviation ΔT (=T−T*) of the detected steering torque T from the command steering torque T*.
The basic concept of a method of calculating the current increase/decrease amount ΔIγ* using the command current increase/decrease amount calculation unit 30 will be described. When the absolute value of the torque deviation ΔT is equal to or smaller than the predetermined value A (A>0, see
In the case where the sign of the command steering torque T* is the positive sign (T*≧0), when the torque deviation ΔT (=T−T*) is equal to or larger than 0, the absolute value of the detected steering torque T is larger than the absolute value of the command steering torque T*. Accordingly, in this case, it is considered that the motor torque (assist torque) is insufficient. Therefore, when the torque deviation ΔT is larger than the predetermined value +A, the current increase/decrease amount ΔIγ* is set to a positive value in order to fill up a deficiency in the assist torque. In this case, as the absolute value of the torque deviation ΔT increases, the absolute value of the current increase/decrease amount ΔIγ* also increases (becomes a positive value that has a larger absolute value).
On the other hand, when the torque deviation ΔT (=T−T*) is smaller than 0, the absolute value of the detected steering torque T is smaller than the absolute value of the command steering torque T*. Accordingly, in this case, it is considered that the motor torque (assist torque) is not insufficient. Therefore, when the torque deviation ΔT is smaller than the predetermined value −A, the current increase/decrease amount ΔIγ* is set to a negative value in order to suppress power consumption and generation of heat in the motor 3. In this case, as the absolute value of the torque deviation ΔT increases, the absolute value of the current increase/decrease amount ΔIγ* also increases (becomes a negative value that has a larger absolute value).
In the case where the sign of the command steering torque T* is the negative sign (T*<0), when the torque deviation ΔT (=T−T*) is equal to or larger than 0, the absolute value of the detected steering torque T is smaller than the absolute value of the command steering torque T*. Accordingly, in this case, it is considered that the assist torque is not insufficient. Therefore, when the torque deviation ΔT is larger than the predetermined value +A, the current increase/decrease amount ΔIγ* is set to a negative value in order to suppress power consumption and generation of heat in the motor 3. In this case, as the absolute value of the torque deviation ΔT increases, the absolute value of the current increase/decrease amount ΔIγ* also increases (becomes a negative value that has a larger absolute value).
On the other hand, when the torque deviation ΔT (=T −T*) is smaller than 0, the absolute value of the detected steering torque T is larger than the absolute value of the command steering torque T*. Accordingly, in this case, it is considered that the assist torque is insufficient. Therefore, when the torque deviation ΔT is smaller than the predetermined value −A, the current increase/decrease amount ΔIγ* is set to a positive value in order to fill up a deficiency in the assist torque. In this case, as the absolute value of the torque deviation ΔT increases, the absolute value of the current increase/decrease amount ΔIγ* also increases (becomes a positive value that has a larger absolute value).
The current increase/decrease amount ΔIγ* calculated by the command current increase/decrease amount calculation unit 30A is added to the immediately preceding value Iγ*(n−1) (“n” is the number of the present calculation cycle) of the command current value Iγ* by the addition unit 3013 (“Z−1” indicates the immediately preceding value indicated by a signal). Thus, the command current value Iγ* in the present calculation cycle is calculated. Note that the initial value of the command current value Iγ* is a prescribed value (e.g. 0). The command current value Iγ* obtained by the addition unit 3013 is provided to the upper/lower limiter 30C. The upper/lower limiter 30C limits the command current value Iγ* obtained by the addition unit 30B to a value within a range from the predetermined lower limit ξmin (ξmin≧0) to the predetermined upper limit ξmax (ξmax>ξmin).
That is, when the command current value Iγ* obtained by the addition unit 30B is equal to or higher than the lower limit ξmin and equal to or lower than the upper limit ξmax, the upper/lower limiter 30C outputs the command current value Iγ* without correction. When the command current value Iγ* obtained by the addition unit 30B is lower than the lower limit ξmin, the upper/lower limiter 30C outputs the lower limit ξmin as the command current value Iγ* in the present calculation cycle. When the command current value Iγ* obtained by the addition unit 30B is higher than the upper limit ξmax, the upper/lower limiter 30C outputs the upper limit ξmax as the command current value Iγ* in the present calculation cycle.
The current deviation calculation unit 32 calculates the deviation Iγ*−Iγ of the γ-axis detected current Iγ from the γ-axis command current value Iγ* prepared by the command current value preparation unit 30, and the deviation Iδ*−Iδ of the δ-axis detected current Iδ from the δ-axis command current value Iδ (=0). The γ-axis detected current Iγ and the δ-axis detected current Iδ are provided from the UVW/γδ conversion unit 36 to the deviation calculation unit 32.
The UVW/γδ conversion unit 36 converts the three-phase detected current IUvw (U-phase detected current IU, V-phase detected current IV, and the W-phase detected current IW) of the UVW coordinate system, which is detected by the current detection unit 13, into the two-phase detected currents Iγ and Iδ of the γδ coordinate system (hereinafter, these phase currents will be collectively referred to as “two-phase detected current Iγδ” where appropriate). These two-phase detected currents Iγ and Iδ are provided to the current deviation calculation unit 32. The control angle θC calculated by the control angle calculation unit 26 is used for the coordinate conversion that is executed by the UVW/γδ conversion unit 36.
The PI control unit 33 executes the PI calculation on the current deviation calculated by the current deviation calculation unit 32 to prepare the two-phase command voltage Vγδ*(the γ-axis command voltage Vγ* and the δ-axis command voltage Vδ*) that should be applied to the motor 3. The two-phase command voltage Vγδ* is provided to the γδ/UVW conversion unit 34. The γδ/UVW conversion unit 34 executes the coordinate conversion calculation on the two-phase command voltage Vγδ* to prepare the three-phase command voltage VUVW*. The control angle θC calculated by the control angle calculation unit 26 is used for this coordinate conversion. The three-phase command voltage VUVW* is formed of the U-phase command voltage VU*, the V-phase command voltage VV* and the W-phase command voltage VW*. The three-phase command voltage VUvw* is provided to the PWM control unit 35.
The PWM control unit 35 prepares the U-phase PWM control signal, the V-phase PWM control signal and the W-phase PWM control signal having duty ratios that correspond to the U-phase command voltage VU*, the V-phase command voltage VV* and the W-phase command voltage VW*, respectively, and provides the control signals to the drive circuit 12. The drive circuit 12 is formed of an inverter circuit having three phases that correspond to the U-phase, the V-phase and the W-phase. The power elements that constitute the inverter circuit are controlled based on the PWM control signals provided from the PWM control unit 35, and therefore the voltages that correspond to the three-phase command voltage VUvw* are applied to the U-phase stator coil 51, the V-phase stator coil 52 and the W-phase stator coil 53 of the motor 3.
The current deviation calculation unit 32 and the PI control unit 33 constitute a current feedback control unit. The current feedback control unit controls the electric current that is supplied to the motor 3 in such a manner that the electric current that is supplied to the motor 3 approaches the two-phase command current value Iγδ* that is set by the command current value preparation unit 30.
Through the PI control (KP is a proportionality coefficient, KI is an integration coefficient, and 1/s is an integration operator) on the deviation (torque deviation) ΔT of the detected steering torque T from the command steering torque T*, the addition angle α is prepared. The present value θC(n) (θC(n)=θC(n−1)+α) of the control angle θC is obtained by adding the addition angle α to the immediately preceding value θC(n−1) of the control angle θC. At this time, the deviation of the actual rotor angle θM of the rotor 50 from the control angle θC is used as the load angle θL (θL=θC−θM).
Therefore, if the γ-axis current Iγ is supplied to the γ-axis (imaginary axis) in the γδ coordinate system (imaginary rotating coordinate system), which rotates in accordance with the control angle θC, based on the γ-axis command current value Iγ*, the q-axis current Iq is equal to Iγ sin θL (Iq=Iγ sin θL). The q-axis current Iq contributes to generation of torque by the rotor 50. That is, the value obtained by multiplying the q-axis current Iq (=Iγ sin θ0L) by the torque constant KT of the motor 3 is transmitted to the steering mechanism 2 via the speed reduction mechanism 7 as the assist torque TA (=KT×Iγ sin θL). The value obtained by subtracting the assist torque TA from the load torque TL from the steering mechanism 2 is the steering torque that should be applied by the driver to the steering wheel 10. When the steering torque is fed back through the steering torque limiter 20, a system is operated in such a manner that the steering torque is brought to the command steering torque T*. That is, the addition angle α is obtained and the control angle θC is controlled based on the addition angle α so that the detected steering torque T coincides with the command steering torque T*.
The control angle θC is updated with the use of the addition angle α that is obtained based on the deviation ΔT of the detected steering torque T from the command steering torque T* while an electric current is supplied to the γ-axis that is the imaginary axis used in the control. Thus, the load angle θL changes and therefore, the torque that corresponds to the load angle θL is generated by the motor 3. Therefore, the torque that corresponds to the command steering torque T* set based on the steering angle and the vehicle speed is generated by the motor 3. Accordingly, an appropriate steering assist force that corresponds to the steering angle and the vehicle speed is applied to the steering mechanism 2. That is, a steering assist control is executed in such a manner that the steering torque increases as the absolute value of the steering angle increases and the steering torque decreases as the vehicle speed increases.
Therefore, there is provided the electric power steering system in which an appropriate steering assist operation is executed by appropriately controlling the motor 3 without using a rotational angle sensor. Thus, the configuration is simplified and cost is reduced.
When the addition angle α obtained by the PI control unit 23 is equal to or smaller than the upper limit UL (“NO” in S1), the addition angle limiter 24 further compares the addition angle α with the lower limit LL (S3). When the addition angle α is smaller than the lower limit LL (“YES” in S3), the lower limit LL is substituted for the addition angle α (S4). Thus, the lower limit LL (=−ωmax) is added to the control angle θC.
When the addition angle α obtained by the PI control unit 23 is equal to or larger than the lower limit LL and equal to or smaller than the upper limit UL (“NO” in S3), the addition angle α is added to the control angle θC without correction. Therefore, the addition angle limiter 24 limits the addition angle α to a value within the range between the upper limit UL and the lower limit LL so as to stabilize the control. More specifically, although the control state is unstable (assist force is unstable) when the electric current is low or when the control starts, the control is encouraged to move to the stable state.
In the first embodiment, when the absolute value of the detected steering torque T is larger than the absolute value of the command steering torque T*, that is, when the assist torque is insufficient, the current increase/decrease amount ΔIγ* calculated by the command current increase/decrease amount calculation unit 30A of the command current value preparation unit 30 is a positive value. In this case, as the absolute value of the torque deviation ΔT becomes larger, the absolute value of the current increase/decrease amount ΔIγ* also becomes larger (becomes a positive value having a larger absolute value). Then, the current increase/decrease amount ΔIγ* is added to the immediately preceding value of the command current value by the addition unit 3013. Therefore, the command current value Iγ* in the present calculation cycle becomes higher than that in the immediately preceding cycle. As a result, a deficiency in the assist torque is filled up, and the steering torque T is promptly brought to the command steering torque T*.
On the other hand, when the absolute value of the detected steering torque T is smaller than the absolute value of the command steering torque T*, the current increase/decrease amount ΔIγ* calculated by the command current increase/decrease amount calculation unit 30A of the command current value preparation unit 30 is a negative value. In this case, as the absolute value of the torque deviation ΔT becomes larger, the absolute value of the current increase/decrease amount AIγ* also becomes larger (becomes a negative value having a larger absolute value). Then, the current increase/decrease amount ΔIγ* is added to the immediately preceding value of the command current value Iγ* by the addition unit 30B. Therefore, the command current value Iγ* in the present calculation cycle becomes lower than that in the immediately preceding cycle. Thus, the power consumption is suppressed and generation of heat in the motor 3 is suppressed.
Also, the command current value Iγ* obtained by the addition unit 30B is limiter by the upper/lower limiter 30C. Therefore, it is possible to prevent the command current value Iγ* from being excessive. Thus, it is possible to appropriately control the torque.
In the second embodiment, a command current value preparation unit 60 is provided instead of the command current value preparation unit 30 shown in
The command current value preparation unit 60 includes a first PI control unit 60A, a second PI control unit 60B, a switching unit 60C, an addition unit 60D, and an upper/lower limiter 60E. The first PI control unit 60A calculates the current increase/decrease amount ΔIγ* for the command current value Iγ* by executing the PI control on the torque deviation ΔT on the assumption that the sign of the command steering torque T* is the positive sign. When the sign of the command steering torque T* is the positive sign, the first PI control unit 60A executes a feedback control on the current increase/decrease amount ΔIγ* so that the torque deviation ΔT becomes 0. That is, in the case where the sign of the command steering torque T* is the positive sign (T*≧0), when the torque deviation ΔT (=T−T*) is equal or larger than 0 (when the assist torque is insufficient), the first PI control unit 60A calculates the current increase/decrease amount ΔIγ*, which is a positive value, so that the deviation ΔT approaches 0. When the torque deviation ΔT is smaller than 0, the first PI control unit 60A calculates the current increase/decrease amount which is a negative value, so that the deviation ΔT approaches 0. In each of these cases, the absolute value of the current increase/decrease amount ΔIγ* increases as the absolute value of the torque deviation ΔT increases.
The second PI control unit 60B calculates the current increase/decrease amount ΔIγ,* for the command current value Iγ* by executing the PI control on the torque deviation ΔT on the assumption that the sign of the command steering torque T* is the negative sign. When the sign of the command steering torque T* is the negative sign, the second PI control unit 60B executes a feedback control on the current increase/decrease amount ΔIγ,* so that the torque deviation ΔT becomes 0. That is, in the case where the sign of the command steering torque T* is the negative sign (T*<0), when the torque deviation ΔT (=T−T*) is equal or larger than 0, the second PI control unit 60B calculates the current increase/decrease amount ΔIγ*, which is a negative value, so that the deviation ΔT approaches 0. When the torque deviation ΔT is smaller than 0 (when the assist torque is insufficient), the second PI control unit 60B calculates the current increase/decrease amount ΔIγ*, which is a positive value, so that the deviation ΔT approaches 0. In each of these cases, the absolute value of the current increase/decrease amount ΔI7* increases as the absolute value of the torque deviation ΔT increases.
The switching unit 60C selects one of the current increase/decrease amount ΔIγ* calculated by the first PI control unit 60A and the current increase/decrease amount ΔIγ* calculated by the second PI control unit 60B depending on the sign of the command steering torque T*, and outputs the selected current increase/decrease amount ΔIγ*. More specifically, when the sign of the command steering torque T* is the positive sign, the switching unit 60C selects and outputs the current increase/decrease amount ΔIγ* calculated by the first PI control unit 60A. On the other hand, when the sign of the command steering torque T* is the negative sign, the switching unit 60C selects and outputs the current increase/decrease amount ΔIγ* calculated by the second PI control unit 60B.
The current increase/decrease amount ΔIγ* output from the switching unit 60C is added to the immediately preceding value Iγ*(n−1) (“n” is the number of the present calculation cycle) of the command current value Iγ* by the addition unit 60D (“Z−1” indicates the immediately preceding value indicated by a signal). Thus, The command current value Iγ* in the present calculation cycle is calculated. Note that, the initial value of the command current value Iγ* is a prescribed value (e.g. 0). The command current value Iγ* obtained by the addition unit 60D is provided to the upper/lower limiter 60E. The upper/lower limiter 60E limits the command current value Iγ* obtained by the addition unit 60D to a value within a range from the predetermined lower limit ξmin (ξmin≧0) to the predetermined upper limit ξmax (ξmax>ξmin).
That is, when the command current value iv obtained by the addition unit 60D is equal to or higher than the lower limit ξmin and equal to or lower than the upper limit ξmax, the upper/lower limiter 60E outputs the command current value Iγ* without correction. When the command current value Iγ* obtained by the addition unit 60D is lower than the lower limit ξmin, the upper/lower limiter 60E outputs the lower limit ξmin as the command current value Iγ* in the present calculation cycle. When the command current value Iγ* obtained by the addition unit 60D is higher than the upper limit ξmax, the upper/lower limiter 60E outputs the upper limit ξmax as the command current value Iγ* in the present calculation cycle. In the second embodiment as well, it is possible to obtain the same effects as those in the first embodiment.
More specifically, the command current value preparation unit 70 sets the γ-axis command current value Iγ* based on the ratio between the change amount δT of the detected steering torque T (hereinafter, referred to as “steering torque change amount δT”) and the addition angle α. The steering torque change amount δT is obtained by subtracting the detected steering torque T(n−1) in the immediately preceding calculation cycle from the detected steering torque T(n) in the present calculation cycle. The command current value preparation unit 70 includes a command current increase/decrease amount calculation unit 70A, an addition unit 70B and an upper/lower limiter 70C.
The command current increase/decrease amount calculation unit 70A calculates the current increase/decrease amount ΔIγ* for the command current value Iγ* based on the absolute value of the ratio of the steering torque change amount δT to the addition angle α (|δT/α|), the absolute value of the ratio of the addition angle α to the steering torque change amount δT (|α/δT|), and the present command current value Iγ* (immediately preceding value of the command current value Iγ*). The ratio of the steering torque change amount δT to the addition angle α (δT/α) is obtained by dividing the steering torque change amount δT calculated in the present calculation cycle by the addition angle α calculated by the PT control unit 23 and then subjected to the limitation process by the addition angle limiter 24 in the immediately preceding calculation cycle or the present calculation cycle. The ratio of the addition angle α to the steering torque change amount δT (α/δT) is obtained by dividing the addition angle α calculated by the PI control unit 23 and then subjected to the limitation process by the addition angle limiter 24 in the immediately preceding calculation cycle or the present calculation cycle by the steering torque change amount δT calculated in the present calculation cycle.
The command current increase/decrease amount calculation unit 70A calculates the current increase/decrease amount ΔIγ* for the command current value Iγ* in the following manner. The relationship between the absolute value of the ratio of the steering torque change amount δT to the addition angle α (|δT/α|) and the current increase/decrease amount ΔIγ* is set in advance. Also, the relationship between the absolute value of the ratio of the addition angle α to the steering torque change amount δT (|α/δT|) and the current increase/decrease amount ΔIγ* is set in advance. In addition, the relationship between the present command current value Iγ* and the increase/decrease amount gain G is set in advance.
When the value δT that is used as the denominator of the ratio of the addition angle α to the steering torque change amount δT (α/δT) is a small value near 0, an error is likely to be generated in the calculated value of the ratio α/δT. Therefore, the command current increase/decrease amount calculation unit 70A calculates the base value of the current increase/decrease amount ΔIγ* based on the absolute value of the other ratio (|δT/α|). Then, the command current increase/decrease amount calculation unit 70A calculates the final current increase/decrease amount ΔIγ* by multiplying the base value by the increase/decrease amount gain G corresponding to the present command current value Iγ*.
On the other hand, when the value α that is used as the denominator of ratio of the steering torque change amount δT to the addition angle α (δT/α) is a small value near 0, an error is likely to be generated in the calculated value of the ratio δT/α. Therefore, the command current increase/decrease amount calculation unit 70A calculates the base value of the current increase/decrease amount ΔIγ* based on the absolute value of the other ratio (|α/δT|). Then, the command current increase/decrease amount calculation unit 70A calculates the final current increase/decrease amount ΔIγ* by multiplying the base value by the increase/decrease amount gain G corresponding to the present command current value Iγ*.
When the absolute value of the ratio of the steering torque change amount δT to the addition angle α (|δT/α|) is large, the amount of change in the assist torque TA with respect to the amount of change in the load angle θL is large. Therefore, it is considered that the load angle θL is near 0°. For example, when the assist torque characteristic is expressed by the curve S1 in
When the load angle θL is near 0°, the efficiency of the assist torque TA with respect to the γ-axis current Iγ is low. When the load angle θL is near 90° (or −90°), the efficiency of the assist torque TA with respect to the γ-axis current Iγ is high. This is because when the load angle θL is near 90°, the magnetic field of the coil can be generated in the direction substantially perpendicular to the rotor 50. If the γ-axis current Iγ is decreased when the load angle θL is near 0°, control is executed such that the load angle θL becomes a value near 90° in order to generate the same magnitude of assist torque. Therefore, it is possible to increase the efficiency of the assist torque TA with respect to the γ-axis current Iγ. For example, when the operation point is at the point a on the curve S1, if the γ-axis current Iγ is decreased, it is possible to shift the operation point to the point c on the curve S2.
For the reason described above, as shown in
The absolute value of the ratio of the addition angle α to the steering torque change amount δT (|α/δT|) decreases as the absolute value of the ratio of the steering torque change amount δT to the addition angle α (|δT/α|) increases. Therefore, the direction in which the current increase/decrease amount ΔIγ* changes with respect to the absolute value (|α/δT|) is opposite to the direction in which the current increase/decrease amount ΔIγ* changes with respect to the absolute value (|δT/α|).
For example, when the assist torque characteristic is indicated by the curve S2 in the case where the γ-axis current Iγ is a low value and the load angle θL is an angle near 0°, which corresponds to the point d on the curve S2, the absolute value |δT/α| is large. In this case, as described above, the γ-axis current Iγ is decreased to increase the efficiency of the assist torque TA with respect to the γ-axis current Iγ. Thus, the load angle θL is shifted to an angle near 0°. As described above, when the γ-axis current Iγ is low and the absolute value |δT/α| is large (for example, when the operation point is at the point d on the curve S2), if the γ-axis current Iγ is decreased while the same magnitude of assist torque is obtained, it is possible to relatively drastically decrease the γ-axis current Iγ as indicated by the arrow Y2 in
In
The case where the base value of the current increase/decrease amount ΔIγ* is a positive value, that is, the case where the command current value Iγ* is increased will be described. When the base value of the current increase/decrease amount ΔIγ* is a positive value, as described above, the absolute value |δT/α| is small (when the absolute value |α/δT| is large), that is, the amount of change in the assist torque TA with respect to the change amount δθL of the load angle θL is small. That is, it is considered that the load angle θL is near 90° (−90°). In this case, as described above, preferably, the γ-axis current Iγ is increased in order to increase the assist torque. However, when the γ-axis current Iγ is already high, if the increase amount is made large, the γ-axis current Iγ may be excessive. Therefore, when the command current value Iγ* is increased to increase the γ-axis current Iγ, preferably, the increase amount is made smaller as the present command current value Iγ* is larger. For the reason described above, the increase/decrease amount gain G is made smaller as the present command current value Iγ* is higher.
The final current increase/decrease amount ΔIγ* is obtained by multiplying the base value of the current increase/decrease amount ΔIγ* calculated based on the characteristic shown in
That is, when the command current value Iγ* obtained by the addition unit 70B is equal to or higher than the lower limit ξmin and equal to or lower than the upper limit ξmax, the upper/lower limiter 70C outputs the command current value Iγ* without correction. When the command current value Iγ* obtained by the addition unit 70B is lower than the lower limit ξmin, the upper/lower limiter 70C outputs the lower limit ξmin as the command current value Iγ* in the present calculation cycle. When the command current value Iγ* obtained by the addition unit 70B is higher than the upper limit ξmax, the upper/lower limiter 70C outputs the upper limit ξmax as the command current value Iγ* in the present calculation cycle.
The UVW/γδ conversion unit 36 is formed of a UVW/αβ conversion unit 36A and an αβ/γδ conversion unit 36B. The UVW/αβ conversion unit 36A converts the three-phase detected current IUVW (U-phase detected current IU, V-phase detected current IV and W-phase detected current IW) of the UVW coordinate system, which is detected by the current detection unit 13, into the two-phase detected current Iα and Iβ (hereinafter, collectively referred to as “two-phase detected current Iαβ” where appropriate) of the αβ coordinate system that is the two-phase fixed coordinate system. As shown in
The αβ/γ conversion unit 36B converts the two-phase detected current Iαβ into the two-phase detected currents Iγ and Iδ (hereinafter, correctively referred to as “two-phase detected current Iγδ” where appropriate) of the γδ coordinate system. The two-phase detected currents Iγ and Iδ are provided to the current deviation calculation unit 32. The control angle θC calculated by the control angle calculation unit 26 is used for the coordinate conversion executed by the αβ/γ conversion unit 36B. The γδ/UVW conversion unit 34 is formed of a γδ/αβ conversion unit 34A and an αβ/UVW conversion unit 34B. The γδ/αβ conversion unit 34A converts the two-phase command voltage Vγδ* output from the PI control unit 33 into the two-phase command voltage Vαβ* of the αβ coordinate system. The control angle θC calculated by the control angle calculation unit 26 is used for this coordinate conversion. The two-phase command voltage Vαβ* is formed of the α-axis command voltage Vα* and the β-axis command voltage Vβ*. The αβ/UVW conversion unit 34B executes coordinate conversion calculation on the two-phase command voltage Vαβ* thereby preparing the three-phase command voltage VUVW*. The three-phase command voltage VUVW* is formed of the U-phase command voltage VU*, the V-phase command voltage VV* and the W-phase command voltage VW*. The three-phase command voltage UUVW* is provided to the PWM control unit 35
The induced voltage estimation unit 37 estimates the inducted voltage generated by the rotation of the motor 3.
The induced voltage estimation unit 37 is formed of an inverse motor model (inverse model of the motor model) 65 that estimates the motor voltage using the two-phase detected current Iαβ as an input, and a voltage deviation calculation unit 66 that obtains the deviation of the motor voltage that is estimated by the inverse motor model 65 from the two-phase command voltage Vαβ*. The voltage deviation calculation unit 66 obtains the disturbance to the two-phase command voltage Vαβ*. As is clear from
The command current value preparation unit 80 includes a command current increase/decrease amount calculation unit 80A, an output control unit 80B, an addition unit 80C, and an upper/lower limiter 80D. The command current increase/decrease amount calculation unit 80A calculates the current increase/decrease amount ΔIγ* for the command current value Iγ* based on the command steering torque T* and the detected steering torque T in predetermined calculation cycles. More specifically, the command current increase/decrease amount calculation unit 80A calculates the current increase/decrease amount ΔIγ* based on the sign of the command steering torque T* and the deviation ΔT (=T−T*) of the detected steering torque T from the command steering torque T*.
The basic concept of a method of calculating the current increase/decrease amount ΔIγ* using the command current increase/decrease amount calculation unit 80A will be described. When the absolute value of the torque deviation ΔT is larger than the predetermined value E (E>0, see
On the other hand, in each of the case where the absolute value of the torque deviation ΔT is smaller than the predetermined value E and the case where the absolute value of the torque deviation ΔT is equal to or larger than the predetermined value E and the absolute value of the detected steering torque T is smaller than the absolute value of the command steering torque T*, the command current value is set to a value lower than 0 in order to suppress power consumption and generation of heat in the motor 3. That is, the command current increase/decrease amount calculation unit 80A calculates the current increase/decrease amount ΔIγ*(ΔIγ*<0) with which the command current value Iγ* is decreased (hereinafter, referred to as “current decrease amount” where appropriate). The details of the command current increase/decrease amount calculation unit 80A will be described later.
If the current increase/decrease amount ΔIγ* calculated by the command current increase/decrease amount calculation unit 80A is the “current increase amount” (ΔIγ*>0), the output control unit 8013 outputs this current increase/decrease amount ΔIγ*. On the other hand, if the current increase/decrease amount ΔIγ* calculated by the command current increase/decrease amount calculation unit 80A is the “current decrease amount” (ΔIγ*<0), the output control unit 80B outputs this current increase/decrease amount ΔIγ* only when it is determined that a time equal to or longer than the predetermined time Ts has elapsed since the command current value Iγ* is decreased last time and the motor 3 (rotor 50) is at a standstill (not rotating).
In other words, the output control unit 80B does not output the current increase/decrease amount ΔIγ* when a time equal to or longer than the predetermined time Ts has not elapsed since the command current value Iγ* is decreased last time or the motor 3 is rotating. The predetermined time Ts is a minimum cycle when the command current value Iγ* is successively decreased. In this embodiment, it is determined whether the motor 3 is at a standstill based on the estimated induced voltage Êαβ that is estimated by the induced voltage estimation unit 37. More specifically, when the square sum (Êα2+Êβ2) of the α-axis induced voltage Êα and the β-axis induced voltage Êβ is equal to or smaller than the predetermined threshold H, the output control unit 8013 determines that the motor 3 is at a standstill. On the other hand, when the square sum (Êα2+Êβ2) is larger than the threshold H, the output control unit 80B determines that the motor 3 is rotating. The threshold H is set to a value that is larger than an estimated error of the square sum (Êα2+Êβ2).
The predetermined time Ts is set as follows. If the command current value Iγ* is decreased, the load angle θL is controlled such that the same magnitude of assist torque (motor torque) is generated. The predetermined time Ts is set to the maximum value of the time that is required to bring the load angle θL to the angle at which the same magnitude of assist torque is generated, from when the command current value Iγ* is decreased. The maximum value Ts is set to, for example, the maximum value of the permissible time during which continuation of inappropriate assist torque is permitted (hereinafter, referred to as “maximum permissible time for inappropriate state”). The “maximum permissible time for inappropriate state” is set to, for example, 100 ms.
After the command current value Iγ* is decreased, if the command current value Iγ* is further decreased before the load angle θL is brought to the angle at which the same magnitude of assist torque is generated, there is a possibility that the load angle θL is not brought to an appropriate value. Therefore, in this embodiment if the time equal to or longer than the predetermined time Ts has not elapsed since the command current value Iγ* is decreased last time, the current increase/decrease amount ΔIγ* with which the command current value Iγ* is decreased is not output.
If the driver takes his/her hands off the steering wheel 10 while the motor 3 (steering wheel 10) is rotating, the command current value Iγ* may be excessively decreased because the absolute value of the detected steering torque T decreases. Then, there arises a possibility that the required assist torque is not obtained. In order to avoid occurrence of such a situation, in this embodiment, the current increase/decrease amount ΔIγ* is not output when the motor 3 (steering wheel 10) is rotating.
The command current increase/decrease amount calculation unit 80A will be described in detail.
When the torque deviation ΔT is equal to smaller than the predetermined value +D (D>0) that is smaller than the predetermined value +E, the current increase/decrease amount ΔIγ* is fixed to the minimum value −ΔIγmin* that is smaller than 0 (ΔIγmin*>0). When the torque deviation ΔT is between the predetermined value +E and the predetermined value +D, the current increase/decrease amount ΔIγ* is set to decrease (linearly decrease in the example in
The absolute value ΔIγmax* of the maximum value +ΔIγmax* of the current increase/decrease amount ΔIγ* is the maximum value of the “current increase amount”. The maximum value +ΔIγmax* is set to such a value that the command current value Iγ* reaches the command current upper limit (upper limit for the upper/lower limiter 80D) within the “maximum permissible time for inappropriate state (100 ms in this example)” if the current increase/decrease amount ΔIγ* is set to the maximum value +ΔIγmax*. More specifically, the calculation cycle of the calculation of the current increase/decrease amount ΔIγ*, executed by the command current increase/decrease amount calculation unit 80A, is set to a value shorter than the “maximum permissible time for inappropriate state (100 ms in this example)”. The maximum value +ΔIγmax* is set to such a value that the command current value Iγ* reaches the upper limit of the command current if the maximum value +ΔIγmax* is calculated as the current increase/decrease amount ΔIγ* over the time corresponding to the “maximum permissible time for inappropriate state (100 ms in this example)” starting from the state where the command current value Iγ* is the lower limit (lower limit for the upper/lower limiter 80D).
Thus, when the torque deviation ΔT is equal to or larger than the predetermined value +F, it is possible to increase the command current value γ* to the upper limit within the “maximum permissible time for inappropriate state (100 ms in this example)”. If the “current increase amount” is changed from 0 to the maximum value +ΔIγmax*, the assist torque is abruptly changed, which is not preferable. Therefore, when the torque deviation ΔT is equal to or larger than the predetermined value +E and equal to or smaller than the predetermined value +F (when the amount of deficiency in the assist torque is small), the “current increase amount” is gradually increased from 0 to the maximum value +ΔIγmax*. Thus, when the torque deviation ΔT is equal to or larger than the predetermined value +E and equal to or smaller than the predetermined value +F, there is a possibility that the command current value Iγ* is not increased to the upper limit within the “maximum permissible time for inappropriate state”. However, it is considered that no problem occurs because the amount of deficiency in the assist torque (torque deviation ΔT) is small.
The absolute value ΔIγmin* of the minimum value −ΔIγmin* of the current increase/decrease amount ΔIγ* is the maximum value of the “current decrease amount”. The absolute value ΔIγmin* is set to such a value that the corresponding assist torque change amount is equal to or smaller than the predetermined value (e.g. 2 Nm) and the time that is required to bring the load angle θL to the angle at which the same magnitude of assist torque is generated after the command current value Iγ* is decreased is equal to or shorter than the “maximum permissible time for inappropriate state (100 ms in this example)”.
In the case where the sign of the command steering torque T* is the positive sign (T*≧0), when the torque deviation ΔT (T−T*) is smaller than 0, the absolute value of the detected steering torque T is smaller than the absolute value of the command steering torque T*. In this case, it is considered that the assist torque is not insufficient. However, in the case where there are variations in the output from the torque sensor 1, when the maximum value of the detection error due to the variation is set to the value E, even if the actual torque deviation ΔT is 0, the calculated torque deviation ΔT may be a value within the range from the predetermined value −E to the predetermined value +E.
Therefore, when there is a possibility that the actual torque deviation ΔT is 0, that is, when the calculated torque deviation ΔT is within the range from the predetermined value −E to the predetermined value +E, the command current value Iγ* is decreased in order to suppress power consumption and generation of heat in the motor 3. When the calculated torque deviation ΔT is smaller than the predetermined value −E, the current increase/decrease amount ΔIγ* is set to a negative value in order to suppress power consumption and generation of heat in the motor 3. More specifically, when the torque deviation ΔT is a value between the predetermined value +E and the predetermined value +D, the current increase/decrease amount ΔIγ* decreases (current decrease amount increases) as the torque deviation ΔT decreases. Also, when the torque deviation ΔT is a value equal to or smaller than the predetermined value +D, the current increase/decrease amount ΔIγ* is set to the minimum value −ΔIγmin* (the maximum value of the “current decrease amount”).
On the other hand, in the case where the sign of the command steering torque T* is the positive sign (T*≧0), when the torque deviation ΔT is equal to or larger than 0, the absolute value of the detected steering torque T is larger than the absolute value of the command steering torque T*. Accordingly, in this case, it is considered that the motor torque (assist torque) is insufficient. Therefore, when the torque deviation ΔT is larger than the predetermined value +E, the current increase/decrease amount ΔIγ* is set to a positive value in order to fill up a deficiency in the assist torque. More specifically, when the torque deviation ΔT is between the predetermined value +E and the predetermined value +F, the current increase/decrease amount ΔIγ* increases (“current increase amount” increases) as the torque deviation ΔT increases. When the torque deviation ΔT is a value equal to or larger than the predetermined value +F, the current increase/decrease amount ΔIγ* is set to the maximum value +ΔIγmax* (the maximum value of the “current increase amount”).
When the torque deviation ΔT is equal to or larger than the predetermined value −D that is larger than the predetermined value −E, the current increase/decrease amount ΔIγ* is fixed to the minimum value −ΔIγ* that is smaller than 0 (ΔIγ*>0). When the torque deviation ΔT is between the predetermined value −E and the predetermined value −D, the current increase/decrease amount ΔIγ* is set such that the current increase/decrease amount ΔIγ* decreases (linearly decreases in the example in
In the case where the sign of the command steering torque T* is the negative sign (T*<0), when the torque deviation ΔT (=T−T*) is larger than 0, the absolute value of the detected steering torque T is smaller than the absolute value of the command steering torque T*. Accordingly, in this case, it is considered that the assist torque is not insufficient. However, in the case where there are variations in the output from the torque sensor 1, when the maximum value of the detection error due to the variation is set to the value E, even if the actual torque deviation ΔT is 0, the calculated torque deviation ΔT may be a value within the range from the predetermined value −E to the predetermined value +E. Therefore, when there is a possibility that the actual torque deviation ΔT is 0, that is, when the calculated torque deviation ΔT is within the range from the predetermined value −E to the predetetinined value +E, the command current value Iγ* is decreased in order to suppress power consumption and generation of heat in the motor 3.
Also, when the calculated torque deviation ΔT is larger than the predetermined value −E, the current increase/decrease amount ΔIγ* is set to a negative value in order to suppress power consumption and generation of heat in the motor 3. More specifically, when the torque deviation ΔT is a value between the predetermined value −E and the predetermined value +D, the current increase/decrease amount ΔIγ* is decreased (“current decrease amount” is increased) as the torque deviation ΔT increases. When the torque deviation ΔT is a value equal to or larger than the predetermined value −D, the current increase/decrease amount ΔIγ* is set to the minimum value −ΔIγmin* (“maximum value of the “current decrease amount”).
On the other hand, when the torque deviation ΔT (=T−T*) is smaller than 0, the absolute value of the detected steering torque T is larger than the absolute value of the command steering torque T*. Accordingly, in this case, it is considered that the assist torque is insufficient. Therefore, when the torque deviation ΔT is smaller than the predetermined value −E, the current increase/decrease amount ΔIγ* is set to a positive value in order to fill up a deficiency in the assist torque. More specifically, when the torque deviation ΔT is a value between the predetermined value −E and the predetermined value −F, the current increase/decrease amount ΔIγ* increases (the “current increase amount” increases) as the torque deviation ΔT decreases. When the torque deviation ΔT is a value equal to or smaller than the predetermined value −F, the current increase/decrease amount ΔIγ* is set to the maximum value +ΔIγmax*(the maximum value of the “current increase amount”).
The current increase/decrease amount ΔIγ* calculated by the command current increase/decrease amount calculation unit 80A is provided to the output control unit 80B. The output control unit 80B executes the above-described process.
When it is determined that the current increase/decrease amount ΔIγ* calculated by the command current increase/decrease amount calculation unit SOA is the “current increase amount” (“NO” in S12), the output control unit 8013 outputs the current increase/decrease amount ΔIγ*(“current increase amount”) calculated in present calculation cycle (S13), and ends the process in the present calculation cycle. On the other hand, when it is determined that the current increase/decrease amount ΔIγ* calculated by the command current increase/decrease amount calculation unit 80A is the “current decrease amount” (“YES” in S12), the output control unit 80B determines whether a time equal to or longer than the predetermined time Ts has elapsed since the command current value Iγ* is decreased last time (S14). The predetermined time Ts is the minimum cycle when the command current value Iγ* is successively decreased, and 100 ms in this example. In S14, a determination is made, for example, by determining whether the predetermined time Ts has elapsed since the time point at which the newest “current decrease amount” is output from the output control unit 80B.
When a time equal to or longer than the predetermined time Ts has elapsed since the command current value Iγ* is decreased last time (“YES” in S14), it is determined whether the square sum (Êα2+Êβ2) of the estimated induced voltage Êαβ estimated by the induced voltage estimation unit 37 is equal to or lower than the predetermined threshold H (S15). When the square sum (Êα2+Êβ2) of the estimated induced voltage Êαβ is equal to or smaller than the predetermined threshold H (“YES” in S15), the output control unit 80B outputs the current increase/decrease amount ΔIγ* (“current decrease amount”) calculated in the present calculation cycle (S16), and ends the process in the present calculation cycle.
When it is determined in S14 that a time that is equal to or longer than the predetermined time Ts has not elapsed since the command current value Iγ* is decreased last time (“NO” in S14) or when it is determined in S15 that the square sum (Êα2+Êβ2) of the estimated induced voltage Êαβ is equal to or larger than the threshold H (“NO” in S15), the output control unit 80B ends the process in the present calculation cycle without outputting the current increase/decrease amount ΔIγ*(“current decrease amount”) calculated in the present calculation cycle (S17).
Referring again to
That is, when the command current value Iγ* obtained by the addition unit 80C is equal to or higher than the lower limit ξmin and equal to or lower than the upper limit ξmax, the upper/lower limiter 80D outputs the command current value Iγ* without correction. When the command current value Iγ* obtained by the addition unit 80C is lower than the lower limit ξmin, the upper/lower limiter 80D outputs the lower limit ξmin as the command current value Iγ* in the present calculation cycle. When the command current value Iγ* obtained by the addition unit 80C is higher than the upper limit ξmax, the upper/lower limiter 80D outputs the upper limit ξmax as the command current value Iγ* in the present calculation cycle.
In the embodiment described above, whether the motor 3 is at a standstill is determined based on the square sum (Êα2+Êβ2) of the estimated induced voltage. Alternatively, whether the motor 3 is at a standstill may be determined based on the amount of change in the steering angle per unit time, which is detected by the steering angle sensor 4. More specifically, when the amount of change in the steering angle per unit time is equal to or smaller than a predetermined threshold, it is determined that the motor 3 is at a standstill. When the amount of change in the steering angle per unit time is larger than the predetermined threshold, it is determined that the motor 3 is rotating.
In the first embodiment shown in
When the driver turns the steering wheel 10 in the clockwise direction and then performs a steering operation for returning the steering wheel 10 toward the neutral position, the each of the signs of the command steering torque T* and the detected steering torque T is the positive sign, and the absolute value of the detected steering torque T decreases. Therefore, the torque deviation ΔT (=T−T*) is a negative value. When the torque deviation ΔT becomes a negative value due to the steering operation for returning the steering wheel 10 toward the neutral position, the current increase/decrease amount ΔIγ* becomes the minimum value −ΔIγmin*. Therefore, the command current value Iγ* may decrease and the assist torque may become equal to 0. Then, the assist torque that has been generated becomes 0, and the driver feels a sense of discomfort when performing the steering operation for returning the steering wheel 10 toward the neutral position. In the fifth embodiment, the assist torque is generated even during the steering operation for returning the steering wheel 10 toward the neutral position. Thus, the driver does not feel a sense of discomfort when performing the steering operation for returning the steering wheel 10 toward the neutral position.
In the fifth embodiment, a command current value preparation unit 90 is provided instead of the command current value preparation unit 30 shown in
The command current value preparation unit 90 includes a command current increase/decrease amount calculation unit 90A, an addition unit 90B and an upper/lower limiter 90C. The command current increase/decrease amount calculation unit 90A calculates the current increase/decrease amount ΔIγ* for the command current value Iγ* based on the command steering torque T* and the detected steering torque T in predetermined calculation cycles. More specifically, the command current increase/decrease amount calculation unit 90A calculates the current increase/decrease amount ΔIγ* based on the sign of the command steering torque T* and the deviation ΔT (=T−T*) of the detected steering torque T from the command steering torque T*.
The basic concept of a method of calculating the current increase/decrease amount ΔIγ* using the command current increase/decrease amount calculation unit 90A will be described. When the absolute value of the detected steering torque T is larger than the absolute value of the command steering torque T* and the absolute value of the torque deviation ΔT is larger than the first predetermined value E (E>0, see
When the absolute value of the detected steering torque T is smaller than the absolute value of the command steering torque T* and the absolute value of the torque deviation ΔT is larger than the second predetermined value H (H>0: see
In each of the case where the absolute value of the detected steering torque T is larger than the absolute value of the command steering torque T* and the absolute value of the torque deviation ΔT is equal to or smaller than the first predetermined value E and the case where the absolute value of the detected steering torque T is smaller than the absolute value of the command steering torque T* and the absolute value of the torque deviation ΔT is equal to or smaller than the second predetermined value H, the command current value Iγ* is set to a value lower than 0 in order to suppress power consumption and generation of heat in the motor 3. That is, the command current increase/decrease amount calculation unit 90A calculates the current increase/decrease amount ΔIγ*(ΔIγ*<0) with which the command current value Iγ* is decreased (“current decrease amount”).
The absolute value of the predetermined value −H (second predetermined value H) is set to a value equal to or larger than the first predetermined value E. The second predetermined value H is set to, for example, a value within a range from 2 Nm to 3 Nm. When the driver turns the steering wheel 10 in the clockwise direction and then performs the steering operation for returning the steering wheel 10 toward the neutral position, the absolute value of the detected steering torque T is decreased and the torque deviation ΔT becomes a negative value. In this embodiment, when the torque deviation ΔT is smaller than the predetermined value −H that is equal to or smaller than the predetermined value −E, it is determined that the operation for returning the steering wheel 10 toward the neutral position is performed, in consideration of the maximum value E in a detection error due to variations in the output from the torque sensor 1.
When the torque deviation ΔT is equal to or smaller than the predetermined value −G (G>0) that is smaller than the predetermined value −H, the current increase/decrease amount ΔIγ* is fixed to the maximum value +ΔIγmax* (ΔIγmax*>0) that is larger than 0. The predetermined value G is set to, for example, 5 Nm. When the torque deviation ΔT is between the predetermined value −H and the predetermined value −G, the current increase/decrease amount ΔIγ* is set such that the current increase/decrease amount ΔIγ* increases (linearly increases in the example in
When the torque deviation ΔT is within the range equal to or larger than −I (I>0) that is larger than the predetermined value −H and equal to or smaller than the predetermined value +D (D>0) that is smaller than the predetermined value +E, the current increase/decrease amount ΔIγ* is fixed to the minimum value −ΔIγmin* (ΔIγmin*>0) that is smaller than 0. When the torque deviation ΔT is between the predetermined value −H and the predetermined value −I, the current increase/decrease amount ΔIγ* is set such that the current increase/decrease amount AIγ* decreases (linearly decreases in the example in
The absolute value ΔIγmax* of the maximum value +ΔIγmax* of the current increase/decrease amount ΔIγ* is the maximum value of the “current increase amount”. The maximum value +ΔIγmax* may be set to such a value that the command current value Iγ* reaches the command current upper limit (upper limit for the upper/lower limiter 80D) within the “maximum permissible time for inappropriate state (100 ms in this example)” when the current increase/decrease amount ΔIγ* is set to the maximum value +ΔIγmax*.
The absolute value ΔIγmin* of the minimum value +AIγmin* of the current increase/decrease amount ΔIγ* is the maximum value of the “current decrease amount”. The absolute value ΔIγmin* may be set to such a value that the corresponding assist torque change amount is equal to or smaller than the predetermined value (e.g. 2 Nm) and the time required to bring the load angle θL to the angle at which the same magnitude of assist torque is generated after the command current value Iγ* is decreased is equal to or shorter than the “maximum permissible time for inappropriate state (100 ms in this example)”.
In the case where the sign of the command steering torque T* is the positive sign (T*≧0), when the torque deviation ΔT (=T−T*) is equal to or larger than 0, the absolute value of the detected steering torque T is larger than the absolute value of the command steering torque T*, and therefore, it is considered that the assist torque is insufficient. Accordingly, when the torque deviation ΔT is larger than the predetermined value +E, the current increase/decrease amount ΔIγ* is set to a positive value in order to fill up a deficiency in the assist torque.
As described above, when the driver turns the steering wheel 10 in the clockwise direction and then performs the steering operation for returning the steering wheel 10 toward the neutral position, the absolute value of the detected steering torque T decreases, and therefore, the torque deviation ΔT (T−T*) becomes smaller than 0. Therefore, when the torque deviation ΔT becomes smaller than the predetermined value −H, the current increase/decrease amount ΔIγ* is set to a positive value in order to generate the assist torque during the operation for returning the steering wheel 10 toward the neutral position. Thus, it is possible to perform the operation for returning the steering wheel 10 toward the neutral position without a sense of discomfort.
When the torque deviation ΔT is equal to or larger than the predetermined value −H and equal to or smaller than the predetermined value +E, the current increase/decrease amount ΔIγ* is set to a negative value in order to suppress power consumption and generation of heat in the motor 3.
When the driver turns the steering wheel 10 in the counterclockwise direction and then performs the steering operation for returning the steering wheel 10 toward the neutral position, the absolute value of the detected steering torque T decreases and, therefore, the torque deviation ΔT (=T−T*) becomes a positive value. In this embodiment, when the torque deviation ΔT is larger than the predetermined value +H that is equal to or larger than the predetermined value +E, it is determined that the operation for returning the steering wheel 10 toward the neutral position is performed, in consideration of the maximum value E of a detection error due to variations in the output from the torque sensor 1.
When the torque deviation ΔT is equal to or larger than the predetermined value +G that is larger than the predetermined value +H, the current increase/decrease amount ΔIγ* is fixed to the maximum value +ΔIγmax* (ΔIγmax*>0) that is larger than 0. When the torque deviation ΔT is between the predetermined value +H and the predetermined value +G, the current increase/decrease amount ΔIγ* is set such that the current increase/decrease amount ΔIγ* increases (linearly increases in the example in
When the torque deviation ΔT is within the range equal to or larger than the predetermined value −D that is larger than the predetermined value −E and equal to or smaller than the predetermined value +I that is smaller than the predetermined value +H, the current increase/decrease amount ΔIγ* is fixed to the minimum value −ΔIγmin* (ΔIγmin*>0) that is smaller than 0. When the torque deviation ΔT is between the predetermined value +H and the predetermined value +I, the current increase/decrease amount ΔIγ* is set such that the current increase/decrease amount ΔIγ* decreases (linearly decreases in the example in
In the case where the sign of the command steering torque T* is the negative sign (T*<0), when the torque deviation ΔT (=T−T*) is smaller than 0, the absolute value of the detected steering torque T is larger than the absolute value of the command steering torque T* and therefore it is considered that the assist torque is not sufficient. Therefore, when the torque deviation ΔT is smaller than the predetermined value −E, the current increase/decrease amount ΔIγ* is set to a positive value so as to fill up a deficiency in the assist torque.
As described above, when the driver turns the steering wheel 10 in the counterclockwise direction and then performs the steering operation for returning the steering wheel 10 toward the neutral position, the absolute value of the detected steering torque T decreases and therefore the torque deviation ΔT (=T−T*) becomes larger than 0. Therefore, when the torque deviation ΔT becomes larger than the predetermined value +H, the current increase/decrease amount ΔIγ* is set to a positive value to generate the assist torque during the operation for returning the steering wheel 10 toward the neutral position. Thus, it is possible to perform the operation for returning the steering wheel 10 toward the neutral position without a sense of discomfort.
When the torque deviation ΔT is within the range equal to or larger than the predetermined value −E and equal to or smaller than the predetermined value +H, the current increase/decrease amount ΔIγ* is set to a negative value in order to suppress power consumption and generation of heat in the motor 3. Referring again to
That is, when the command current value Iγ* obtained by the addition unit 90B is equal to or higher than the lower limit ξmin and equal to or lower than the upper limit ξmax, the upper/lower limiter 90C outputs the command current value without correction. When the command current value Iγ* obtained by the addition unit 90B is lower than the lower limit ξmin, the upper/lower limit 90C outputs the lower limit ξmin as the command current value Iγ* in the present calculation cycle. When the command current value Iγ* obtained by the addition unit 90B is higher than the upper limit ξmax, the upper/lower limit 90C outputs the upper limit ξmax as the command current value Iγ* in the present calculation cycle.
In the fifth embodiment shown in
In the embodiments described above, a rotational angle sensor is not provided and the motor 3 is driven by executing the sensorless control. Alternatively, a rotational angle sensor, for example, a resolver may be provided and the above-described sensorless control may be executed when the rotational angle sensor malfunctions. Thus, even if the rotational angle sensor malfunctions, driving of the motor 3 is continued. Therefore, the steering assist operation is continued. In this case, when the rotational angle sensor is used, the δ-axis command current value Iδ* may be prepared by the command current value preparation unit 30 based on the steering torque and the vehicle speed and according to the predetermined assist characteristics.
In the embodiments described above, the invention is applied to the electric power steering system. Alternatively, the invention may be applied to a motor control for an electric pump hydraulic power steering system. Further alternatively, the invention may be implemented in various embodiments other than a control of a motor for an electric pump hydraulic power steering system and a power steering system. For example, the invention may be applied to a steer-by-wire (SBW) system, a variable gear ratio (VGR) steering system, and a control of a brushless motor provided in another type of vehicle steering system. The motor control unit according to the invention may be used in not only a control for the vehicle steering system but also controls for motors for other use.
In addition, various design changes may be made within the scope of claims.
Number | Date | Country | Kind |
---|---|---|---|
JP2009-261958 | Nov 2009 | JP | national |
JP2010-096374 | Apr 2010 | JP | national |
JP2010-205920 | Sep 2010 | JP | national |