In the following, an ignition timing control apparatus for an internal combustion engine according to one embodiment of the present invention will be described with reference to the drawings. As illustrated in
As illustrated, the engine 3 is a V-type six-cylinder gasoline engine which comprises a first to a third cylinder #1, #2, #3 in a right bank, and a fourth to a sixth cylinder #4, #5, #6 in a left bank. An intake pipe 4 is connected to these first to sixth cylinders #1-#6 (a plurality of cylinders) through intake manifolds 4a, and a fuel injection valve 5 is attached at each branch of the intake manifold 4a to face an intake port, not shown, of each cylinder.
The fuel injection valve 5 is arranged at each branch so as to inject a fuel into each branch, and is electrically connected to ECU 2, such that ECU 2 controls a valve opening time and a valve opening timing of the fuel injection valve 5 in accordance with an operating condition of the engine 3. In other words, fuel injection control is executed.
Also, an ignition plug 6 and a cylinder inner pressure sensor 10 are attached to a cylinder head of the engine 3 for each cylinder (only one each of both is shown). This ignition plug 6 is also electrically connected to the ECU 2, such that the ECU 2 controls a discharge state to burn an air/fuel mixture within a combustion chamber at a timing in accordance with an ignition timing, later described. In other words, ignition timing control is executed. The foregoing fuel injection control and ignition timing control are executed in the six cylinders #1-#6 in the order of #1→#5→#3→#6→#2→#4.
On the other hand, the cylinder inner pressure sensor 10 is a piezo-electric type one integrated with the ignition plug 6, and distorts in association with a change in the pressure within each cylinder, i.e., the cylinder inner pressure to output a detection signal indicative of the cylinder inner pressure to the ECU 2. The ECU 2 calculates the cylinder inner pressure PCYLF#i and the like based on a voltage value VCPS#i of the detection signal (hereinafter called the “detected voltage”) of the cylinder inner pressure sensor 10. In this connection, #i (=#1-#6) in “detected voltage VCPS#i” and “cylinder inner pressure PCYLF#i” is a cylinder number value indicative of a cylinder number. In the following description, when labeled “PCYLF#1,” this indicates the cylinder inner pressure of the first cylinder #1, and when labeled “PCYLF#i,” this indicates the cylinder inner pressure of all the six cylinders #1-#6. This aspect applies to a variety of parameters later described, and #i in a variety of parameters is omitted as appropriate.
In this connection, the cylinder inner pressure sensor 10 corresponds to knock intensity parameter detecting means and cylinder inner pressure parameter detecting means, and the detected voltage VCPS corresponds to a cylinder inner pressure parameter in this embodiment.
Also, an intake pipe inner pressure sensor 11 and an intake air temperature sensor 12 are disposed at locations downstream of a throttle valve 7 of the intake pipe 4. The intake pipe inner pressure sensor 11, which comprises, for example, a semiconductor pressure sensor, detects a pressure PBA within the intake pipe 4 (hereinafter called the “intake pipe inner pressure”), and outputs a detection signal indicative of the pressure PBA to the ECU 2. This intake pipe inner pressure PBA is detected as an absolute pressure. The intake air temperature sensor 12 detects the temperature TA of air flowing through the intake pipe 4 (hereinafter called the “intake air temperature”), and outputs a detection signal indicative of the temperature TA to the ECU 2.
A crank angle sensor 13, a water temperature sensor 14, and accelerator opening sensor 15 are also connected to the ECU 2. The crank angle sensor 13 comprises a magnet rotor and an MRE pickup, and outputs a CRK signal and a TDC signal, both of which are pulse signals, in association with rotations of a crank shaft, not shown, to the ECU 2. The CRK signal is outputted one pulse every predetermined crank angle (for example, 1°), such that the ECU 2 calculates a rotational speed NE of the engine 3 (hereinafter called the “engine rotational speed”) based on the CRK signal. In this connection, the crank angle sensor 13 corresponds to engine rotational speed detecting means in this embodiment.
The TDC signal in turn is a signal which indicates that the piston 3b of each cylinder 3a is at a predetermined crank angle position slightly in front of a TDC position of the intake stroke. In the six-cylinder engine 3 of this embodiment, one pulse is outputted every 120° of the crank angle. The TDC signal for the first cylinder #1 has a pulse width which is slightly longer such that it can be distinguished from other TDC signals. The ECU 2 calculates a crank angle position CA based on the TDC signal and CRK signal for the first cylinder #1.
The water temperature sensor 14 detects an engine water temperature TW which is the temperature of cooling water which circulates within a cylinder block of the engine 3, and outputs a detection signal indicative of the engine water temperature TW to the ECU 2. Further, the accelerator opening sensor 15 detects an amount AP by which the driver treads on an accelerating pedal, not shown, of the vehicle (hereinafter called the “accelerator opening”), and outputs a detection signal indicative of the accelerator opening AP to the ECU 2.
The ECU 2, which is based on a microcomputer which comprises a CPU, a RAM, a ROM, an I/O interface (none of which is shown), and the like, determines the operating condition of the engine 3, and executes the ignition timing control and the like in accordance with the detection signals of a variety of the aforementioned sensors 10-15.
It should be noted that in this embodiment, the ECU 2 corresponds to ignition timing determining means, knock intensity parameter detecting means, correction degree parameter calculating means, first correcting means, engine rotational speed detecting means, knock intensity parameter calculating means, first parameter calculating means, second parameter calculating means, parameter calculating means, maximum pressure angle detecting means, target angle setting means, and second correcting means.
Next, the ignition timing control apparatus 1 of this embodiment will be generally described in configuration. As illustrated in
It should be noted that in this embodiment, the knock determination controller 20 corresponds to the knock intensity parameter detecting means, knock intensity parameter calculating means, first parameter calculating means, second parameter calculating means, parameter calculating means, and maximum pressure angle detecting means. Further, the ignition timing controller 40 corresponds to the ignition timing determining means, correction degree parameter calculating means, first correcting means, target angle setting means, and second correcting means.
The knock determination controller 20 executes knocking determination processing and the like on a cylinder-by-cylinder basis, and comprises, as shown in
It should be noted that in each equation described below, each discrete data followed by a symbol (n) indicates discrete data which is sampled or calculated at a predetermined control period ΔTn (period synchronized to the generation of the CRK signal, i.e., at a period of crank angle 1°), where the symbol n represents the turn of each discrete data sampling or calculation timing. For example, the symbol n indicates a value which is sampled or calculated at a current control timing, and a symbol n−1 indicates a value which has been sampled or calculated at the preceding control timing. This applies to the following discrete data. Also, in the following description, the symbol (n) and the like in each discrete data are omitted as appropriate.
First, the bandpass filtering unit 21 calculates an integrated value ANOISES#i for noise level calculation, and an integrated value AKNOCKS#i for knock level calculation on a cylinder-by-cylinder basis based on the detected voltage VCPS#i and the engine rotational speed NE, as will be later described.
Specifically, the integrated value ANOISES#i for noise level calculation is calculated as described below. First, in a noise bandpass filter section (hereinafter called the “noise BPF section”) of each cylinder, the detected voltage VCPS#i is sampled at the aforementioned control period ΔTn, and this sampled value VCPS#i(n) is subjected to a bandpass filtering expressed by the following equation (1) to calculate a filtered value VCPS_F#i of the detected voltage:
In the above Equation (1), b1-bm and a1-am′ are predetermined filter coefficients, and m and m′ are predetermined integers equal to or larger than the value of two. For a reason set forth below, a set of high rotation values b1H-bmH and a set of low rotation values b1L-bmL are prepared for these filter coefficients b1-bm which are switched to one of the two sets in accordance with the engine rotational speed NE. Also, the filter coefficients b1-bm and filtered values VCPS_F#i(n−1)−VCPS_F#i(n−m) have initial values which are all set to the value of zero.
Next, in a noise level calculation section (for example CA2-CA3 in
Here, crank angle positions at the start point and end point of the noise level calculation section (CA2, CA3 in
These first and second frequencies FRQ1, FRQ2 are set at a second-order and a third-order resonant frequency, respectively, of the detected voltage VCPS#i with respect to the engine rotational speed NE. This setting is made for the following reason. Specifically, since the cylinder inner pressure sensor 10 is adapted to detect the pressure within the cylinder, it is susceptible to the influence of vibration noise caused by the engine rotational speed NE, so that the detected voltage VCPS#i exhibits such characteristics that its amplitude presents a maximum value at the resonant frequency with the engine rotational speed NE. Accordingly, in this embodiment, the two frequencies FRQ1, FRQ2, which are pass frequencies of the bandpass filter, are set to the second-order and third-order resonant frequencies, respectively, of the detected voltage VCPS#i with respect to the engine rotational speed NE in order to ensure a highest possible S/N ratio of the filtered value VCPS_F#i of the detected voltage.
Referring to
On the other hand, the integrated value AKNOCKS#i for knock level calculation is calculated as described below. First, in a knock bandpass filter section (hereinafter called the “knock BPF section”) of each cylinder, the detected voltage VCPS#i is sampled at the aforementioned control period ΔTn, and the sampled value is subjected to the aforementioned bandpass filtering of Equation (1) to calculate the filtered value VCPS_F#i of the detected voltage.
Next, in a knock level calculation section (CA5-CA6 in
Here, crank angle positions (for example, CA5, CA6 in
The reason for which the start point of the knock BPF section is set in the foregoing manner, and the reason for which the start point of the noise BPF section is set in the foregoing manner will be described with reference to
First, in the example of the calculation result shown in
On the other hand, in the example of the calculation result according to this embodiment shown in
Also, as is apparent from a comparison of the aforementioned Equations (2), (3), the integrated value ANOISES#i for noise level calculation, and the integrated value AKNOCKS#i for knock level calculation are calculated by the same equation, with their calculation sections different from each other.
It should be noted that in this embodiment, the integrated value ANOISES for noise level calculation corresponds to a first parameter, the integrated value AKNOCKS for knock level calculation corresponds to a second parameter, the first frequency FRQ1 corresponds to a first frequency band, and the second frequency FRQ2 corresponds to a second frequency band.
Next, the aforementioned noise level calculation unit 22 calculates a noise level NLVLS_A#i on a cylinder-by-cylinder basis by applying predetermined first-order delay filtering to the integrated value ANOISES#i for noise level calculation. The aforementioned knock level calculation unit 23 in turn calculates a knock level KNLVLS_A#i on a cylinder-to-cylinder basis by applying predetermined upper limit processing to the integrated value AKNOCKS#i for knock level calculation.
Further, the aforementioned knock intensity calculation unit 24 calculates a knock intensity SNA_S#i on a cylinder-by-cylinder basis by the following Equation (4). This knock intensity SNA_S#i represents the intensity of knocking in a cylinder #i. It should be noted that in this embodiment, the knock intensity SNA_S corresponds to a knock intensity parameter.
On the other hand, the aforementioned knock determination value calculation unit 25 calculates a map value for a knock determination value by searching a map, not shown, in accordance with the engine rotational speed NE and intake pipe inner pressure PBA, and corrects the map value with a correction coefficient calculated in accordance with the engine water temperature TW to calculate the knock determination value SNA_REFL. It should be noted that in this embodiment, the knock determination value SNA_REFL corresponds to a first determination value.
Also, the aforementioned knock determination unit 26 sets a value for a knock determination flag F_KNOCKIG#i on a cylinder-by-cylinder basis based on the result of a comparison of the knock intensity SNA_S#i with the knock determination value SNA_REFL. Specifically, the knock determination flag F_KNOCKIG#i is set to “1” when SNA_S#i>SNA_REFL, and the knock determination flag F_KNOCKIG#i is set to “0” when SNA_S#i≦SNA_REFL.
Further, the cylinder inner pressure calculation unit 27 calculates a cylinder inner pressure PCYLF#i on a cylinder-by-cylinder basis by applying predetermined filtering, predetermined model fitting, and the like to the detected voltage VCPS#i of the cylinder inner pressure sensor 10.
Next, the maximum pressure angle calculation unit 28 calculates a maximum pressure angle θPMAX#i on a cylinder-by-cylinder basis with reference to a change in the cylinder inner pressure PCYLF#i in a maximum pressure angle calculation section. This maximum pressure angle calculation section is a section which has a start point at an air/fuel mixture light-off timing and an end point at a crank angle position CA retarded therefrom by a predetermined value.
In the foregoing manner, the knock determination controller 20 of this embodiment calculates the knock intensity SNA_S#i, knock determination flag F_KNOCKIG#i, and maximum pressure angle θPMAX#i on a cylinder-by-cylinder basis.
Next, the aforementioned ignition timing controller 40 will be described. As described below, this ignition timing controller 40 is adapted to calculate an ignition timing IGLOGCL#i on a cylinder-by-cylinder basis, and comprises a basic ignition timing calculation unit 41, a correction term calculation unit 42, a knock correction term calculation unit 43, an adder 44, a basic target angle calculation unit 45, an IMEP correction value calculation unit 46, an adder 47, a maximum pressure angle controller 48, and an ignition timing calculation unit 49, as shown in
It should be noted that in each equation described below, each discrete data followed by a symbol (k) indicates discrete data which is sampled or calculated at a predetermined control period ΔTk (period synchronized to the generation of the TDC signal, i.e., at a period of crank angle 120°), where the symbol k represents the turn of each discrete data sampling or calculation timing. Also, in the following description, the symbol (k) and the like in each discrete data are omitted as appropriate.
First, the basic ignition timing calculation unit 41 calculates a basic ignition timing IGMAP on a cylinder-by-cylinder basis. Specifically, a required torque PMCMD is calculated by searching a map, not shown, in accordance with the engine rotational speed NE and accelerator opening AP, and the basic ignition timing IGMAP is calculated by searching a map, not shown, in accordance with the required torque PMCMD and engine rotational speed NE.
The correction term calculation unit 42 in turn calculates a correction term IGCRT#i on a cylinder-by-cylinder basis by searching a variety of maps, not shown, in accordance with a variety of parameters such as the intake air temperature TA, engine water temperature TW and the like.
Further, the knock correction term calculation unit 43 calculates a knock correction term IGCRK#i on a cylinder-by-cylinder basis in accordance with the knock determination flag F_KNOCKIG#i, knock intensity SNA_S#i, engine rotational speed NE, and intake pipe inner pressure PBA, as will be later described.
Then, the adder 44 calculates a corrected ignition timing IGLOG#i by the following Equation (5):
IGLOG#i(k)=IGMAP(k)+IGCRT#i(k)+IGCRK#i(k) (5)
On the other hand, the aforementioned basic target angle calculation unit 45 calculates a basic target angle θPMAX_CMD_MAP by searching a map shown in
Also, the IMEP correction value calculation unit 46 calculates an IMEP correction value DθPMAX#i in accordance with the maximum pressure angle θPMAX#i and the like. Next, the adder 47 calculates a target angle θPMAX_CMD#i by the following Equation (6):
θPMAX—CMD#i(k)=θPMAX—CMD—MAP(k)+DθPMAX#i(k)+IGCRK#i(k) (6)
Further, the aforementioned maximum pressure angle controller 48 calculates a maximum pressure angle correction term IGSLD#i on a cylinder-by-cylinder basis as described below. First, a control input USLIG#i is calculated in accordance with a sliding mode control algorithm expressed by the following Equations (7)-(12):
As shown in the above Equation (7), the control input USLIG#i is calculated as a sum total of an equivalent control input Ueq#i, a reaching law input Urch#i, an adaptive law input Uadp#i, and a non-linear input Unl#i.
The equivalent control input Ueq#i is calculated by Equation (8). In Equation (8), A1, A2, B1, C1 represent model parameters of a model, later described, and are set at predetermined values. Alternatively, these model parameters A1, A2, B1, C1 may be identified by an on-board identifier, or these model parameters A1, A2, B1, C1 may be calculated by searching a model parameter scheduler (map) in accordance with an operating condition. Also, in Equation (8), POLE is a switching function setting parameter and is set at a value which satisfies the relationship of −1<POLE<0.
The reaching law input Urch#i in turn is calculated by Equation (9). In this Equation (9), Krch represents a predetermined reaching law gain, and σ#i represents a switching function defined as in Equation (11). E#i in Equation (11) represents a following error defined by Equation (12). Further, the adaptive law input Uadp#i is calculated by Equation (10), and in this Equation (10), Kadp represents a predetermined adaptive law gain.
On the other hand, the non-linear input Unl#i is calculated by searching a map shown in
In this connection, the above Equations (7)-(12) are derived in the following manner. Specifically, when a system which has the control input USLIG#i as a control input and the maximum pressure angle θPMAX#i as a controlled variable is modeled as a discrete time system model, the following Equation (13) is derived. By applying a sliding mode control theory to this model, the aforementioned Equations (7)-(12) are derived.
θPMAX#i(k+1)=A1·θPMAX#i(k)+A2·θPMAX#i(k−1)+B1·USLIG#i(k)+C1 (13)
Next, a predetermined limit processing is applied to the control input USLIG#i to calculate the maximum pressure angle correction term IGSLD#i. In the foregoing manner, the maximum pressure angle controller 48 calculates the maximum pressure angle correction term IGSLD#i as a value for converging the maximum pressure angle θPMAX#i to the target angle θPMAX_CMD#i.
Further, the aforementioned ignition timing calculation unit 49 calculates the sum of the corrected ignition timing IGLOG#i and maximum pressure angle correction term IGSLD#i calculated in the foregoing manner, and applies predetermined limit processing to the sum to calculate the ignition timing IGLOGCL#i. More specifically, the ignition timing IGLOGCL#i is limited to fall under a value within a range defined by a predetermined upper and lower limit value IGLOG_H, IGLOG_L. In the foregoing manner, since the ignition timing IGLOGCL#i is calculated as a limited value of the sum of the corrected ignition timing IGLOG#i and maximum pressure angle correction term IGSLD#i, the corrected ignition timing IGLOG#i is calculated as a value corrected by the maximum pressure angle correction term IGSLD#i such that the maximum pressure angle θPMAX#i converges to the target angle θPMAX_CMD#i.
Next, the aforementioned knock correction term calculation unit 43 will be described. This knock correction term calculation unit 43 calculates the knock correction term IGCRK#i on a cylinder-by-cylinder basis by an approach described below. In this connection, since the same calculation approach is employed for the knock correction term IGCRK#i in each cylinder, the fourth cylinder #4 is given as an example in the following description.
First, when the knock determination flag F_KNOCKIG#4=0, a correction coefficient learning value KIGKN#4 is calculated by the following Equations (14), (15), and a knock correction term IGCRK#4 is calculated by the following Equations (16), (17). It should be understood that in this embodiment, the correction coefficient learning value KIGKN corresponds to a correction degree parameter.
KIGKM#4(k)=KIGKM#4(k−1)−DKIGKM (14)
KIGKN#4(k)=R·KIGKN#4(k−1)+(1−R)·KIGKM#4(k) (15)
IGKNOCK#4(k)=DIGKR(k)−KIGKN#4(k) (16)
IGCRK#4(k)=DIGRSV(k)−IGKNOCK#4(k) (17)
Here, KIGKM#4 in Equation (14) is a correction coefficient, and DKIGKM is a predetermined value (for example, the value of 0.1). Also, R in Equation (15) is a predetermined coefficient which is set to satisfy 0<R<1. On the other hand, IGKNOCK#4 in Equation (16) is a knock retard term, and DIGKR in Equation (16) is a retard value which is calculated by searching a map, not shown, in accordance with the engine rotational speed NE and intake pipe inner pressure PBA. Further, DIGRSV in Equation (17) is a knock margin which represents a maximum value of an angle by which the ignition timing can be advanced without causing knocking in an associated cylinder. This knock margin DIGRSV is calculated by searching a map, not shown, in accordance with the engine rotational speed NE and intake pipe inner pressure PBA.
As shown in the aforementioned Equations (14), (15), when F_KNOCKIG#4=0, the correction coefficient KIGKM#4 is calculated such that is decremented by a predetermined value DKIGKM, while the correction coefficient learning value KIGKN#4 is calculated as a value which is derived by applying first-order delay processing to such a correction coefficient KIGKM#4. In this event, lower limit processing is applied to the calculated value of the correction coefficient learning value KIGKN#4 for limiting the same to a lower limit value which is the value of zero. As a result, the correction coefficient learning value KIGKN#4 is calculated to gradually decrease toward the value of zero. Also, as shown in the aforementioned Equations (16), (17), the knock retard term IGKNOCK#4 is calculated as a product of the correction coefficient learning value KIGKN#4 and retard value DIGKR. As the knock correction term IGCRK#4 is calculated by subtracting the product from the knock margin DIGRSV, the correction coefficient learning value KIGKN#4 gradually decreases toward the value of zero, causing the knock correction term IGCRK#4 to gradually increase toward the knock margin DIGRSV. In other words, the knock correction term IGCRK#4 gradually changes on the advance side.
On the other hand, with F_KNOCKIG#4=1, when the following condition (h1) is satisfied, or when two conditions (h2), (h3) are both satisfied, or when three conditions (h4)-(h6) are all satisfied, correction coefficient learning values KIGKN#i are calculated for the six cylinders by the following Equations (18), (19). In other words, the correction coefficient learning values KIGKN#i for the six cylinders are updated. In this event, upper limit processing is applied to these calculated values to limit them to an upper limit value which is the value of one. Here, SNA_REFH is a predetermined strong knock determination value which is calculated by adding a positive predetermined value to the knock determination value SNA_REFL. It should be noted that in this embodiment, the strong knock determination value SNA_REFH corresponds to a second determination value.
(h1) SNA_S#4≧SNA_REFH
(h2) SNA_S#4<SNA_REFH
(h3) F_KNOCKIG#i=1 in the cylinders except for the fourth cylinder #4 during one pertinent combustion cycle.
(h4) SNA_S#4<SNA_REFH
(h5) F_KNOCKIG#i?1 in the cylinders except for the fourth cylinder #4 during the one pertinent combustion cycle.
(h6) The value of F_KNOCKIG#4 has changed from “0” to “1” before a predetermined time is elapsed from a time point at which the correction coefficient learning values KIGKN#i were calculated for the six cylinders.
KIGKM#i(k)=KIGKM#i(k−1)+DKIGKM (18)
KIGKN#i(k)=R·KIGKN#i(k−1)+(1−R)·KIGKM#i(k) (19)
Here, KIGKM#i is a correction coefficient, and as shown in this Equation (19), the correction coefficient learning value KIGKN#i is calculated as a value which is derived by applying first-order delay processing to the correction coefficient KIGKM#i.
Further, with F_KNOCKIG#4=1, when both of the following conditions (h7), (h8) are satisfied, only the correction coefficient learning value KIGKN#4 is calculated by equations in which i=4 is substituted into the aforementioned Equations (18), (19).
(h7) F_KNOCKIG#i=0 in the cylinders except for the fourth cylinder #4 during the one pertinent combustion cycle.
(h8) The value of F_KNOCKIG#4 changes from “0” to “1” after a predetermined time has been elapsed from a time point at which the correction coefficient learning values KIGKN#i were calculated for the six cylinders.
Next, the knock retard term IGKNOCK#4 is calculated by the following Equation (20) which is the same as the aforementioned Equation (16):
IGKNOCK#4(k)=DIGKR(k)·KIGKN#4(k) (20)
Subsequently, the knock correction term IGCRK#4 is calculated by the following Equation (21) which is the same as the aforementioned Equation (17).
IGCRK#4(k)=DIGRSV(k)−IGKNOCK#4(k) (21)
As shown in this Equation (21), the knock correction term IGCRK#4 is calculated by subtracting the knock retard term IGKNOCK#4 from the knock margin DIGRSV, so that when DIGRSV<IGKNOCK#4, the knock correction term IGCRK#4 takes a negative value. As shown in the aforementioned Equation (5), this knock correction term IGCRK#4 is added to the basic ignition timing IGMAP upon calculation of the corrected ignition timing IGLOG#4, so that when the knock correction term IGCRK#4 is negative, the corrected ignition timing IGLOG#4 is corrected toward the retarding side by the knock correction term IGCRK#4.
Next, control processing executed by the ECU 2 at the control period ΔTn mentioned above will be described with reference to
Next, at step 3, cylinder inner pressures PCYLF#i are calculated for the six cylinders #i, respectively, by the same approach as the aforementioned cylinder inner pressure calculation unit 27.
At step 4 next to step 3, the maximum pressure angles θPMAX#i are calculated for the six cylinders #i by the same approach as the aforementioned maximum pressure angle calculation unit 28. Subsequently, this processing is terminated.
Next, the knock determination processing for the six cylinders #i at the aforementioned step 2 will be described with reference to
When the result of the determination at step 10 is YES, it is determined that the knock determination should be executed for the fourth cylinder #4, followed by a transition to step 11, where a knock determination done flag F_DONE#4 is set to “0” to indicate the determination. On the other hand, when the result of the determination at step 10 is NO, the processing goes to step 12.
At step 12 next to step 10 or 11, it is determined whether or not the knock determination done flag F_DONE#4 is “1.” When the result of this determination is YES, i.e., when the knock determination has been terminated for the fourth cylinder #4, this processing is terminated without further actions. On the other hand, when the result of this determination is NO, the processing goes to step 13, where the knock intensity SNA_S#4 of the fourth cylinder #4 is calculated.
Specifically, the calculation of the knock intensity SNA_S#4 is executed as shown in
Next, the processing goes to step 31, where it is determined whether or not a calculation done flag F_SNA_S#4 is “1.” When the result of this determination is YES, i.e., when the knock intensity SNA_S#4 has been calculated, this processing is terminated without further actions.
On the other hand, when the result of the determination at step 31 is NO, i.e., when the knock intensity SNA_S#4 has not been calculated, the processing goes to step 32, where it is determined whether or not the crank angle position CA lies in the aforementioned noise BPF section. When the result of this determination is YES, the processing goes to step 33, where the filtered value VCPS_F#4 of the detected voltage is calculated.
Specifically, this processing of calculating the filtered value VCPS_F#4 of the detected voltage is executed as shown in
On the other hand, when the result of the determination at step 50 is YES, i.e., when the engine rotational speed NE is in the high rotation range, the filter coefficients b1-bm are set to the values b1H-bmH for high rotations, respectively, at step 52.
At step 53 next to step 51 or 52, the filtered value VCPS_F#4 of the detected voltage is calculated by the aforementioned Equation (1). Subsequently, this processing is terminated.
Turning back to
At step 36 next to step 35, it is determined whether or not the crank angle position CA lies at the end point of the noise level calculation section. When the result of this determination is NO, this processing is terminated without further actions. On the other hand, when the result of this determination is YES, the processing goes to step 37, where the predetermined first-order delay filtering is applied to the integrated value ANOISES#4 for noise level calculation to calculate a noise level NLVLS_A#4. Subsequently, this processing is terminated.
On the other hand, when the result of the determination at step 32 is NO, i.e., when the crank angle position CA does not lie in the noise BPF section, the processing goes to step 38, where it is determined whether or not the crank angle position CA lies in the aforementioned knock BPF section. When the result of this determination is NO, this processing is terminated without further actions. On the other hand, when the result of this determination is YES, the processing goes to step 39, where the filtered value VCPS_F#4 of the detected voltage is calculated by the same approach as that used at the aforementioned step 33.
Next, the processing goes to step 40, where it is determined whether or not the crank angle position CA lies in the knock level calculation section. When the result of this determination is NO, this processing is terminated without further actions. On the other hand, when the result of this determination is YES, the processing goes to step 41, where the integrated value AKNOCKS#4 for knock level calculation is calculated by the aforementioned Equation (3).
At step 42 next to step 41, it is determined whether or not the crank angle position CA lies at the end point of the knock level calculation section. When the result of this determination is NO, this processing is terminated without further actions. On the other hand, when the result of this determination is YES, the processing goes to step 43, where the predetermined upper limit processing is applied to the integrated value AKNOCKS#4 for knock level calculation to calculate the knock level KNLVLS_A#4, as previously described.
At step 44 next to step 43, the knock intensity SNA_S#4 is calculated by the aforementioned Equation (4), and for indicating this, the processing goes to step 45, where the calculation done flag F_SNA_S#4 is set to “1.” Subsequently, this processing is terminated.
Turning back to
Next, the processing goes to step 15, where it is determined whether or not the knock intensity SNA_S#4 is larger than the knock determination value SNA_REFL. When the result of this determination is YES, it is determined that knocking equal to or larger than a predetermined intensity is occurring in the fourth cylinder #4, and the knock determination flag F_KNOCKIG#4 is set to “1” at step 16 in order to indicate that the knocking is occurring.
On the other hand, when the result of the determination at step 15 is NO, it is determined that knocking is not occurring in the fourth cylinder #4, and the knock determination flag F_KNOCKIG#4 is set to “0” at step 17 in order indicate that no knocking is occurring.
At step 18 subsequent to step 16 or 17, the knock determination done flag F_DONE#4 is set to “1” in order to indicate that the knock determination has been completed for the fourth cylinder #4, followed by termination of this processing.
Next, the ignition timing control processing executed by the ECU 2 at the aforementioned control period ΔTk will be described with reference to
Next, it is determined at step 61 whether or not the counter value CT is larger than six. When the result of this determination is NO, the processing goes to step 63, later described. On the other hand, when the result of this determination is YES, the processing goes to step 62, where the counter value CT is reset to the value of zero, followed by the processing going to step 63.
At step 63 next to step 61 or 62, it is determined whether or not the counter value CT is equal to the value of one. When the result of this determination is YES, the processing goes to step 64, where the ignition timing control processing is executed for the first cylinder #1, followed by termination of this processing.
On the other hand, when the result of the determination at step 63 is NO, the processing goes to step 65, where it is determined whether or not the counter value CT is equal to the value of two. When the result of this determination is YES, the processing goes to step 66, where the ignition timing control processing is executed for the fifth cylinder #5, followed by termination of this processing.
On the other hand, when the result of the determination at step 65 is NO, the processing goes to step 67, where it is determined whether or not the counter value CT is equal to the value of three. When the result of this determination is YES, the processing goes to step 68, where the ignition timing control processing is executed for the third cylinder #3, followed by termination of this processing.
On the other hand, when the result of the determination at step 67 is NO, the processing goes to step 69, where it is determined whether or not the counter value CT is equal to the value of four. When the result of this determination is YES, the processing goes to step 70, where the ignition timing control processing is executed for the sixth cylinder #6, followed by termination of this processing.
On the other hand, when the result of the determination at step 69 is NO, the processing goes to step 71, where it is determined whether or not the counter value CT is equal to the value of five. When the result of this determination is YES, the processing goes to step 72, where the ignition timing control processing is executed for the second cylinder #2, followed by termination of this processing. On the other hand, when the result of the determination at step 71 is NO, the processing goes to step 73, where the ignition timing control processing is executed for the fourth cylinder #4, followed by termination of this processing.
In the foregoing manner, the ignition timing control processing for the six cylinders #1-#6 is executed in the order of #1→#5→#3→#6→#2→#4. Since the same approach is employed in the ignition timing control processing for any cylinder, the ignition timing control for the fourth cylinder #4 at step 73 will be described below with reference to
As shown in
Next, at step 81, after calculating a required torque PMCMD at step 81 by the same approach as the aforementioned basic ignition timing calculation unit 41, the basic ignition timing IGMAP is calculated at step 82 by the same approach as the basic ignition timing calculation unit 41.
At step 83 next to step 82, the correction term IGCRT#i is calculated by the same approach as the aforementioned correction term calculation unit 42. Next, the processing goes to step 84, where the knock correction term IGCRK#4 is calculated by an approach shown in
As illustrated in
When the result of the determination at step 101 is YES, it is determined that strong knocking is occurring in the fourth cylinder #4, followed by a transition to step 103, where the correction coefficient learning values KIGKN#i for the six cylinders are updated. Specifically, this update processing is performed as shown in
First, at step 120, the sum of the preceding value KIGKM#iZ of the correction coefficient and a predetermined addition term DKIGKM is set as the correction coefficient KIGKM#i. In other words, the correction coefficients KIGKM#i for the six cylinders are calculated.
Next, the flow goes to step 121, where the product of a value (1−R) and correction coefficient KIGKM#i is added to the product of a predetermined coefficient R and the preceding value KIGKN#iZ of the correction coefficient learning value, and the resulting sum is set as the correction coefficient learning value KIGKN#i. In other words, the correction coefficient learning values KIGKN#i for the six cylinders are updated.
Next, at step 122, the aforementioned upper limit processing is applied to the learning values KIGKN#i for the six cylinders calculated at step 121 to calculate the correction coefficient learning values KIGKN#i. Subsequently, this processing is terminated.
Turning back to
Next, the processing goes to step 105, where the knock retard term IGKNOCK#4 is set to the product DIGKR·KIGKN#4 of the retard value and correction coefficient learning value. Next, at step 106, the knock correction term IGCRK#4 is set to a deviation DIGRSV-IGKNOCK#4 of the knock margin from the knock retard term, followed by termination of this processing.
On the other hand, when the result of the determination at step 101 is NO, i.e., when weak knocking is occurring in the fourth cylinder #4, the flow goes to step 102, where it is determined whether or not the knock determination flag F_KNOCKIG#1=1 is established in any cylinder other than the fourth cylinder in this combustion cycle.
When the result of this determination is YES, steps 103-106 are executed as described above, followed by termination of this processing, on the assumption that poor properties of the fuel makes each cylinder more susceptible to knocking.
On the other hand, when the result of the determination at step 102 is NO, it is determined whether or not the aforementioned update flag F_KOUSIN is “1.” When the result of this determination is YES, steps 103-106 are executed as described above, followed by termination of this processing, on the assumption that poor properties of the fuel makes each cylinder more susceptible to knocking.
On the other hand, when the result of the determination at step 107 is NO, i.e., when F_KOUSIN=0, the processing goes to step 108, where the correction coefficient learning value KIGKN#4 for the fourth cylinder #4 is updated. This processing is executed at the aforementioned steps 120-122 in
On the other hand, when the result of the determination at the aforementioned step 100 is NO, i.e., when knocking is not occurring in the fourth cylinder #4, the processing goes to step 109, where the counter value CT2 is set to the sum of its preceding value CT2Z and the value of one. In other words, the counter value CT2 is incremented by one.
Next, it is determined at step 110 whether or not the counter value CT2 is larger than a predetermined value CT2REF. When the result of this determination is YES, i.e., when knocking is not occurring in the fourth cylinder while a time corresponding to the predetermined value CT2REF is elapsed, the update flag F_KOUSIN is reset to “0” at step 111, followed by a transition to step 112, later described.
On the other hand, when the result of the determination at step 110 is NO, the processing goes to step 112. At step 112 next to step 110 or 111, the correction coefficient learning value KIGKN#4 is gradually reduced. Specifically, the correction coefficient learning value KIGKN#4 is calculated by the aforementioned Equations (14), (15), and lower limit processing is applied to the calculated value to limit the same to a lower limit value which is the value of zero. As a result, the correction coefficient learning value KIGKN#4 is calculated to gradually decrease toward the value of zero, as previously described.
Next, the processing goes to step 113, where the knock correction term IGCRK#4 is gradually increased. Specifically, the knock correction term IGCRK#4 is calculated by the aforementioned Equations (16), (17). As a result, the knock correction term IGCRK#4 is calculated to gradually increase toward the knock margin DIGRSV, as previously described. After executing step 113 in the foregoing manner, this processing is terminated.
Turning back to
Next, a maximum pressure angle correction term IGSLD#4 is calculated at step 86. Specifically, this processing is executed as shown in
First, at step 130, a basic target angle θPMAX_CMD_MAP is calculated by searching the map shown in
Next, at step 132, a target angle θPMAX_CMD#4 is set to the sum of the basic target angle θPMAX_CMD_MAP, IMEP correction value DθPMAX#4, and knock correction term IGCRK#4.
At step 133 next to step 132, a control input USLIG#4 is calculated in accordance with the sliding mode control algorithm of the aforementioned Equations (7)-(11). Next, the processing goes to step 134, where predetermined limit processing is applied to the control input USLIG#4 to calculate a maximum pressure angle correction term IGSLD#4, followed by termination of this processing.
Turning back to
Specifically, it is determined at step 88 whether or not the ignition timing IGLOGCL#4 calculated at step 87 is smaller than a predetermined lower limit threshold value IGLOG_L. When the result of this determination is YES, i.e., when the ignition timing IGLOGCL#4 presents a value retarded from the lower limit threshold value IGLOG_L, the ignition timing IGLOGCL#4 is set to the lower limit threshold value IGLOG_L at step 89, followed by termination of this processing.
On the other hand, when the result of the determination at step 88 is NO, the processing goes to step 90, where it is determined whether or not the ignition timing IGLOGCL#4 is larger than a predetermined upper limit threshold value IGLOG_H. When the result of this determination is YES, i.e., when the ignition timing IGLOGCL#4 presents a value advanced from the upper limit threshold value IGLOG_H, the ignition timing IGLOGCL#4 is set to the upper limit threshold value IGLOG_H, followed by termination of this processing.
On the other hand, when the result of the determination at step 90 is NO, i.e., when IGLOG_L≦IGLOGCL#4≦IGLOG_H, this processing is terminated without further actions. In other words, the value calculated at step 87 is used as the ignition timing IGLOGCL#4.
Next, a description will be given of exemplary operations when knocking occurs in the fourth cylinder #4 during the execution of the ignition timing control processing as described above. As shown in
Further, since knocking is not occurring in the cylinders other than the fourth cylinder #4 during a period between times t1 and t2, which corresponds to one combustion cycle, the result of the determination at step 102 is NO. Since knocking has not occurred in all the cylinders #1-#6 for a long period, F_KOUSIN=0 is established, causing the result of the determination at step 107 to be NO. As a result, the correction coefficient learning value KIGKN#4 for the fourth cylinder #4 alone is updated at step 108. Then, at time t3 after one combustion cycle, knocking does not occur in the fourth cylinder #4, causing the knock determination flag F_KNOCKIG#4 to be reset to “0.”
On the other hand, when relatively weak knocking occurs at time t5 in the fourth cylinder #4, the knock determination flag F_KNOCKIG#4 is set to “1.” Also, since knocking occurs in the third cylinder #3 during a period between times t4 and t5 which corresponds to one combustion cycle, the result of the determination at step 102 is YES. As a result, the correction coefficient learning values KIGKN#i for the six cylinders are updated at step 103, and the update flag F_KOUSIN is set to “1.”
Then, at time t4 after one combustion cycle, knocking does not occur in the fourth cylinder #4, causing the knock determination flag F_KNOCKIG#4 to be reset to “0.” Further, when knocking does not continuously occur in the fourth cylinder #4 for more than a period corresponding to a predetermined value CTREF2 after time t3 (time t7), the update flag F_KOUSIN is reset to “0.”
On the other hand, when strong knocking occurs in the fourth cylinder #4 at time t11 during the ignition timing control as shown in
Then, at time t12 after one combustion cycle, knocking does not occur in the fourth cylinder #4, causing the knock determination flag F_KNOCKIG#4 to be reset to “0.” Further, when knocking does not continuously occur in the fourth cylinder #4 for a period corresponding to the predetermined value CTREF2 after time t12 (time t13), the update flag F_KOUSIN is reset to “0.”
Further, when strong knocking occurs in the fourth cylinder #4 at time t14, the knock determination flag F_KNOCKIG#4 is set to “1” and the correction coefficient learning values KIGKN#i for the six cylinders are updated, causing the update flag F_KOUSIN to be set to “1,” as previously described. Then, since knocking does not occur in the fourth cylinder #4 at time t15 after one combustion cycle, the knock determination flag F_KNOCKIG#4 is rest to “0.”
In the foregoing manner, according to the ignition timing control apparatus 1 for an internal combustion engine of this embodiment, when relatively weak knocking occurs in one of the six cylinders #1-#6, for example, in the fourth cylinder #4 to establish SNA_REFL<SNA_S#4<SNA_REFH, the correction coefficient learning value KIGKN#4 for the fourth cylinder #4 alone is updated. On the other hand, when strong knocking occurs in the fourth cylinder #4 to establish SNA_REFH≦SNA_S#4, the correction coefficient learning values KIGKN for the six cylinders are updated. In this way, the knock retard term IGKNOCK is set to a larger value in all the cylinders to increase the degree of a correction toward the retarding side by the knock correction term IGCRK, so that the ignition timings IGLOGCL for all the cylinders are corrected more to the retarding side. Therefore, the ignition timings IGLOGCL for all the cylinders can be collectively corrected toward the retarding side, for example, when a fuel exhibits poor properties and a low octane number, thus making it possible to more rapidly and effectively restrain knocking from occurring as the overall engine 3. As a result, the lifetime of the engine 3 can be extended.
Also, the cylinder inner pressure PCYLF is calculated based on the voltage VCPS of the detected signal of the cylinder inner pressure sensor 10, and the absolute value |VCPS_F| of a value derived by applying predetermined bandpass filtering to the cylinder inner pressure PCYLF is integrated in the noise level calculation section and knock level calculation section, thereby calculating the integrated value ANOISES for noise level calculation and the integrated value AKNOCKS for knock level calculation. Also, the knock intensity SNA_S for use in knock determination is calculated based on these values ANOISES, AKNOCKS. In this bandpass filtering, the pass frequency FRQ is set to the predetermined first frequency FRQ1 when NE<NE1, and set to the predetermined second frequency FRQ2 (>FRQ1) when NE≧NE1, so that data indicative only of the knocking intensity can be effectively extracted from the detected voltage VCPS to improve the S/N ratio of the filtered value VCPS_F of the detected voltage, as shown in the experiment result in
In addition, in the bandpass filtering, the calculations of the two integrated values ANOISES, AKNOCKS are started at a time point at which initial noise in the filtered value VCPS_F has converged immediately after the start of the calculation in both the noise BPF section and knock BPF section, thus making it possible to improve the calculation accuracy for these integrated values ANOISES, AKNOCKS. In the foregoing manner, the knock intensity SNA_S can be calculated with a higher accuracy, and as a result, knocking can be more effectively restrained.
Also, the maximum pressure angle correction term IGSLD is calculated by the sliding mode control algorithm such that the maximum pressure angle θPMAX reaches the target angle θPMAX_CMD, and the ignition timing IGLOGCL is calculated as the sum of the maximum pressure angle correction term IGSLD and corrected ignition timing IGLOG. In the calculation of the target angle θPMAX_CMD, since the knock correction term IGCRK is used as an addition term, the target angle θPMAX_CMD is calculated as a more retarded value when SNA_REFL<SNA_S as compared with when SNA_S≦SNA_REFL, thereby causing the maximum pressure angle correction term IGSLD to be calculated as a more retarded value as well.
On the other hand, in the calculation of the corrected ignition timing IGLOG, since the knock correction term IGCRK is used as an addition term as well, the ignition timing IGLOGCL is calculated as a value retarded from the corrected ignition timing IGLOG when SNA_REFL<SNA_S as compared with when SNA_S≦SNA_REFL is established. In the foregoing manner, since the direction in which the ignition timing IGLOGCL is corrected by the knock correction term IGCRK can be matched with the direction in which the ignition timing IGLOGCL is corrected by the maximum pressure angle correction term IGSLD, a knocking restraining effect can be ensured while avoiding the correction of the ignition timing IGLOGCL by the knock correction term IGCRK from interfering with the feedback control of the maximum pressure angel θPMAX to the target angle θPMAX_CMD by the maximum pressure angle correction term IGSLD.
While the foregoing embodiment has shown an example in which the knock intensity SNA_S is calculated as a knock intensity parameter, the knock intensity parameter of the present invention is not so limited, and any value may be used as long as it indicates the intensity of knocking.
Also, while the foregoing embodiment has shown an example in which the correction coefficient learning value KIGKN is calculated as a correction degree parameter, the correction degree parameter of the present invention is not so limited, but any value may be used as long as it indicates a degree to which the ignition timing should be corrected toward the retarding side. For example, the correction coefficient KIGKM may be calculated as a correction degree parameter, and the knock correction term IGCRK may be calculated in accordance with the calculated correction coefficient KIGKM. Also, the knock correction term IGCRK may be calculated as a correction degree parameter.
Further, while the foregoing embodiment has shown an example in which the cylinder inner pressure sensor 10 and ECU 2 are used as cylinder inner pressure parameter detecting means, the cylinder inner pressure detecting means of the present invention is not so limited, but any device may be used as long as it detects a cylinder inner pressure parameter indicative of the cylinder inner pressure.
Also, while the foregoing embodiment has shown an example in which the detected voltage VCPS is used as a cylinder inner pressure parameter, the cylinder inner pressure parameter of the present invention is not so limited, but any value may be used as long as it indicates the cylinder inner pressure.
Further, while the foregoing embodiment has shown an example in which the sliding mode control algorithm of Equations (7)-(12) is used as a predetermined feedback control algorithm, the predetermined feedback control algorithm of the present invention is not so limited, but any algorithm may be used as long as it can calculate the maximum pressure angle correction term IGSLD for correcting the ignition timing IGLOGCL such that the maximum pressure angle θPMAX reaches the target angle θPMAX_CMD. For example, a PID control algorithm or the like may be used as the predetermined feedback control algorithm to calculate the maximum pressure angle correction term IGSLD.
Also, while the foregoing embodiment has shown an example in which the integrated value ANOISES for noise level calculation and the integrated value AKNOCKS for knock level calculation are used as the first and second parameters, the first and second parameters are not so limited, but any values may be used as long as the knock intensity parameter can be calculated in accordance with these two parameters.
Number | Date | Country | Kind |
---|---|---|---|
2006-154798 | Jun 2006 | JP | national |