Method for optimizing calibration maps for an algorithm of estimation of a control quantity of an internal combustion engine

Information

  • Patent Grant
  • 8041511
  • Patent Number
    8,041,511
  • Date Filed
    Monday, December 8, 2008
    16 years ago
  • Date Issued
    Tuesday, October 18, 2011
    13 years ago
Abstract
Described herein is a method for optimizing a plurality of calibration maps for an algorithm of estimation of a control quantity of an internal combustion engine, each of the maps comprising a plurality of calibration values of said control quantity estimated by said algorithm. The optimization method comprises measuring the control quantity, estimating the control quantity, and individually optimizing each calibration map based on the measured control quantity and the estimated control quantity.
Description

The present invention concerns a method for optimizing calibration maps for an algorithm of estimation of a control quantity of an internal combustion engine.


BACKGROUND OF THE INVENTION

As is known, modern electronic vehicle engine control units implement a plurality of algorithms that, when the engine is running, estimate engine quantities based on which the electronic control unit controls the engine operation.


These algorithms generally operate by using input quantities, of the motor type for example, generally measured by sensors when the engine is running, and experimentally determined calibration maps, which describe the trend of the quantity estimated by the algorithm, as a function of the quantities on which it depends.


As a rule, before being stored in the electronic control unit, the algorithms are calibrated using the aforementioned maps.


For example, the algorithm for estimating the instantaneous torque supplied by the engine, normally uses the number of engine revs RPM and/or the position of the accelerator pedal as input quantities, both of these detected by suitable sensors, and one or more algorithm calibration maps that describe the trend of supplied torque as a function of the number of engine revs RPM and/or position of the accelerator pedal, with the values of which the algorithm calculates each value of estimated torque.


In particular, the calibration maps of the algorithm are defined by experimentally measuring, on an engine test bench or a rolling road for vehicles, the motor quantities that will be estimated by the algorithm, as a function of the variables on which these depend, for example the torque supplied by the engine can be measured as a function of the number of revs RPM.


Carrying out the measurements of the quantities specified in the calibration maps and the calibration of the control unit's algorithms are operations that require rather long times, are particularly onerous and weigh significantly on the development costs of vehicle control units. Furthermore, the need to implement increasingly complex algorithms in the control units to carry out calculations on the basis of quantities supplied by a plurality of maps makes the process of calibrating the algorithms, consisting in the definition of map values, even longer and more complicated.


In order to simplify the calibration procedure of the algorithms, the following, for example, are known of: use of approximation formulas that describe the physics of the phenomenon to be represented, use of specific programming languages needed to be able to use algebraic formulas via which optimal parameter values can be calculated, or breaking down the algorithms into simpler algorithms and calibrating each one of them using specifically acquired data. For example, if the torque supplied by the engine depends on the product of the output of two calibration maps, usually the representative physical quantities of each of the two maps are measured and then each map is calibrated independently.


However, these solutions have several drawbacks, including:

    • the need to carry out specific measurements for calibration of the algorithm,
    • the need to carry out the measurements in special environmental and/or engine conditions,
    • the use of additional sensors for the acquisition of all the input and output quantities of the maps,
    • the propagation of measurement errors in the calibration procedure,
    • the poor precision of the simplified formulas utilized for describing the physical phenomenon,
    • the imprecision and difficulty of specific programming languages used for implementing the algorithm.


Thus, the need is felt to reduce the number of experimental measurements necessary for obtaining the maps to the bare minimum and to implement an optimization method for the calibration maps of the algorithms that at least partially overcome the drawbacks of the known methods.


SUMMARY OF THE INVENTION

According to the present invention, a method for optimizing calibration maps for an algorithm of estimation of a control quantity of an internal combustion engine is provided, as defined in the attached claims.





BRIEF DESCRIPTION OF THE DRAWINGS

For a better understanding of the present invention, a preferred embodiment shall now be described, purely by way of a non-limitative example and with reference to the enclosed drawings, where:



FIG. 1 shows a block diagram of the principle of the invention's calibration map optimization method,



FIG. 2 shows a flowchart of the invention's calibration map optimization method,



FIGS. 3 and 5 show more detailed flowcharts of the invention's calibration map optimization method, and



FIG. 4 shows an example of a calibration map structure obtained according to the method of the invention.





DETAILED DESCRIPTION OF THE INVENTION

In FIG. 1, reference numeral 1 indicates, in its entirety, an electronic data-processing unit, for example a computer, configured to implement the invention's calibration map optimization method.


In outline, as shown in the block diagram of the principle in FIG. 1, the method of the invention includes:

    • storing the calibration maps of at least one estimation algorithm 2 for a control quantity Pctr, of the motor type, such as the torque supplied by the engine for example, in the processing unit 1,
    • estimating the control quantity Pctr, by means of the algorithm 2, on the basis of the calibration maps and the input quantities detected by sensors and upon which the control quantity Pctr to be estimated depends,
    • experimentally measuring the control quantity Pctrm, and
    • implementing a calibration algorithm 3 for the algorithm 2 via the optimization of the calibration maps of the algorithm 2, so as to make the quantity Pctrs estimated by the algorithm 2 as closely approximated to the measured quantity Pctrm as possible.


For example, always with reference to FIG. 1, the method of the invention can be used to calibrate the estimation algorithm for the torque supplied by the engine, implemented by the electronic control unit for engine control through the optimization of the calibration maps for the torque estimated by said algorithm, these also stored in the electronic control unit and used by the algorithm to perform the torque estimate.


In particular, as shown in the flowchart in FIG. 2, in an initial phase of the method, block 4, the characteristic parameters of each stored calibration map are acquired, more specifically:

    • the values of the input quantities Pi of the map and the corresponding calibration values Pclb associated with them,
    • and, in the case of multidimensional maps in which the calibration quantity Pclb represented in the map depends on more than one input quantity Pi,
    • the calibration values Pclb in function of all the input quantities and the corresponding values of the input quantities Pi associated with them.


For example, if it is wished to optimize the map M1 that represents the trend of torque Ce supplied by the engine as a function of the number of engine revs RPM, the map M2 that represents the trend of torque Ce supplied by the engine as a function of the accelerator pedal position η and the map M3 that represents the trend of torque Ce supplied by the engine as a function of the number of engine revs RPM and accelerator pedal position η, the following will be acquired and stored in this phase of the method:

    • from map M1, the calibration torque Ce-RPM values and the corresponding RPM values associated with them,
    • from map M2, the calibration torque Ce-η values and the corresponding η values associated with them, and
    • from map M3, the calibration torque Ce-RPM-η values and the corresponding RPM and η values associated with them.


For each map, always in said initial phase of the method, map-delimiting parameters are also defined, or rather, more specifically:

    • a minimum variation De allowed for each value of each input quantity, and for each calibration value Pclb specified on the map, for example 0.1 or 0.05,
    • a minimum value Min allowed for each input quantity Pi and for the calibration value Pclb, for example RPM=1000 rpm in map M1, or C=0 Nm in maps M1, M2 and M3, and
    • a maximum value Max allowed for each input quantity Pi and for the calibration value Pclb, for example RPM=8000 rpm in map M1, or C=200 Nm in maps M1, M2 and M3.


Once the initialization phase described in block 4 is completed, in block 5 of FIG. 2 the processing unit 1 performs an optimization procedure on each map. In particular, the calibration maps are individually optimized, one by one, starting from map M1 for example, and proceeding, as shown in block 6 in FIG. 2, with map M2 and so on until all calibration maps have been optimized. The procedure shown in FIG. 2 will be repeated, starting from the first map M1 until interrupted by an operator.


The optimization procedure for each map shall now be described with reference to the flowchart in FIG. 3 and the diagram in FIG. 4.


In particular, as shown in block 10 in FIG. 3, the processing unit 1 first of all checks whether the input quantities Pi of the map Mn to optimize depend on the values of a calibration quantity Pclb of a previously calibrated map Mn−1. If this is not the case, the NO exit is taken from block 10 and, with reference to FIG. 4, the processing unit 1 distributes the calibration values Pclb of map Mn (for example, the calibration values of torque supplied by the engine) inside a system of Cartesian axes, and associates certain respective competence indices IC with each value of the calibration quantity Pclb, so as to create a structure of map Mn, defined by areas An of competence (block 12), each one delimited by a plurality of competence indices IC.



FIG. 4 shows a simplified example of a structure of map Mn to be optimized.


In particular, as shown in FIG. 4, the coordinates of the input variables IC1: [1,1], IC2: [1,2], IC3: [2,2] and IC4: [2,1] are associated with calibration values P1, P2, P3 and P4 of map Mn; coordinates IC5: [2,3], IC6: [3,3], and IC7: [3,2] are associated with values P5, P6 and P7; and coordinates IC8: [3,4], IC9: [4,4] and IC10: [4,3] are associated with calibration values P8, P9 and P10.


After having defined the structure of map Mn, always with reference to FIG. 4, the processing unit 1 copies the measured experimental values for quantity Pctrm, acquired by the processing unit 1 in block 4, into the structure of map Mn and calculates the competence indices IC of each measured experimental value Pctrm.


For example, still with reference to FIG. 4, measured experimental values Pctrm1 and Pctrm2 contribute to map points P1, P2 and P4, while measured experimental values Pctrm3, Pctrm4 and Pctrm5 contribute to map point P6 and, similarly, measured experimental values Pctrm3 and Pctrm4 contribute to map points P8, P9 and P10. This means that a change in the value of each map point will only influence the estimate value in relation to the competence indices; for example, the value of the map at point P1 will only affect the estimate value in correspondence to points Pctrm1 and Pctrm2 and not at other points.


Again, with reference to FIG. 3, in the case in which map Mn depends on a map Mn−1 already optimized by the algorithm 3 and for which the structure has already been defined, the YES exit is taken from block 10 and the processing unit 1 does not recalculate the structure of map Mn at the beginning of each optimization, but uses the same competence indices IC and the same structure previously defined for the same map Mn, block 11.


Then, the processing unit 1 identifies the measured values Pctrm specified in the structure of map Mn that contribute to the single map point to be optimized, block 14, and implements an optimization procedure on each calibration value Pclb, according to the flowchart in FIG. 5.


In particular, as shown in block 20 in FIG. 5, the processing unit 1 corrects the measured quantity Pctrm with the respective calibration value Pclb to which the competence index IC of the measured quantity Pctrm is associated, thereby determining the estimated quantity Pctrs, and calculates the standard deviation SQM1 between the measured quantity Pctrm and the quantity Pctrs estimated by the algorithm 2 with the current values of the map.


Then, in block 21, the processing unit 1:






    • adds a factor F equal to the product K*De to the calibration value Pclb, where:

    • K is an integer chosen, randomly for example, from a preset range of integers, from 1 to 16 for example, and

    • De is a minimum variation allowed for the calibration quantity Pclb,

    • in order to obtain a new calibration value Pclb+F,

    • corrects the measured quantity Pctrm with the new calibration value Pclb+F thereby determining a new value Pctrs+F for the estimated quantity, and

    • calculates the standard deviation SQM2 between the measured quantity Pctrm and the new estimated value Pctrs+F of the control quantity.





Successively, in block 22 the processing unit 1:

    • subtracts the factor F, equal to the product K*De from calibration value Pclb, obtaining a new calibration value Pclb−F,
    • corrects the measured quantity Pctrm with the new calibration value Pclb−F thereby determining a new value Pctrs−F for the estimated quantity, and
    • calculates the standard deviation SQM3 between the measured quantity Pctrm and the new estimated value Pctrs−F of the control quantity.


In block 23, the processing unit 1 determines the minimum standard deviation SQMmin by selecting the smallest of the standard deviations SQM1, SQM2 and SQM3, and compares the minimum standard deviation SQMmin with a preset threshold value, for example 0.1.


In the case where the minimum standard deviation SQMmin is below the threshold value, the YES exit is taken from block 24 and the processing unit 1 sets the one of the three calibration values Pclb, Pclb+F and Pclb−F having the standard deviation SQM closest to the minimum standard deviation SQMmin in map Mn as the optimal calibration value Pclb−ott, which will result as being the optimized calibration value, block 25.


Instead, in the case where the minimum standard deviation SQMmin is greater than the threshold value, the NO exit is taken from block 24 and, in block 26, the processing unit 1 implements a calculation algorithm to obtain a value that is as close as possible to the minimum standard deviation SQMmin. To this end, the processing unit 1 calculates two calibration values Pclb2 and Pclb3 that tend towards an expected minimum calibration value Pclb−min and determines the algebraic minimum of a curve that models the standard deviation SQMmin, implementing a parabolic model of deviation of known type, for example the “Levenberg Marquardt” algorithm, block 27.


In particular, to that end, the processing unit 1 calculates:

    • a calibration value Pclb2 that is at the minimum (xmin=−b/2a) of a parabolic equation SQM=ax2+bx+c passing through the points of standard deviation SQM1, SQM2 and SQM3,
    • a calibration value Pclb3 that is at the minimum (xmin=−b/2a) of a parabolic equation SQM=ax2+bx+c passing through the points defined by the values of standard deviation SQM1, SQM2 and SQM3 and the calculated calibration point Pclb2, and
    • determines the algebraic minimum of a curve that models the standard deviation SQMmin on the basis of the points defined by the values of the standard deviations SQM1, SQM2, SQM3, and by points Pclb2 and Pclb3.


Then, in block 28 the processing unit 1 substitutes, in map Mn, the value Pclb used to correct the measured quantity Pctrm with a calibration value Pclb−ott of map Mn that is at an intermediate point between the calibration value Pclb used to correct the measured quantity Pctrm and the algebraic minimum of the standard deviation SQMmin determined by means of the parabolic model of deviation, which will thus constitute the optimized calibration value Pclb−ott, block 29.


After having optimized each one of the calibration values Pclb of map Mn, again with reference to FIG. 3, the processing unit 1 implements a calculation procedure with the purpose of improving the distribution of the calibration values Pclb within map Mn, block 16.


In particular, this procedure, for descriptive convenience henceforth referred to as “stretching” of the map Mn, consists in:

    • calculating a vector STR according to the formula:







S





T






R

(
i
)



=


Y

(

i
-
1

)


+



(


x

(
i
)


-

X

(

i
-
1

)



)

*

(


y

(

i
+
1

)


-

y

(

i
-
1

)



)




x

(

i
+
1

)


-

x

(

i
-
1

)




-

y

(
i
)








where:

    • X is a vector containing the values of the input quantity Pi of the map, for example X=[P1 P2 P3 P4],
    • Y is a vector containing each value of the calibration quantity Pclb of the mono-dimensional map corresponding to a specific input value Pi, for example Y=[Pclb1 Pclb2 Pclb3 Pclb4], and
    • i is the index that identifies the element of vector X or Y, (for example, Y(3) indicates the third element of vector Y),
    • adding a quantity equal to η*STR/2 to value Pclb of the map, where η is a stretching factor between a minimum value of zero corresponding to no stretching and a maximum value of 1 corresponding to maximum stretching, which can be set by the user, and
    • subtracting a quantity equal to η*STR/4 from the neighbouring values Pclb−1 and Pclb+1 of the value Pclb to calibrate.


The stretching procedure increases the continuity of the map, making it more faithful to the description of a physical phenomenon.


After having carried out the stretching procedure on the map Mn, again with reference to FIG. 3, in block 17 the processing unit 1 calculates: a minimum saturated value Pmin−sat on the basis of the minimum calibration value Pmin of map Mn, and a maximum saturated value Pmax−sat on the basis of the maximum calibration value Pmax of map Mn.


In particular, the minimum saturated value Pmin−sat of each calibration value of the map corresponds to the maximum value between the value of the map and the allowed minimum Pmin, while the maximum saturated value Pmin−sat of each point of the map corresponds to the minimum value between the value of the map and the allowed maximum Pmax.


The advantages that can be achieved with the present invention are evident from an examination of its characteristics.


First of all, the optimization of only one map at a time allows the optimized calibration value to be determined in an optimal manner, significantly reducing calculating times.


In addition, the identification of experimental points of competence for each map point outside of the optimization procedure and use of the Levenberg Marquardt algorithm only in cases where the calibration value is significantly different from its optimal value, allow a significant reduction in the execution times and complexity of the entire calculation procedure, at the same time preserving very good precision for the final result.


The implementation of the “stretching” procedure allows the most “continuous” calibration to be identified from a plurality of calibration values that roughly exhibit the same standard deviation.


Finally, it is clear that modifications and variants can be made to that described and shown herein without leaving the scope of protection of the present invention, as defined in the enclosed claims.


For example, instead of standard deviation SQM, the percentage standard deviation SPQM could be calculated, this being more indicated for solving problems where the requested precision specifications are provided in percentage terms rather than absolute ones.

Claims
  • 1. Method for controlling an internal combustion engine by optimizing calibration maps (Mr) for an algorithm of estimation of a control quantity (Pctr) of the internal combustion engine, each calibration map comprising a plurality of calibration values (Pclb) of said control quantity (Pctrs) estimated by said algorithm, the method comprising: measuring the control quantity (Pctrm),estimating the control quantity (Pctrs) by means of said algorithm, andindividually optimizing each calibration map (Mn) based on the measured control quantity (Pctrm) and the estimated control quantity (Pctrs),wherein optimizing each calibration map (Mn) comprises operating a computer to execute the steps of:optimizing at least one of said plurality of calibration values (Pcbl), anddistributing said optimized calibration values (Pclb-ott, ) in said calibration map (M˜ based on a preset criterion, andwherein optimizing a calibration value (Pclb) comprises:determining the estimated control quantity (Pctrs) based on the measured control quantity (Pctrm) and the calibration value (Pclb),computing a first standard deviation (SQM1) between the measured control quantity (Pctrm) and the estimated control quantity (Pctrs),determining a first corrected calibration value (Pclb+F) based on the correction factor (F),determining the estimated control quantity (Pctrs) based on the measured control quantity (Pctrm) and the first corrected calibration value (Pclb+F),computing a second standard deviation (SQM2) between the measured control quantity (Pctrm) and the estimated control quantity (Pctrs) based on the measured control quantity (Pctrm) and the first corrected calibration value (Pclb+F),determining a second corrected calibration value (Pclb+F) based on the correction factor (F),determining the estimated control quantity (Pctrs) based on the measured control quantity (Pctrm) and the second corrected calibration value (Pclb+F),computing a third standard deviation (SQM3) between the measured control quantity (Pctrm) and the estimated control quantity (Pctrs) based on the measured control quantity (Pctrm) and the second corrected calibration value (Pclb+F),comparing the first (SQM1), second (SQM2) and third (SQM3) standard deviations with each other and with a preset threshold value, andoptimizing the calibration value (Pclb) based on said comparison; andutilizing the calibration value (Pclb) to control a function of the internal combustion engine.
  • 2. Method according to claim 1, wherein the calibration factor (F) is determined based on an integer (K) within a preset range of integers and a preset minimum variation (De) of the calibration value (Pclb).
  • 3. Method according to claim 2, wherein the calibration factor (F) is determined based on the product of said integer (K) within a preset range of integers and said preset minimum variation (De) of said calibration value (Pclb).
  • 4. Method according to claim 1, wherein: said first corrected calibration value (Pclb+F) is determined by adding said correction factor (F) to said calibration value (Pclb), andsaid second corrected calibration value (Pclb−F) is determined by subtracting said correction factor (F) from said calibration value (Pclb).
  • 5. Method according to claim 1, wherein optimizing said calibration value (Pclb) based on said comparison comprises: determining the smallest (SPQMmin) of said first (SQM1), second (SQM2) and third (SQM3) standard deviations,comparing the smallest (SPQMmin) standard deviation with said preset threshold value, andoptimizing said calibration value (Pclb) based on said comparison.
  • 6. Method according to claim 5, wherein when said smallest standard deviation (SPQMmin) is below said preset threshold value, optimizing said calibration value (Pclb) based on said comparison comprises: setting in the calibration map an optimal calibration value (Pclb-ott) chosen among said calibration value (Pclb), said first corrected calibration value (Pclb+F), and said second corrected calibration value (Pclb−F), and for which the standard deviation (SQM) is closest to said smallest standard deviation (SQMmin).
  • 7. Method according to claim 5, wherein when said smallest standard deviation (SPQMmin) is higher than said preset threshold value, optimizing said calibration value (Pclb) based on said comparison comprises: determining a first minimum calibration value (Pclb2), which is defined as the lowest point of a parabolic-like function passing through said first, second and third standard deviations (SQM1, SQM2 and SQM3),determining a second minimum calibration value (Pclb3) which is defined as the lowest point of a parabolic-like function passing through said first, second and third standard deviations (SQM1, SQM2 and SQM3) and said first calibration value (Pclb2),determining a minimum algebraic value of a function passing through said first, second and third standard deviations (SQM1, SQM2 and SQM3) and said first and second minimum value (Pclb2 and Pclb3), and that models said smallest standard deviation (SQMmin), andsubstituting said calibration value (Pclb) in said calibration map with an optimal calibration value (Pclb ott) that is located at an intermediate point between said calibration value (Pclb) and said minimum algebraic value.
  • 8. Method according to claim 7, wherein said minimum algebraic value is determined based on a “Levenberg Marquardt” algorithm.
  • 9. Method according to claim 1, wherein distributing said plurality of optimized calibration values (Pclb-ott) in said map (Mn) comprises: computing a stretching factor (STR) according to the formula: where:X is a value of an input quantity (Pi) of said map,Y is a calibration value (Pclb) corresponding to said value X of said input quantity (Pi), andI is an index that associates a value X of the input quantity (Pi) with the corresponding optimized calibration value (Pclb-ott),adding a quantity equal to η*STR/2 to each optimized calibration value (Pclb-ott), where η is a stretching factor between zero and one, andsubtracting a quantity equal to η*STR/4 from adjacent values (Pclb−1 and Pclb+1) of said optimized calibration value (Pclb-ott).
  • 10. A non-transitory computer readable medium containing a software code stored therein and loadable in a memory of a digital processor, said software code being configured to implement the method according to claim 1, when said software code is executed on said digital processor.
Priority Claims (1)
Number Date Country Kind
07425782 Dec 2007 EP regional
US Referenced Citations (2)
Number Name Date Kind
6397152 Kalweit et al. May 2002 B1
6848421 Karau et al. Feb 2005 B1
Foreign Referenced Citations (2)
Number Date Country
2 864 162 Jun 2005 FR
WO 2005103472 Nov 2005 WO
Related Publications (1)
Number Date Country
20090150111 A1 Jun 2009 US