This application is a National Stage of International Application No. PCT/JP2020/019717 filed on May 19, 2020.
The present disclosure relates to an electric motor control device.
As an angle detector for detecting the rotation angle of a motor, a resolver is often used. While the resolver is known as a robust angle detector, the resolver as an angle detector for a motor is also required to be imparted with redundancy on the basis of a demand for failure resistance of a motor driving system. For example, Patent Document 1 discloses a resolver including an annular stator having resolver windings composed of excitation windings and output windings, and a rotor rotatably provided on the inner side of the annular stator, the resolver windings being formed as first-system and second-system resolver windings provided to one annular stator, thus having a dual-system configuration.
Meanwhile, Patent Document 2 discloses that, in paragraphs [0043] and [0044] and
Patent Document 1: JP 2000-18968A
Patent Document 2: WO2019/123592A1
As in Patent Documents 1 and 2, in the case where teeth of a stator are divided into a plurality of groups in the circumferential direction and the number of divisional groups is increased, depending on the relative eccentric direction between the stator and the rotor, magnetic resistance imbalance between the stator and the rotor is not eliminated, and error occurs in the detected angle due to a first-order component contained in the output signal of the resolver, thus causing a problem that torque ripple occurs due to the angle error.
The present disclosure has been made to solve the above problem, and an object of the present disclosure is to provide an electric motor control device that can suppress ripple due to angle error even when eccentricity has occurred in a resolver.
An electric motor control device according to the present disclosure is an electric motor control device configured to control rotation of an AC electric motor having first three-phase windings and second three-phase windings and provided with a resolver in which a plurality of teeth provided to a stator are wound with a first excitation winding and a first output winding as a first system and a second excitation winding and a second output winding as a second system such that a number of the teeth wound with the windings in the first system and a number of the teeth wound with the windings in the second system are equal to each other. The electric motor control device includes: a first voltage application unit which applies AC voltages for three phases to the first three-phase windings; a second voltage application unit which applies AC voltages for three phases to the second three-phase windings; a first current detector which detects current for each phase of the first three-phase windings; a second current detector which detects current for each phase of the second three-phase windings; and a controller which outputs AC voltage to be applied to the first excitation winding and AC voltage to be applied to the second excitation winding, calculates first voltage command values which are voltage command values for three phases in the first voltage application unit and outputs the first voltage command values to the first voltage application unit, and calculates second voltage command values which are voltage command values for three phases in the second voltage application unit and outputs the second voltage command values to the second voltage application unit. The controller is configured to: perform coordinate conversion of current values for three phases detected by the first current detector into a first d-axis current value and a first q-axis current value, using a first angle obtained from an output of the first system of the resolver, and perform coordinate conversion of current values for three phases detected by the second current detector into a second d-axis current value and a second q-axis current value, using a second angle obtained from an output of the second system of the resolver; select either a first d-axis current command value candidate calculated from a first current command value inputted as a current command value for the first three-phase windings or a second d-axis current command value candidate calculated from a second current command value inputted as a current command value for the second three-phase windings, and set the selected one as a d-axis current command value; calculate a first d-axis voltage command value so that the d-axis current command value and the first d-axis current value coincide with each other, calculate a first q-axis voltage command value so that a first q-axis current command value obtained from the first current command value and the first q-axis current value coincide with each other, and perform coordinate conversion of the first d-axis voltage command value and the first q-axis voltage command value, using the first angle, to calculate the first voltage command values; and calculate a second d-axis voltage command value so that the d-axis current command value and the second d-axis current value coincide with each other, calculate a second q-axis voltage command value so that a second q-axis current command value obtained from the second current command value and the second q-axis current value coincide with each other, and perform coordinate conversion of the second d-axis voltage command value and the second q-axis voltage command value, using the second angle, to calculate the second voltage command values.
Another electric motor control device according to the present disclosure is an electric motor control device configured to control rotation of an AC electric motor having first three-phase windings and second three-phase windings and provided with a resolver in which a plurality of teeth provided to a stator are wound with a first excitation winding and a first output winding as a first system and a second excitation winding and a second output winding as a second system such that a number of the teeth wound with the windings in the first system and a number of the teeth wound with the windings in the second system are equal to each other. The electric motor control device includes: a first voltage application unit which applies AC voltages for three phases to the first three-phase windings; a second voltage application unit which applies AC voltages for three phases to the second three-phase windings; a first current detector which detects current for each phase of the first three-phase windings; a second current detector which detects current for each phase of the second three-phase windings; and a controller which outputs AC voltage to be applied to the first excitation winding and AC voltage to be applied to the second excitation winding, calculates first voltage command values which are voltage command values for three phases in the first voltage application unit and outputs the first voltage command values to the first voltage application unit, and calculates second voltage command values which are voltage command values for three phases in the second voltage application unit and outputs the second voltage command values to the second voltage application unit. The controller is configured to: perform coordinate conversion of current values for three phases detected by the first current detector into a first d-axis current value and a first q-axis current value, and coordinate conversion of current values for three phases detected by the second current detector into a second d-axis current value and a second q-axis current value, using a corrected angle set as an average value of a first angle obtained from an output of the first system and a second angle obtained from an output of the second system of the resolver; calculate a first d-axis voltage command value so that a first d-axis current command value obtained from a first current command value inputted as a current command value for the first three-phase windings and the first d-axis current value coincide with each other, calculate a first q-axis voltage command value so that a first q-axis current command value obtained from the first current command value and the first q-axis current value coincide with each other, and perform coordinate conversion of the first d-axis voltage command value and the first q-axis voltage command value, using the corrected angle, to calculate the first voltage command values; and calculate a second d-axis voltage command value so that a second d-axis current command value obtained from a second current command value inputted as a current command value for the second three-phase windings and the second d-axis current value coincide with each other, calculate a second q-axis voltage command value so that a second q-axis current command value obtained from the second current command value and the second q-axis current value coincide with each other, and perform coordinate conversion of the second d-axis voltage command value and the second q-axis voltage command value, using the corrected angle, to calculate the second voltage command values.
The electric motor control device according to the present disclosure makes it possible to provide an electric motor control device that can suppress ripple due to angle error even when eccentricity has occurred in a resolver.
The first excitation winding 10A wound around a plurality of teeth provided to the stator 13 is connected in series between the teeth, and a terminal of the first excitation winding 10A connected in series is connected to a controller 6 described later. Similarly, a terminal of the first output winding 111A connected in series between teeth is connected to the controller 6 described later. A terminal of another first output winding 112A connected in series between teeth is connected to the controller 6 described later. A terminal of the second excitation winding 10B connected in series is connected to the controller 6 described later. Similarly, a terminal of the second output winding 111B connected in series between teeth is connected to the controller 6 described later. A terminal of another second output winding 112B connected in series between teeth is connected to the controller 6 described later.
A DC power supply 3a outputs DC voltage Vdc1 to a first voltage application unit 4a. A DC power supply 3b outputs DC voltage Vdc2 to a second voltage application unit 4b. Each of these DC power supplies may be any DC power supply that outputs DC voltage, such as a battery, a DC-DC converter, a diode rectifier, or a PWM rectifier. Here, an example in which two DC power supplies 3a and 3b are used is shown. However, using one DC power supply, DC voltage Vdc outputted from the one DC power supply may be supplied to the first voltage application unit 4a and the second voltage application unit 4b.
The first voltage application unit 4a and the second voltage application unit 4b are each configured as an inverter that converts DC voltage to AC voltage. The first voltage application unit 4a undergoes PWM modulation through comparison with a PWM carrier wave having a frequency fc on the basis of first voltage command values Vu1_ref, Vv1_ref, Vw1_ref described later, to reversely convert the DC voltage Vdc1 inputted from the DC power supply 3a (conversion from DC to AC), and applies AC voltages Vu1, Vv1, Vw1 to the first three-phase windings U1, V1, W1 of the AC electric motor 1, respectively. Switches Sup1 to Swn1 of the inverter forming the first voltage application unit 4a are semiconductor switches such as IGBTs, bipolar transistors, or MOS power transistors, to which diodes are connected in antiparallel. The second voltage application unit 4b undergoes PWM modulation through comparison with a PWM carrier wave having a frequency fc on the basis of second voltage command values Vu2_ref, Vv2_ref, Vw2_ref described later, to reversely convert the DC voltage Vdc2 inputted from the DC power supply 3b (conversion from DC to AC), and supplies AC voltages Vu2, Vv2, Vw2 to the second three-phase windings U2, V2, W2 of the AC electric motor 1, respectively. Switches Sup2 to Swn2 of the inverter forming the second voltage application unit 4b are semiconductor switches such as IGBTs, bipolar transistors, or MOS power transistors, to which diodes are connected in antiparallel.
A first current detector 5a detects currents Iu1, Iv1, Iw1 respectively flowing through the first three-phase windings U1, V1, W1, and outputs the detected currents to the controller 6 described later. Similarly, a second current detector 5b detects currents Iu2, Iv2, Iw2 respectively flowing through the second three-phase windings U2, V2, W2, and outputs the detected currents to the controller 6 described later. Each of these current detectors may be a current detector of a known type such as a lower-arm shunt type or a bus single-shunt type.
The controller 6 receives a first current command value I_target1, the currents Iu1, Iv1, Iw1 detected by the first current detector 5a, and the output signal V1A from the first output winding 111A and the output signal V2A from the first output winding 112A of the resolver 2, and outputs the first voltage command values Vu1_ref, Vv1_ref, Vw1_ref to the first voltage application unit 4a. In addition, the controller 6 applies the AC voltage VRA to the first excitation winding 10A of the resolver 2. Further, the controller 6 receives a second current command value I_target2, the currents Iu2, Iv2, Iw2 detected by the second current detector 5b, and the output signal V1B from the second output winding 111B and the output signal V2B from the second output winding 112B of the resolver 2, and outputs the second voltage command values Vu2_ref, Vv2_ref, Vw2_ref to the second voltage application unit 4b. In addition, the controller 6 applies AC voltage VRB to the second excitation winding 10B of the resolver 2.
Next, the configuration of the controller 6 will be described in detail with reference to
A first output signal detection unit 602A periodically detects the output signals V1A, V2A from the two first output windings 111A, 112A in the first system of the resolver 2, at predetermined detection timings (hereinafter, may be referred to as first detection timings) (see
θ1=arctan(V1A_S/V2A_S) (1)
A second output signal detection unit 602B periodically detects the output signals V1B, V2B from the two second output windings 111B, 112B in the second system of the resolver 2 at predetermined detection timings (hereinafter, may be referred to as second detection timings). Detected signals V1B_S, V2B_S are inputted to a second angle calculation unit 604B, and a second angle θ2 is obtained through calculation of Expression (2).
θ2=arctan(V1B_S/V2B_S) (2)
A first angle correction unit 605A calculates an average value of the first angle θ1 and the second angle θ2, and outputs the average value as a first corrected angle θ1_m. A second angle correction unit 605B calculates an average value of the second angle θ2 and the first angle θ1, and outputs the average value as a second corrected angle θ2_m. That is, the first corrected angle and the second corrected angle are the same corrected angle θ1_m=θ2_m=(θ1+θ2)/2.
The effects of the first angle correction unit 605A and the second angle correction unit 605B will be described later. A first current command value calculator 7a calculates a first q-axis current command value iq1_ref on q axis and a first d-axis current command value candidate id1_ref on d axis for applying currents to the first three-phase windings of the AC electric motor 1, on the basis of the first current command value I_target1. The first current command value calculator 7a may substitute values as id1_ref=0 and iq1_ref=I_target1, may perform calculation using known field weakening control, may perform calculation on the basis of known max torque per ampere (MTPA) control, or may use another known calculation method for dq-axis current commands A second current command value calculator 7b calculates a second q-axis current command value iq2_ref on q axis and a second d-axis current command value candidate id2_ref on d axis for applying currents to the second three-phase windings of the AC electric motor 1, on the basis of the second current command value I_target2. The second current command value calculator 7b may substitute values as id2_ref=0 and iq2_ref=I_target2, may perform calculation using known field weakening control, may perform calculation on the basis of known max torque per ampere (MTPA) control, or may use another known calculation method for dq-axis current commands.
A d-axis current selection unit 606 receives the first d-axis current command value candidate id1_ref which is an output value from the first current command value calculator 7a and the second d-axis current command value candidate id2_ref which is an output value from the second current command value calculator 7b. The d-axis current selection unit 606 selects either of id1_ref or id2_ref and outputs the selected one as a d-axis current command value id_ref. As a selection method, the one having the greater absolute value may be selected, or another selection method may be used.
A coordinate converter 8a performs coordinate conversion of the currents Iu1, Iv1, Iw1 flowing through the first three-phase windings and detected by the first current detector 5a, using the first corrected angle θ1_m outputted from the first angle correction unit 605A, to obtain a first d-axis current value id1 and a first q-axis current value iq1 which are currents on rotating two axes (d-q axes). A coordinate converter 8b performs coordinate conversion of the currents Iu2, Iv2, Iw2 flowing through the second three-phase windings and detected by the second current detector 5b, using the second corrected angle θ2_m outputted from the second angle correction unit 605B, to obtain a second d-axis current value id2 and a second q-axis current value iq2 which are currents on rotating two axes (d-q axes).
A subtractor 9a subtracts the first d-axis current value id1 from the d-axis current command value id_ref, and outputs a deviation err_d1. A subtractor 10a subtracts the first q-axis current value iq1 from the first q-axis current command value iq1_ref, and outputs a deviation err_q1. A subtractor 9b subtracts the second d-axis current value id2 from the d-axis current command value id_ref, and outputs a deviation err_d2. A subtractor 10b subtracts the second q-axis current value iq2 from the second q-axis current command value iq2_ref, and outputs a deviation err_q2.
A current controller 11a calculates a first d-axis voltage command value vd1 on rotating two axes (d-q axes) through proportional integral control so that err_d1 obtained from the subtractor 9a coincides with zero, i.e., the d-axis current command value id_ref and the first d-axis current value id1 coincide with each other. A current controller 12a calculates a first q-axis voltage command value vq1 on rotating two axes (d-q axes) through proportional integral control so that err_q1 obtained from the subtractor 10a coincides with zero, i.e., the first q-axis current command value iq1_ref and the first q-axis current value iq1 coincide with each other. A current controller 11b calculates a second d-axis voltage command value vd2 on rotating two axes (d-q axes) through proportional integral control so that err_d2 obtained from the subtractor 9b coincides with zero, i.e., the d-axis current command value id_ref and the second d-axis current value id2 coincide with each other. A current controller 12b calculates a second q-axis voltage command value vq2 on rotating two axes (d-q axes) through proportional integral control so that err_q2 obtained from the subtractor 10b coincides with zero, i.e., the second q-axis current command value iq2_ref and the second q-axis current value iq2 coincide with each other.
A coordinate converter 13a performs coordinate conversion of the first d-axis voltage command value vd1 and the first q-axis voltage command value vq1 on rotating two axes (d-q axes), using the first corrected angle θ1_m, to calculate the three-phase voltage command values Vu1_ref, Vv1_ref, Vw1_ref to be outputted to the first voltage application unit 4a. A coordinate converter 13b performs coordinate conversion of the second d-axis voltage command value vd2 and the second q-axis voltage command value vq2 on rotating two axes (d-q axes), using the second corrected angle θ2_m, to calculate the three-phase voltage command values Vu2_ref, Vv2_ref, Vw2_ref to be outputted to the second voltage application unit 4b.
Hereinafter, the reason why torque ripple due to angle error caused by eccentricity of the resolver can be suppressed in the present embodiment will be described.
When θ1 and θ2 have angle errors with the same magnitude and opposite signs, θ1 and θ2 are represented by Expression (3) and Expression (4).
θ1=θ+Δθ (3)
θ2=θ−Δθ (4)
Here, θ is a true angle and Δθ is angle error. The first angle correction unit 605A calculates the first corrected angle θ1_m by Expression (5) using θ1 and θ2.
θ1_m=0.5×(θ1+θ2) (5)
Through calculation of Expression (5), the angle errors Δθ are canceled out and θ1_m coincides with the value of the true angle θ. Similarly, the second angle correction unit 605B also calculates the second corrected angle θ2_m by Expression (6) using θ2 and θ1.
θ2_m=0.5×(θ2+θ1) (6)
Through calculation of Expression (6), the angle errors Δθ are canceled out and θ2_m coincides with the value of the true angle θ. Thus, through such angle correction as to cancel the angle errors Δθ by each other, it becomes possible to suppress torque ripple due to the angle error Δθ.
In a case where the angle error Δθ is an AC quantity that varies with time, if the first detection timing of detecting θ1 and the second detection timing of detecting θ2 differ from each other, the angle errors Δθ might not be canceled by each other through correction by Expression (5) and Expression (6). This is because the magnitudes of the angle error at the timing of detecting θ1 and the angle error at the timing of detecting θ2 are different from each other. A method for suppressing torque ripple due to angle error in such a case will be described. First, θ1 will be discussed. In θ1, the angle error of +Δθ is superimposed on the true angle θ. It is noted that the sign of Δθ may be either positive or negative. Here, axes obtained by performing dq conversion using θ1 are defined as dc1-qc1 axes. The dc1-qc1 axes mean that the angle is shifted by Δθ relative to the true d-q axes. At this time, current id_c1 flowing by a command on dc1 axis has a true q-axis component. The current having the true q-axis component contributes to torque, and therefore, when id_c1×sin(Δθ) which is a q-axis component of id_c1 occurs as q-axis current error Δiq1, torque ripple occurs. Also current iq_c1 flowing by a command on qc1 axis has error relative to the true q-axis component, but the magnitude of the error is iq_c1×(1−cos(Δθ)) and therefore the influence thereof is almost negligible when Δθ is small. Meanwhile, a true d-axis component of iq_c1 less contributes to torque than the true q-axis component of id_c1 and therefore is not considered here.
Next, θ2 will be discussed. In θ2, angle error of −Δθ is superimposed on the true angle θ. Here, axes obtained by performing dq conversion using θ2 are defined as dc2-qc2 axes. The dc2-qc2 axes mean that the angle is shifted by −Δθ relative to the true d-q axes. At this time, current id_c2 flowing by a command on dc2 axis has a true q-axis component. This component is represented as id_c2×sin(−Δθ) and occurs as q-axis current error Δiq2, thus causing torque ripple. In the same manner as in the dc1-qc1 axes, the influence of a true q-axis component of current iq_c2 flowing by a command on qc2 axis is almost negligible when the angle error is small. Meanwhile, a true d-axis component of iq_c2 less contributes to torque than the true q-axis component of id_c2 and therefore is not considered here.
From the above, the q-axis current error which significantly contributes to torque is the sum of Δiq1 and Δiq2. Here, the sum of Δiq1 and Δiq2 is calculated as shown by Expression (7).
Δiq1+Δiq2=(id_c1−id_c2)sin(Δθ) (7)
In Expression (7), it is found that the q-axis current error can be made zero by setting id_c1 and id_c2 at the same value. Therefore, it is possible to suppress torque ripple by setting id_c1 and id_c2 at the same value. Thus, by making the d-axis current command value for the first three-phase windings and the d-axis current command value for the second three-phase windings equal to each other by the d-axis current selection unit 606, it becomes possible to suppress torque ripple due to the angle error Δθ.
As described above, in a case where difference between the first detection timing and the second detection timing is small enough that the difference does not become a problem, torque ripple due to eccentricity of the resolver can be reduced through angle correction by the first angle correction unit 605A and the second angle correction unit 605B. On the other hand, in a case where there might be some difference between the first detection timing and the second detection timing, torque ripple due to eccentricity of the resolver can be reduced by setting the d-axis current command value for the first three-phase windings and the d-axis current command value for the second three-phase windings at the same value.
As a matter of course, also in the case where angle error correction by the first angle correction unit 605A and the second angle correction unit 605B is effective, the d-axis current command value for the first three-phase windings and the d-axis current command value for the second three-phase windings may be made to coincide with each other by the d-axis current selection unit. In this way, by executing at least one of control using the average value of θ1 and θ2 as the corrected angle for coordinate conversion and control using the same value as the d-axis current command values, it is possible to reduce torque ripple due to eccentricity of the resolver.
The first controller 6a receives the first current command value I_target1, the currents Iu1, Iv1, Iw1 detected by the first current detector 5a, and the output signal V1A from the first output winding 111A and the output signal V2A from the first output winding 112A of the resolver 2, and outputs the first voltage command values Vu1_ref, Vv1_ref, Vw1_ref to the first voltage application unit 4a configured as an inverter. In addition, the first controller 6a applies the AC voltage VRA having a first cycle TA to the first excitation winding 10A of the resolver 2.
The second controller 6b receives the second current command value I_target2, the currents Iu2, Iv2, Iw2 detected by the second current detector 5b, and the output signal V1B for the second output winding 111B and the output signal V2B for the second output winding 112B of the resolver 2, and outputs the second voltage command values Vu2_ref, Vv2_ref, Vw2_ref to the second voltage application unit 4b configured as an inverter. In addition, the second controller 6b applies the AC voltage VRB having a second cycle TB different from the first cycle TA, to the second excitation winding 10B of the resolver 2. Here, the relationship between the first cycle TA and the second cycle TB is assumed to be TB=2×TA.
The first output signal detection unit 602A periodically detects the output signals V1A, V2A from the two first output windings 111A, 112A, at predetermined detection timings (hereinafter, may be referred to as first detection timings).
Here, magnetic interference between the first output winding and the second output winding of the resolver 2 will be described. On the output signals V1A, V2A from the two first output windings 111A, 112A, second-cycle components V1A_TB, V2A_TB induced by a magnetic flux having the second cycle TB excited at the second excitation winding 10B are respectively superimposed due to magnetic interference between the systems.
Here,
Thus, when the angle is calculated using the signals containing V1A_TB, V2A_TB, detection error occurs. Therefore, in order to suppress the angle detection error, it is necessary to remove the second-cycle component V1A_TB from the output signal V1A of the first output winding in the first system. Accordingly, a first removal processing unit 603A performs second-cycle component removing processing for removing (reducing) the component having the second cycle TB, on the detected values V1A_S, V2A_S of the output signals from the two first output windings. Then, the first angle calculation unit 604A calculates the first angle θ1 on the basis of detected values V1A_F, V2A_F of the output signals from the two first output windings that have undergone the second-cycle component removing processing.
In the present embodiment, the second-cycle component removing processing is performed on the basis of the principle described below. As shown in the graph at the lower stage in
ΔT1=TB/2+TB×M (8)
The first removal processing unit 603A is configured as shown in
The first angle calculation unit 604A is configured to calculate the first angle θ1 on the basis of the detected values V1A_F, V2A_F of the output signals from the two first output windings 111A, 112A after the addition. With this configuration, two second-cycle components having plus/minus signs opposite to each other are added, whereby the two second-cycle components are canceled by each other. Thus, in the detected values V1A_F, V2A_F of the output signals from the two first output windings after the addition, the second-cycle components have been removed. Then, on the basis of the detected values from which the second-cycle components have been removed, the first angle θ1 can be accurately calculated.
In the present embodiment, the first angle calculation unit 604A calculates an arctangent of the ratio between the detected value V1A_F of the output signal from the first output winding 111A and the detected value V2A_F of the output signal from the first output winding 112A that have undergone the second-cycle component removing processing, as shown by Expression (9), thus calculating the first angle θ1.
θ1=arctan(V1A_F/V2A_F) (9)
The first angle θ1 is communicated to the second controller 6b by CPU communication. The first angle correction unit 605A receives the first angle θ1 and the second angle θ2 which is a signal communicated from the second controller 6b described later. The first angle correction unit 605A calculates the average value of θ1 and θ2 and outputs the average value as the first corrected angle θ1_m.
Next, the first current command value calculator 7a calculates the first q-axis current command value iq1_ref on q axis and the first d-axis current command value candidate id1_ref on d axis for applying currents to the first three-phase windings of the AC electric motor 1, on the basis of the first current command value I_target1. The first current command value calculator 7a may substitute values as id1_ref=0 and iq1_ref=I_target1, may perform calculation using known field weakening control, may perform calculation on the basis of known max torque per ampere (MTPA) control, or may use another known calculation method for dq-axis current commands The first d-axis current command value candidate id1_ref for applying currents to the first three-phase windings is communicated to the second controller 6b by CPU communication.
The first d-axis current selection unit 606A receives the first d-axis current command value candidate id1_ref which is an output value from the first current command value calculator 7a and the second d-axis current command value candidate id2_ref which is a signal communicated from the second controller 6b described later. The first d-axis current selection unit 606A selects either id1_ref or id2_ref and outputs the selected one as the d-axis current command value id_ref. As a selection method, the one having the greater absolute value may be selected or the one having the smaller absolute value may be selected.
The coordinate converter 8a performs coordinate conversion of the currents Iu1, Iv1, Iw1 flowing through the first three-phase windings and detected by the first current detector 5a, using the first corrected angle θ1_m outputted from the first angle correction unit 605A, to obtain the first d-axis current value id1 and the first q-axis current value iq1 which are currents on rotating two axes (d-q axes).
The subtractor 9a subtracts the first d-axis current value id1 from the d-axis current command value id_ref, and outputs the deviation err_d1. The subtractor 10a subtracts the current iq1 from the first q-axis current command value iq1_ref, and outputs the deviation err_q1. The current controller 11a calculates the first d-axis voltage command value vd1 on rotating two axes (d-q axes) through proportional integral control so that err_d1 obtained from the subtractor 9a coincides with zero. The current controller 12a calculates the first q-axis voltage command value vq1 on rotating two axes (d-q axes) through proportional integral control so that err_q1 obtained from the subtractor 10a coincides with zero. The coordinate converter 13a performs coordinate conversion of the first d-axis voltage command value vd1 and the first q-axis voltage command value vq1 on rotating two axes (d-q axes), using the first corrected angle θ1_m, to obtain the first voltage command values Vu1_ref, Vv1_ref, Vw1_ref.
Next, the second controller 6b will be described.
The second output signal detection unit 602B periodically detects the output signals V1B, V2B from the two second output windings 111B, 112B at predetermined detection timings (hereinafter, may be referred to as second detection timings).
As previously described, magnetic interference occurs between the first output winding and the second output winding of the resolver 2.
Here,
Thus, when the angle is calculated using the signals containing V1B_TA, V2B_TA, detection error occurs. Therefore, in order to suppress the angle detection error, it is necessary to remove the first-cycle component V1B_TA from the output signal V1B of the second output winding. Accordingly, the second removal processing unit 603B performs first-cycle component removing processing for removing (reducing) the component having the first cycle TA, on the detected values V1B_S, V2B_S of the output signals from the two second output windings 111B, 112B. Then, the second angle calculation unit 604B calculates the second angle θ2 on the basis of detected values V1B_F, V2B_F of the output signals from the two second output windings 111B, 112B that have undergone the first-cycle component removing processing.
In the present embodiment, the first-cycle component removing processing is performed on the basis of the principle described below. As shown in the graph at the lower stage in
ΔT2=TA×P (10)
The second removal processing unit 603B is configured as shown in
The second angle calculation unit 604B is configured to calculate the second angle θ2 on the basis of the detected values V1B_F, V2B_F of the output signals from the second output windings 111B, 112B after the subtraction processing. With this configuration, two first-cycle components having equal values at every second removal processing interval ΔT2 are subjected to the subtraction processing so as to be canceled by each other. Thus, in the detected values V1B_F, V2B_F of the output signals from the two second output windings 111B, 112B after the subtraction processing, the first-cycle components have been removed. Then, on the basis of the detected values from which the first-cycle components have been removed, the second angle θ2 can be accurately calculated.
The second angle calculation unit 604B calculates an arctangent of the ratio between the detected value V1B_F of the output signal from the second output winding 111B and the detected value V2B_F of the output signal from the second output winding 112B that have undergone the first-cycle component removing processing, as shown by Expression (11), thus calculating the second angle θ2.
θ2=arctan(V1B_F/V2B_F) (11)
The second angle θ2 is communicated to the first controller 6a by CPU communication. The second angle correction unit 605B receives the second angle θ2 and the first angle Δ1 which is a signal communicated from the first controller 6a. The second angle correction unit 605B calculates the average value of θ2 and θ1 and outputs the average value as the second corrected angle θ2_m.
Next, the second current command value calculator 7b calculates the second q-axis current command value iq2_ref on q axis and the second d-axis current command value candidate id2_ref on d axis for applying currents to the second three-phase windings of the AC electric motor 1, on the basis of the second current command I_target2. The second current command value calculator 7b may substitute values as id2_ref=0 and iq2_ref=I_target2, may perform calculation using known field weakening control, may perform calculation on the basis of known max torque per ampere (MTPA) control, or may use another known calculation method for dq-axis current commands
The second d-axis current command value candidate id2_ref for applying currents to the second three-phase windings is communicated to the first controller by CPU communication. The second d-axis current selection unit 606B receives the second d-axis current command value candidate id2_ref which is an output value from the second current command value calculator 7b and the first d-axis current command value candidate id1_ref which is a signal communicated from the first controller 6a. The second d-axis current selection unit 606B selects either id2_ref or id1_ref and outputs the selected one as the d-axis current command value id_ref. The selection is performed in the same manner as in the first d-axis current selection unit 606A.
The coordinate converter 8b performs coordinate conversion of the currents Iu2, Iv2, Iw2 flowing through the second three-phase windings and detected by the second current detector 5b, using the second corrected angle θ2_m outputted from the second angle correction unit 605B, to obtain the second d-axis current value id2 and the second q-axis current value iq2 which are currents on rotating two axes (d-q axes). The subtractor 9b subtracts the second d-axis current value id2 from the d-axis current command value id_ref, and outputs the deviation err_d2. The subtractor 10b subtracts the second q-axis current value iq2 from the second q-axis current command value iq2_ref, and outputs the deviation err_q2. The current controller 11b calculates the second d-axis voltage command value vd2 on rotating two axes (d-q axes) through proportional integral control so that err_d2 obtained from the subtractor 9b coincides with zero. The current controller 12b calculates the second voltage command value vq2 on rotating two axes (d-q axes) through proportional integral control so that err_q2 obtained from the subtractor 10b coincides with zero. The coordinate converter 13b performs coordinate conversion of the second d-axis voltage command value vd2 and the second q-axis voltage command value vq2 on rotating two axes (d-q axes), using the second corrected angle θ2_m, to obtain the second voltage commands Vu2_ref, Vv2_ref, Vw2_ref.
The reason for occurrence of torque ripple due to angle error caused by eccentricity of the resolver is the same as in embodiment 1. The reason why the torque ripple can be suppressed is also the same as in embodiment 1. In the configuration of embodiment 2, the first angle θ1, the second angle θ2, the first d-axis current command value candidate id1_ref, and the second d-axis current command value candidate id2_ref are communicated between the first controller 6a and the second controller 6b. Here, the error Δθ contained in each of the first angle θ1 and the second angle θ2 is an AC quantity. Therefore, for example, if communication delay occurs when the second angle θ2 is communicated to the first controller 6a, phase delay occurs in Δθ contained in the second angle θ2. Thus, even if the average of the first angle θ1 and the second angle θ2 sent from the second controller 6b by communication is calculated, the errors Δθ might not be canceled by each other, so that the angle error cannot be suppressed. The same applies to a case of communicating the first angle θ1 from the first controller 6a to the second controller 6b. Even in such a case, the first d-axis current command value candidate id1_ref, the second d-axis current command value candidate id2_ref, and the d-axis current command value id_ref are DC quantities and therefore are less influenced by communication delay. Thus, torque ripple due to angle error can be favorably suppressed.
Also in this case, as described in embodiment 1, angle correction is performed in the first angle correction unit 605A and the second angle correction unit 605B as shown in Expression (5) and Expression (6), whereby the influence of eccentricity of the resolver can be eliminated.
Also in this case, angle correction is performed in each of the first angle correction unit 605A and the second angle correction unit 605B, whereby the influence of eccentricity of the resolver can be eliminated.
Also in this case, data of the first d-axis current command value candidate id1_ref and the second d-axis current command value candidate id2_ref is communicated between the first controller 6a and the second controller 6b, and either id1_ref or id2_ref is selected in the first d-axis current selection unit 606A and the second d-axis current selection unit 606B, so as to be set as the d-axis current command value id_ref in both controllers, whereby the influence of eccentricity of the resolver can be eliminated.
The controller 6, the first controller 6a, and the second controller 6b in the above embodiments each include, specifically, a computer processor 101, such as a central processing unit (CPU), a storage device 102 for communicating data to/from the computer processor 101, an input/output interface 103 for inputting/outputting a signal between the computer processor 101 and the outside, and the like, as shown in
Although various exemplary embodiments and examples are described in the present application, various features, aspects, and functions described in one or more embodiments are not inherent in a particular embodiment, and can be applicable alone or in their various combinations to each embodiment. Accordingly, countless variations that are not illustrated are envisaged within the scope of the art disclosed herein. For example, the case where at least one component is modified, added or omitted, and the case where at least one component is extracted and combined with a component in another embodiment are included.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2020/019717 | 5/19/2020 | WO |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2021/234802 | 11/25/2021 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
11711045 | Omata | Jul 2023 | B2 |
20120194109 | Uryu | Aug 2012 | A1 |
20200363233 | Ikeda et al. | Nov 2020 | A1 |
20230170830 | Lee | Jun 2023 | A1 |
Number | Date | Country |
---|---|---|
2000-018968 | Jan 2000 | JP |
2011-169653 | Sep 2011 | JP |
2019123592 | Jun 2019 | WO |
2019150984 | Aug 2019 | WO |
Entry |
---|
International Search Report of PCT/JP2020/019717 dated Aug. 18, 2020 [PCT/ISA/210]. |
Extended European Search Report issued Jun. 9, 2023 in European Application No. 20936972.7. |
Number | Date | Country | |
---|---|---|---|
20230155528 A1 | May 2023 | US |