The present invention relates to an engine torque estimating apparatus, an engine torque estimating method, and an engine control apparatus.
A control apparatus of a gasoline engine or a diesel engine for an automobile performs torque-based control in which the engine is controlled based on torque. In torque-based control, a needed torque is set based on an accelerator operation by a driver, cruise control, or the like, an indicated torque that satisfies the needed torque is calculated, and an injection amount of an injector is controlled so as to enable the indicated torque to be reproduced. Such engine control is referred to as feed-forward control.
In feed-forward control, injection amounts of injectors of a plurality of cylinders of a multi-cylinder engine are controlled in a same manner. However, individual variability among the respective injectors of the plurality of cylinders creates variability among the indicated torques of the plurality of cylinders and causes deterioration in emission performance and fuel economy performance.
On the other hand, feedback control is proposed in which an indicated torque of each cylinder of an engine is estimated based on a sensor value (an observed value or an output value) of a crank angle sensor and an injection amount of an injector of each cylinder is separately controlled so that an estimated indicated torque of each cylinder matches a needed torque.
Patent Literature 1: Japanese Patent Application Laid-open No. 2010-127219
Patent Literature 2: Japanese Patent Application Laid-open No. 2017-82662
Non-Patent Literature 1: Fundamentals of Kalman Filter, Shuichi Adachi, Ichiro Maruta, Tokyo Denki University Press, ISBN 978-4-501-32891-0 C3055
However, due to a limit of measurement resolution in crank angle extraction of a crank angle sensor, a limit of a sampling period of voltage output of the crank angle sensor, a disturbance such as vibration inside the engine in a high-rotation region, and the like, a sensor value of the crank angle sensor contains a different noise in a combustion cycle of each cylinder. Therefore, it is difficult to accurately estimate an indicated torque of each cylinder based on a sensor value of a crank angle sensor. Due to such reasons, feedback control based on an estimated indicated torque of each cylinder is prevented from being performed in a suitable manner.
According to an embodiment, an engine torque estimating apparatus includes a processor; and a memory accessed by the processor, the processor performs a torque estimating that calculates time series data of an estimated indicated torque, based on a crank angle having been extracted from an output of a crank angle sensor of an engine including a plurality of cylinders; an estimated indicated torque-related value extracting that extracts an estimated indicated torque-related value, for each of the cylinders, from the time series data of the estimated indicated torque, for each of the cylinders; and average indicated torque correct value acquiring that converts, for each of the cylinders, the estimated indicated torque-related value into an average indicated torque correct value having been calculated based on a cylinder internal state of the engine in correspondence to the estimated indicated torque-related value.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention.
The crank angle sensor CA is, for instance, a sensor that detects a reference position and a rotation angle of a crank shaft. A sensor value detected by the crank angle sensor becomes a base signal for fuel injection control and ignition timing control in an electronic fuel injection system. For instance, with an electromagnetic crank angle sensor, a magnetic flux received by the crank angle sensor changes in accordance with a rotation of a rotor with projections (teeth) that is attached to the crank shaft. A change in the magnetic flux is converted into and output as a pulse signal of a rectangular wave. The rotor is provided with a plurality of projections so as to correspond to a crank angle pitch and includes a missing tooth for detecting top dead center. In another example, an optical crank angle sensor detects light that penetrates between projections of a rotor, in which case detected light is converted into and output as a pulse signal of a rectangular wave.
The engine torque estimating apparatus constituted by the micro-computer 10 receives a crank angle extracted from an output pulse of the crank angle sensor CA as an input, and the operation processing unit CPU executes an engine torque estimation program in the auxiliary storage device 12 to calculate an estimated torque such as an estimated indicated torque of each cylinder.
In addition, in the engine control apparatus that is constituted by the microcomputer 10 in a same way, the operation processing unit CPU executes an engine control program in the auxiliary storage device 12, calculates an injector injection amount of the engine ENG based on an internal state of the engine such as the number of rotations, the estimated torque described above, and the like, and performs drive control of the injectors.
The engine torque estimating apparatus 20 receives a voltage output 20A of the crank angle sensor CA as an input and extracts time series data of a crank angle from the voltage output. A time series crank angular velocity calculating unit 21 monitors the pulse-shaped voltage output 20A that is output by the crank angle sensor CA and calculates time series data of the crank angle. Specifically, the time series crank angular velocity calculating unit 21 detects that, when a voltage value output by the crank angle sensor crosses 0 volts when the voltage value output by the crank angle sensor rises and falls, a crank angle θ (k) has advanced by a predetermined minute angle Δθ (p. In addition, assuming that the number of 0-crosses is k, the time series crank angular velocity calculating unit 21 stores time point information t (k) and a following crank angle θ (k).
[Math. 1]
θ(k)=θ(k−1)+Δθ(k) (1)
Furthermore, the time series crank angular velocity calculating unit 21 differentiates the time series data θ (k) of the crank angle by time and calculates time series data 21A of the crank angular velocity according to the following mathematical expression (S21).
Next, a time series torque estimating unit 22 estimates time series data of indicated torque based on the time series data of the crank angle and the time series data of the crank angular velocity and outputs time series data 22A of an estimated indicated torque (S22). Among these estimating methods, in a first estimating method, an estimated indicated torque is calculated based on the time series data of the crank angular velocity and a moment of inertia J according to the following mathematical expression.
[Mat. 3]
r=J{umlaut over (θ)} (3)
In a second estimating method, an estimated indicated torque is calculated based on the time series data of the crank angle and the time series data of the crank angular velocity using a nonlinear Kalman filter and, in particular, an unscented Kalman filter. Estimation processing using a nonlinear Kalman filter in the second estimating method will be described in detail later.
In the 4-cylinder engine, a series of operations (cycles) from intake of a mixture of air and gas into a combustion chamber, combustion of the air-fuel mixture, to discharging combustion gas is performed through a total of four strokes of the pistons including two upstrokes and two downstrokes. During a single cycle of the engine, a piston reciprocates inside a cylinder twice and the crank shaft makes two rotations (720 degrees). The respective cylinders CL0 to CL3 perform respective strokes of intake, compression, ignition (combustion), and exhaust at respective offsets of 180 degrees that represent a quarter of one cycle in which the crank shaft 50 rotates twice (720 degrees).
In the time series data of a crank angle having been extracted from a voltage output of the crank angle sensor CA, a crank angle CA increases from 0 degrees to 720 degrees as time elapses on a time axis (an abscissa). On the other hand, in the time series data of a crank angular velocity AV that is obtained by differentiating the crank angle, an increase and a decrease of the crank angular velocity occurs four times in synchronization with the ignition (combustion) stroke of the respective cylinders. For instance, in the example illustrated in
The time series data of the crank angle and the time series data of the crank angular velocity are different time series data in the ignition strokes of the respective cylinders in accordance with individual variability among the respective cylinders. As a result, the time series data of the estimated indicated torque that is calculated by the time series torque estimating unit 22 is respectively different time series data of the estimated indicated torque in the ignition strokes of the respective cylinders.
The indicated torque illustrated in
The engine for an experiment is rotated and time series data of pressure P0 to P3 in each cylinder is acquired from each cylinder internal pressure sensor CP0 to CP3 of the four cylinders. The correct values of the four indicated torques that are respectively created in the four cylinders are calculated from each cylinder internal pressure P0 to P3. The indicated torque correct values are indicated by a solid line in
There is a relationship where that the higher the cylinder internal pressure in the ignition (combustion) stroke of a cylinder, the higher the indicated torque, and therefore the indicated torque is able to be accurately calculated from cylinder internal pressure in correspondence to a cylinder of the engine.
In addition, average indicated torque correct values R_TRK0 to R_TRK3 of the respective cylinders are calculated from the four indicated torque correct values. An average indicated torque is calculated by, for instance, integrating time series data of an indicated torque by a period of an ignition stroke and dividing the integrated value by a time of the ignition stroke.
On the other hand, pieces of time series data CA0 to CA3 of a crank angle are extracted from an output of the crank angle sensor provided in the engine ENG and input to a Kalman filter CA_FLT. While the time series data of a crank angle is extracted from an output of a single crank angle sensor, since the crank angles of the four cylinders are respectively offset by 180 degrees, the pieces of time series data CA0 to CA3 of the four crank angles are obtained by quartering the output of the crank angle sensor in consideration of the 180-degree offsets.
As will be described later, the Kalman filter CA-FLT calculates an estimated torque (an estimated indicated torque) E_TRK that is a state value of the engine while inputting the time series data of the crank angle. The estimated torque is indicated by a dashed line in
However, due to a limit of measurement resolution in crank angle extraction, a limit of a sampling period of an output of a crank angle sensor, a disturbance such as vibration inside the engine in a high-rotation region, and the like, the time series data of the crank angle and the time series data of crank angular velocity that is calculated therefrom contain noise. In particular, at high rotation, the vibration inside the engine or the limit of the sampling period becomes prominent, and a degree of the limit of the sampling period differs in accordance with a different region of the number of rotations of the engine. The influence rates of them also differ in accordance with individual variability of the four cylinders. In addition, the estimated indicated torques of the respective cylinders that are estimated from the time series data of the crank angle and the time series data of the crank angular velocity contain different noises based on individual variability of the plurality of cylinders (such as individual variability of the injectors).
In consideration thereof, in the present embodiment, as illustrated in
In particular, in the present embodiment, an effect of noise contained in a sensor value of a crank angle sensor is suppressed by adopting an estimated indicated torque amplitude as the estimated indicated torque-related value.
By contrast, in the present embodiment, an individual cylinder torque-related value (amplitude) extracting unit 23 illustrated in
Next, an individual cylinder average indicated torque acquiring unit 24 based on the individual cylinder torque-related value (amplitude) illustrated in
In
As indicated by the example of the conversion map or the conversion formula illustrated in
As indicated by the example of the conversion map or the conversion formula illustrated in
As is apparent from the example illustrated in
In the present embodiment, the estimated indicated torque integrated value illustrated in
Returning now to
On the other hand, the torque feed-forward (FF) control unit 34 calculates a fuel injection amount 34A of all cylinders based on an engine internal state value 41A such as the number of rotations from the engine ENG and the torque target value 33A output by the torque target value setting unit 33 (S34). Specifically, the fuel injection amount is calculated by referring to a map including a feed-forward fuel injection amount in correspondence to a combination of the number of rotations of the engine and a torque target value. The calculated feed-forward fuel injection amount is an injection amount common to all cylinders.
Next, the determining unit 32 of instructed injection amount to the injector receives the feed-forward fuel injection amount 34A and the feedback fuel injection amount 31A for each cylinder as input and determines an instructed injection amount (an instructed value of injection amount) 32A to the injector of each cylinder according to, for instance, PID (Proportional Integral Differential) control. In addition, an injector drive control unit 40 generates a drive signal 40A for driving the injector of each cylinder based on the instructed value of injection amount 32A of each cylinder (S40). The injector of each cylinder in the engine is driven by the drive signal 40A of each cylinder (S40).
[Kalman Filter]
In the present embodiment, the time series torque estimating unit 22 illustrated in
The time series torque estimating unit 22 calculates, according to mathematical expression (4) below, an error between an actually-measured value θ(k) of a crank angle having been acquired by the crank angle sensor CA and a priori estimated value θ{circumflex over ( )}−(k) the crank angle as calculated by a nonlinear Kalman filter to be described later.
[Math. 4]
Δθ(k)=θ(k)−{circumflex over (θ)}−l (k) (5)
In mathematical expression (4), k represents a period of the number of updates. In addition, the time series torque estimating unit 22 calculates, according to mathematical expression (5) below, an error between a calculated value θ·−(k) of a crank angular velocity and a priori estimated value θ·{circumflex over ( )}−(k) of the crank angular velocity as calculated by the nonlinear Kalman filter to be described later.
[Math. 5]
Δθ(k)={dot over (θ)}(k)−{dot over ({circumflex over (θ)})}−(k) (5)
As indicated in mathematical expression (6) below, a state estimated value x(k) according to the present embodiment includes the crank angle θ(k), the crank angular velocity θ·−(k), and an indicated torque τ(k).
In addition, in the nonlinear Kalman filter according to the present embodiment, when a state vector indicated in mathematical expression (6) above is provided, time series data of the crank angle and time series data of the crank angular velocity are calculated by a nonlinear function f and a nonlinear function h according to mathematical expressions (7) and (8) below.
In mathematical expressions (7) and (8), v(k) denotes system noise, w(k) denotes measured noise, and y(k) denotes a measured value (output value). The nonlinear function f and the nonlinear function h are functions including arbitrary coefficient functions and, in the present embodiment, the nonlinear function f and the nonlinear function h are expressed by nonlinear equations indicated in mathematical expressions (9-1) to (9-4) below.
In the nonlinear state equations indicated in mathematical expressions (9-1) to (9-4) above, a measured value θ(k) of the crank angle of a period k at a present time point, a calculated value θ·(k) of the crank angular velocity of the period k at the present time point, and a value τ(k) of torque of the period k at the present time point of the state estimated value x(k) indicated in mathematical expression (6) are input. In addition, a crank angle θ(k+1) of a period k+1 at a next time point, a crank angular velocity θ·(k+1) of the period k+1 at the next time point, and a torque τ(k+1) of the period k+1 at the next time point are estimated
In mathematical expressions (9-2) and (9-3), ainer (8) denotes a term related to inertia of a piston-crank mechanism in an engine and agra (θ) denotes a term related to gravity of the piston-crank mechanism. In addition, avel (θ) denotes a term related to angular velocity of the piston-crank mechanism, and afri (θ) denotes a term related to friction of the piston-crank mechanism. ainer (θ), agra (θ), avel (θ), and afri (θ) are coefficient functions.
In the case of 4-cycle, in-line 4-cylinder, for instance, a no. 1 cylinder and a no. 4 cylinder are in a same phase in a same piston arrangement and a no. 2 cylinder and a no. 3 cylinder are in a same phase in a same piston arrangement. Therefore, in consideration of 4-cycle, in-line 4-cylinder, the term related to inertia, the term related to gravity, the term related to angular velocity, and the term related to friction are expressed by being superimposed while phases thereof are respectively shifted by 180 degrees as indicated in mathematical expression (9-5) below.
[Math. 9]
ainer(θ)=2(ainer_s(θ)+ainer_s(θ+π))
agra(θ)=2(agra_s(θ)+agra_s(θ+π))
avel(θ)=2(avel_s(θ)+avel_s(θ+π))
afri(θ)=2(afri_s(θ)+afri_s(θ+π)) (9-5)
ainer_s (θ) is a coefficient function of the term related to inertia in the case of a single cylinder, agra_s (θ) is a coefficient function of the term related to gravity in the case of a single cylinder, avel_s (θ) is a coefficient function of the term related to angular velocity in the case of a single cylinder, and afri_s (θ) is a coefficient function of the term related to friction in the case of a single cylinder.
In the present embodiment, calculations are performed by replacing a mathematical expression calculation portion of the coefficient functions described above by a table that represents a relationship between output values of the coefficient functions and θ values. Specifically, a table is set in advance which represents a relation between an output value of the term ainer (θ) related to inertia, an output value of the term agra (θ) related to gravity, an output value of the term avel (θ) related to angular velocity, and an output value of the term afri (θ) related to friction and the crank angle θ.
[Setting Initial Value of State Estimated Value (S10)]
The time series torque estimating unit 22 sets an initial value x{circumflex over ( )}(0) of a state estimated value x{circumflex over ( )}(k) as indicated in mathematical expression (10) below.
Next, the time series torque estimating unit 22 sets an initial value P(0) of a posteriori error covariance matrix P0 as indicated in mathematical expression (11) below. In addition, a variance Q of system noise and a variance R of measured noise are set.
[Math. 11]
P(0)=P0 (11)
[Time Update (S11)]
Next, in addition, the time series torque estimating unit 22 repetitively executes processing below for each predetermined period. In this case, for instance, update processing is repetitively performed at each period K=1 to 2, 3, . . . , N (S11).
[Calculation of Sigma Point (S12)]
First, from a state estimated value x{circumflex over ( )}(k−1) and a covariance matrix P(k−1) of an immediately previous period, the time series torque estimating unit 22 calculates 2n+1 number of sigma points σ0, σi as sample points corresponding to an average value and a standard deviation according to mathematical expression (12) (a sample point corresponding to an average value) and mathematical expressions (13) and (14) (a sample point corresponding to a standard deviation) below (S12).
[Math. 12]
σ0(k−1)={circumflex over (x)}(k−1) (12)
σi(k−1)={circumflex over (x)}(k−1)+√{square root over (n+k)}(√{square root over (P(k−1))})i (i=1,2, . . . , n) (13)
σn+i(k−1)={circumflex over (x)}(k−1)−√{square root over (n+k)}(√{square root over (P(k−1))})i (i=1,2, . . . , n) (14)
In the mathematical expressions, (√{square root over (P)})i represents an i-th column of a square root matrix of a covariance matrix P. In addition, weights w0, wi with respect to each sigma point are calculated according to mathematical expressions (15) and (16) below.
In mathematical expressions (15) and (16), K denotes a scaling parameter. A priori state estimated value x{circumflex over ( )}−(k) and a priori error covariance matrix P−(k) that are calculated by mathematical expressions (19) and (20) are respectively referred to as estimated values of a primary moment and a secondary moment. The estimated values of the primary moment and the secondary moment have accuracy until a square term of a Taylor series expansion of f (x(k), v(k)) with respect to an arbitrary nonlinear function. Since estimated values of moments of third or higher orders contain an error, K is a parameter for adjusting an effect of such an error. Semi-positive definiteness is guaranteed by selecting K to be 0 or larger. Normally, K is often set to 0.
[Prediction Step (S13)]
Next, the time series torque estimating unit 22 updates the sigma point σi using the nonlinear function f according to mathematical expression (18) below.
[Math. 14]
σi−(k)=f(σi(k−1)) (i=0,1,2, . . . ,2n) (18)
Next, the time series torque estimating unit 22 calculates a priori state estimated value x{circumflex over ( )}−(k) according to mathematical expression (19) below using a sigma point σi−(k) and the weight wi.
Next, the time series torque estimating unit 22 calculates a priori error covariance matrix P−(k) according to mathematical expression (20) below using the sigma point σi−(k) and the priori state estimated value x{circumflex over ( )}−(k). b in mathematical expression (20) below denotes a coefficient matrix of system noise.
Next, the time series torque estimating unit 22 re-calculates the 2n+1 number of sigma points according to mathematical expressions (21), (22), and (23) below using the priori state estimated value x{circumflex over ( )}−(k) and the priori error covariance matrix P−(k).
[Math. 17]
σ0−(k)={circumflex over (x)}−(k) (21)
σi−(k)={circumflex over (x)}−(k)+√{square root over (n+k)}(√{square root over (P31 (k))})i (i=1,2, . . . , n) (22)
σn+i−(k)={circumflex over (x)}−(k)−√{square root over (n+k)}(√{square root over (P−(k))})i (i=1,2, . . . , n) (23)
Next, the time series torque estimating unit 22 calculates a sigma point Ψi−(k) of output according to mathematical expression (24) below using the sigma point σi−(k) and the nonlinear function h.
[Math. 18]
Ψi−(k)=h(σi−(k) (i=0,1,2, . . . ,2n) (24)
Next, the time series torque estimating unit 22 calculates a priori output estimated value y{circumflex over ( )}−−(k) according to mathematical expression (25) below using the sigma point Ψi−(k) of output of the expression (24).
Next, the time series torque estimating unit 22 calculates a priori output error covariance matrix Pyy−(k) according to mathematical expression (26) below using the sigma point Ψi−(k) of output and the priori output estimated value y{circumflex over ( )}−(k).
Next, the time series torque estimating unit 22 calculates a priori state/output error covariance matrix Pxy−(k) according to mathematical expression (27) below using the priori state estimated value x{circumflex over ( )}−(k), the priori error covariance matrix P−(k), the sigma point Ψi−(k) of output, and the priori output estimated value y{circumflex over ( )}−(k).
Next, the time series torque estimating unit 22 calculates a Kalman gain Kg(k) according to mathematical expression (28) below using the priori state/output error covariance matrix Pxy−(k), the priori output error covariance matrix Pyy−(k), and the variance R of measured noise.
[Filtering Step (S14)]
Next, the time series torque estimating unit 22 estimates a state estimated value x{circumflex over ( )}(k) from a priori state estimated value x{circumflex over ( )}−(k) according to mathematical expression (29) below using the Kalman gain g(k), an error Δθ(k) related to a crank angle, and an error Δθ·(k) related to a crank angular velocity.
Next, the time series torque estimating unit 22 calculates a posteriori error covariance matrix P(k) to be used at the time of a next update according to mathematical expression (30) below using the priori error covariance matrix P−(k), the priori state/output error covariance matrix Pxy−(k), and the Kalman gain g(k).
[Math. 24]
P(k)=P−(k)−g(k)(Pxy−(k))T (30)
In addition, the time series torque estimating unit 22 estimates a torque to be generated in each cylinder based on time series data of the indicated torque T(k) among the state estimated value x{circumflex over ( )}(k). Time series data of the estimated indicated torque to be generated in each cylinder is as indicated by the estimated value depicted by a dashed line in
As described above, according to the present embodiment, an engine torque estimating apparatus calculates time series data of an estimated indicated torque based on a crank angle that is detected by a crank angle sensor, respectively extracts estimated indicated torque-related values for each cylinder from the time series data of the estimated indicated torque for each cylinder, and converts, for each cylinder, the estimated indicated torque-related values into average indicated torque correct values having been calculated based on a cylinder internal state of an engine in correspondence to the estimated indicated torque-related values based on a conversion map or a conversion formula. Therefore, an average indicated torque correct value is able to be calculated with accuracy even when the crank angle that is detected by the crank angle sensor includes noise.
According to the first aspect, an indicated torque of each cylinder is able to be estimated with high accuracy.
All examples and conditional language provided herein are intended for the pedagogical purposes of aiding the reader in understanding the invention and the concepts contributed by the inventor to further the art, and are not to be construed as limitations to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although one or more embodiments of the present invention have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
This application is a continuation application of International Application Number PCT/JP2019/007097 filed on Feb. 25, 2019 and designated the U.S., the entire contents of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6041647 | Matsuoka | Mar 2000 | A |
7194899 | Chen | Mar 2007 | B1 |
10138838 | Ogawa | Nov 2018 | B2 |
20050071073 | Ueda | Mar 2005 | A1 |
20090100920 | Sakayanagi | Apr 2009 | A1 |
20090282903 | Nagano et al. | Nov 2009 | A1 |
20170115172 | Ogawa | Apr 2017 | A1 |
20190011319 | Ogawa | Jan 2019 | A1 |
Number | Date | Country |
---|---|---|
102015102249 | Aug 2016 | DE |
3686417 | Jul 2020 | EP |
9-126041 | May 1997 | JP |
2005-61371 | Mar 2005 | JP |
2005-113877 | Apr 2005 | JP |
2005-201163 | Jul 2005 | JP |
2009-13904 | Jan 2009 | JP |
2010-127219 | Jun 2010 | JP |
2013-163436 | Aug 2013 | JP |
2017-82662 | May 2017 | JP |
2017158838 | Sep 2017 | WO |
Entry |
---|
Written Opinion of International Searching Authority for International Application No. PCT/JP2019/007097, dated Apr. 9, 2019. |
English Translation of International Search Report for International Application No. PCT/JP2019/007097, dated Apr. 9, 2019. |
Shuichi Adachi et al.; Fundamentals of Kalman Filter, Tokyo Denki University Press, ISBN 978-4-501-32891-0 C3055, pp. ii-iii. |
Michael Henn et al.; “Estimation of In-Cylinder-Pressure Torque from Angular Speed by Kalman Filtering”; Advances in Automotive Control 1995, Jan. 1, 1995; Elsevier, XP055727320, pp. 21-26, DOI: 10.1016/B978-0-08-042589-4.50007-8; (6 pages). |
Extended European Search Report dated Feb. 2, 2022 in related European Patent Application No. 19916661.2 (9 pages). |
Notice of Reasons for Refusal dated Jul. 5, 2022 in corresponding Japanese Patent Application No. 2021-501399 (2 pages) (5 pages English Translation). |
Number | Date | Country | |
---|---|---|---|
20210372334 A1 | Dec 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2019/007097 | Feb 2019 | US |
Child | 17399890 | US |