The present invention relates to engine throttle control systems, and more particularly to a throttle control system that compensates for an area of a throttle body.
Electronic throttle control (ETC) systems replace the mechanical pedal assemblies that are currently used in vehicles. ETC systems enhance overall engine management while reducing the cost of the vehicle. Traditional engine controls rely on direct input from drivers and numerous valves and linkages to manage the engine. These systems do not enable consistent throttle control.
ETC sensors eliminate the linkage that is used to connect the accelerator pedal to the throttle body. ETC sensors take input from the driver and send it to an engine control system in real time. The engine control system modulates the air/fuel flow to the engine. Direct control of the engine is shifted from the driver to the engine control system to improve efficiency.
ETC can also be coordinated with the shifting of the transmission, whereas mechanical systems react solely to the torque applied by the engine. Mechanical systems shift under high-load conditions, which may decrease the life of the transmission over time. ETC systems can reduce throttle, shift, and then increase throttle. This approach will increase the life of the transmission.
As throttle body coke deposits build up on a throttle blade/bore during the life of a vehicle, a relationship between pedal position and throttle response may deteriorate. This deterioration can lead to reduced idle quality. Customers experiencing poor idle quality during a warranty coverage period will request service. As a result, the warranty cost of the vehicle increases. Customers experiencing poor idle quality after the warranty coverage period ends will have higher operating costs. Other conditions that may adversely impact throttle response include variations in an airflow breakout region position, dirty air cleaners, and/or non-linearity in throttle position sensors.
Accordingly, the present invention provides a throttle control system for a vehicle. The throttle control system includes a driver input device that generates a control signal and a control module that generates a throttle control signal based on the control signal. The control module determines whether the throttle control signal is within one of a first and a second region, determines a compensation factor from a first look-up table when the throttle control signal is within the first region and determines the compensation factor from a second look-up table when the throttle control signal is within the second region. The control module calculates a compensated throttle control signal based on the compensation factor.
In one feature, the throttle control system further includes a throttle that is regulated based on the compensated throttle control signal.
In another feature, the driver input device includes one of an accelerator pedal and a cruise control system.
In another feature, the control module stores the compensation factor in first and second memory stores and determines whether to rate limit the compensation factor. The control module compares compensation factor values from the first and second stores to determine whether the compensation factor was rate limited.
In other features, the control module checks learning conditions. The control module updates the first look-up table based on a mass air flow (MAF) residual when the learning conditions are met and the throttle control signal is in the first region and updates the second look-up table based on the MAF residual when the learning conditions are met and the throttle control signal is in the second region. The control module updates the first and second tables based on the MAF residual when the learning conditions are met and an update index is common to both the first and second tables.
In another feature, the throttle control system further includes a MAF sensor that generates a measured MAF signal. The MAF residual is calculated based on the measured MAF signal.
In another feature, the throttle control system further includes a manifold absolute pressure (MAP) sensor that generates a measured MAP signal. The MAF residual is calculated based on the measured MAP signal.
In another feature, the control module updates a first residual look-up table based on the MAF residual when the learning conditions are met and the throttle control signal is in the first region and updates a second residual look-up table based on the MAF residual when the learning conditions are met and the throttle control signal is in the second region.
In another feature, the control module determines a first mass air flow (MAF) residual from a residual look-up table, determines a second MAF residual from the residual look-up table and enables a barometer update routine when the first and second MAF residuals are each less than a barometer update enable threshold.
In still another feature, the control module resets one of the first and second look-up tables when a size of at least one of the first and second look-up tables is not equal to a predetermined value.
In yet another feature, the control module resets one of the first and second look-up tables when the compensation factor is outside of a threshold range. The control module determines upper and lower limits of the threshold range.
Further areas of applicability of the present invention will become apparent from the detailed description provided hereinafter. It should be understood that the detailed description and specific examples, while indicating the preferred embodiment of the invention, are intended for purposes of illustration only and are not intended to limit the scope of the invention.
The present invention will become more fully understood from the detailed description and the accompanying drawings, wherein:
The following description of the preferred embodiment is merely exemplary in nature and is in no way intended to limit the invention, its application, or uses. For purposes of clarity, the same reference numbers will be used in the drawings to identify similar elements. As used herein, the term module refers to an application specific integrated circuit (ASIC), an electronic circuit, a processor (shared, dedicated, or group) and memory that execute one or more software or firmware programs, a combinational logic circuit, or other suitable components that provide the described functionality.
The present invention uses a throttle area correction factor (ACORR) and mass air flow (MAF) residuals that are generated by an intake diagnostic system to compensate a throttle body for actual airflow progression throughout multiple operating ranges of a throttle blade opening. Generally, the present invention employs the throttle body airflow relationship (or progression) for an ideal throttle body and creates and updates a series of look-up tables used to compensate the ideal throttle body. The throttle control system of the present invention expands upon and provides more advanced functions than the throttle control system of commonly assigned, co-pending U.S. patent application Ser. No. 10/689,184, filed Oct. 20, 2003 and entitled Airflow Variation Learning Using ETC, the disclosure of which is expressly incorporated herein be reference.
Referring now to
Overall operation of the engine 12 is monitored and regulated by a control module 18. More specifically, the control module 18 regulates the engine 12 based on driver inputs and engine operating conditions. The driver inputs include an accelerator pedal 20 and/or a cruise control module 22. A pedal sensor 24 is responsive to a position of the accelerator pedal 20 and generates a pedal position signal to the control module 18. The accelerator pedal position is indicative of a desired engine torque output from the driver. The cruise control module 22 signals desired engine torque output based on a set point set by the driver. A mass air flow (MAF) sensor 26 is responsive to the MAF through the throttle 16 and generates a MAF signal to the control module 18. A throttle position sensor (TPS) 28 is responsive to the position of the throttle blade and generates a TPS signal to the control module 18. A manifold absolute pressure (MAP) sensor 30 is responsive to a pressure within the intake manifold 14 and generates a MAP signal to the control module 18.
The throttle control system of the present invention regulates the throttle position based on a compensated throttle area (ACOMP). ACOMP accounts for variations in the throttle body and/or engine system as a whole to provide the desired engine torque output. More specifically, an uncompensated throttle area (AUNCOMP) is generated based on driver and/or cruise control intent. AUNCOMP does not account for airflow variations through the throttle body. The throttle control system determines whether AUNCOMP is within a low airflow (LO) region or a high air airflow (HI) region by comparing AUNCOMP to respective thresholds.
A throttle area correction factor (ACORR) is determined from a look-up table based on AUNCOMP. More specifically, if AUNCOMP is in the LO region, ACORR is determined from a LO region look-up table. If AUNCOMP is in the HI region, ACORR is determined from a HI region look-up table. The following is an exemplary LO region look-up table:
It is appreciated that the values provided in the table are merely exemplary in nature. The LO and HI region look-up tables overlap and include a common break point or index. More specifically, the last index of the LO region look-up table includes the same values as the first index of the HI region look-up table. The throttle control system further includes a LO region residual look-up table and a HI region residual look-up table, which respectively correspond to the LO region and HI region look-up tables. The residual look-up tables are implemented in an updating or learning routine, discussed in further detail below.
ACORR and the index are determined based on AUNCOMP. More specifically, if AUNCOMP is between index values, the throttle control system interpolates ACORR. If AUNCOMP is below the first index, the first index is value used. If AUNCOMP is above the last index, the last index value is used. ACOMP is determined based on AUNCOMP and ACORR and the throttle position is determined based on ACOMP. In this manner sufficient airflow is enabled to provide the desired engine torque output.
The LO region and HI region look-up tables and corresponding residual tables are concurrently updated when learning conditions are appropriate. More specifically, the throttle control system checks to ensure that the vehicle is operating in a stable state and that there are no sensor faults. In particular, the throttle control system compares a measured MAF (MAFMEAS) to a calculated MAF (MAFCALC) to ensure the MAF sensor is not shifted. MAFMEAS is determined based on the MAF signal from the MAF sensor and MAFCALC is calculate based on the MAP, which is determined from the MAP sensor.
Referring now to
In step 204, control determines a ACORR from the HI region look-up table based on AUNCOMP. In step 208, control determines whether ACORR is within a HI range. More specifically, ACORR is compared to an air learn positive limit (LIMAIRLRNPOS) and an air learn negative limit (LIMAIRLRNNEG). LIMAIRLRNPOS and LIMAIRLRNNEG are determined based on the throttle is operating in the HI region, as discussed in further detail below. If ACORR is greater than LIMAIRLRNPOS or less than LIMAIRLRNNEG, ACORR is not within the HI range. This indicates a corrupted table value and all of the tables are reset in step 210. If ACORR is within the HI range, control continues in step 212.
In step 206, control determines a ACORR from the LO region look-up table based on AUNCOMP. In step 214, control determines whether ACORR is within a LO range. More specifically, ACORR is compared to LIMAIRLRNPOS and LIMAIRLRNNEG, which are determined based on the throttle operating in the LO region, as discussed in further detail below. If ACORR is greater than LIMAIRLRNPOS or less than LIMAIRLRNNEG, ACORR is not within the LO range. This indicates a corrupted table value and all of the tables are reset in step 210. If ACORR is within the LO range, control continues in step 212.
In step 212, ACORR is saved in a second memory store as ACORRDUAL. In step 216, control determines whether to rate limit ACORR. ACORR is rate limited under certain operating conditions. In general, ACORR is rate limited when ACORR is greater than the difference between a maximum idle area (AIDLEMAX) and an idle area (AIDLE). In one operating condition, if the engine is operating under a power limited condition, ACORR is limited to the difference between AIDLEMAX and AIDLE. A power limited condition can occur when one or more sensors, such as the TPS 28 or accelerator pedal position sensor 24, has a fault or when the throttle actuator has a fault. If the engine is not operating under the power limited condition, a corrected area rate (ACORRATE) is calculated as the sum of an idle speed increase area (AIDLESPDINC) and a previous ACORR (i.e., ACORR at the time step immediately previous to the current time step). If ACORR is greater than ACORRATE, then ACORR is limited to the maximum value of either the difference between AIDLEMAX and AIDLE or ACORRATE in step 218.
In another operating condition, ACORR is rate limited when operating in the LO region and ACORR is greater than AIDLEMAX. In this case, ACORR is limited to AIDLEMAX in step 218. In still another operating condition, ACORR is limited when operating in the HI region and ACORR is greater than the maximum HI region look-up table value. In this case, ACORR is limited to the maximum HI region look-up table value in step 218.
In step 220, control determines whether ACORR is equal to ACORRDUAL. If ACORR is equal to ACORRDUAL, then ACORR was not rate limited or limited to any maximum limits and learning is enabled in step 222. If ACORR is not equal to ACORRDUAL, then ACORR from the HI region was rate limited or limited to a maximum limits and learning in the HI region is inhibited in step 224. In this manner, the tables are not updated using a MAF residual calculated from a rate limited throttle position value.
In step 226, control determines ACOMP based on AUNCOMP, ACORR and ACORRDUAL. More specifically, ACOMP is determined based on the following relationship:
ACOMP=MAX(0, (AUNCOMP+MIN(ACORR,ACORRDUAL)))
In this manner, ACOMP can be limited to remain positive or is calculated using the minimum of ACORR and ACORRDUAL. In step 228, control determines whether ACOMP is equal to 0. If ACOMP is equal to zero, ACOMP is a limited value and control inhibits LO region learning in step 230. If ACOMP is not equal to zero, ACOMP is not a limited value and control enables LO region learning in step 232. In step 234, control determines throttle position (TP) based on ACOMP. It is anticipated that TP can be calculated or determined from a look-up table. Control regulates the throttle to achieve TP.
Referring now to
In step 302, control determines whether the control module was initialized. The control module is initialized at every vehicle power-up event (e.g., turning ignition on). If the control module was not initialized, control continues in step 308. If the control module was initialized, control determines whether the table sizes are correct in step 310. If the table sizes are correct, control continues in step 308. If the table sizes are not correct, control resets the tables in step 312 and continues in step 308.
In step 308, control determines whether the learning conditions are met. The learning conditions include ensuring that the engine has not run at idle for an extended period of time. If the engine is at idle for too long, the throttle body can become too warm, varying the intake air temperature (IAT), which in turn affects the accuracy of MAFIND, described in further detail below. Other learning conditions include, but are not limited to, ensuring the engine is operating at steady state, ensuring that the MAF is not below a threshold value and ensuring that the barometer value was last updated within a threshold distance. Still other learning conditions include ensuring that the various sensors are functioning properly. Learning is inhibited if one or more sensors, such as the TPS 28 and pedal position sensor 24, has a fault, the throttle actuator has a fault or the learnt throttle minimums have been reset to default values. Other sensors including, but not lomited to, IAT, MAP, barometer, low battery voltage and MAF can inhibit learning if faulty. Idle speed faults including too low or too high of an engine idle speed can also inhibit learning. If the learning conditions are not met, control inhibits learning in step 314 and control ends. If the learning conditions are met, control continues in step 316.
In step 316, control ensures that neither the MAF and/or MAP sensors are shifted. More particularly, control determines whether the absolute value of the difference between MAFMEAS and MAFCALC is greater than a threshold (MAFTHR). If the absolute value of the difference is greater than MAFTHR, one of the MAP and/or MAF sensors is shifted. In this case, learning is inhibited in step 314 and control ends. If the absolute value of the difference is not greater than MAFTHR, neither the MAP nor MAF sensors is shifted and control continues in step 318.
In step 318, control determines a learning residual (RESLRN) based on indicated MAF (MAFIND) and MAFMEAS. More particularly, RESLRN is an average of multiple residual values calculated at a current throttle position. MAFIND is determined based on the throttle position signal from the TPS and does not include any correction. Each residual value is provided as a unitless ratio and is calculated according to the following equation:
Residual=(MAFIND−MAFMEAS)/MAFMEAS
Several residual values are recorded and RESLRN is calculated when a threshold number of residual values are recorded. More specifically, RESLRN is calculated as the sum of the recorded residual values divided by the number of residual values.
In step 320, control determines a learning index or break point (INDEXLRN) based on either the LO region or HI region tables, depending on whether the throttle is operating in the LO or HI regions, and AUNCOMP. More specifically, INDEXLRN is interpolated from the appropriate table based on AUNCOMP. Because INDEXLRN may lie between table indices, INDEXLRN is rounded to the nearest index. Control saves RESLRN in the corresponding table at INDEXLRN, replacing the previous table value in step 322.
In step 324, control checks a sub-set of the stability conditions to ensure the samples used to update the tables are stable and valid. The sub-set of stability conditions include, but are not limited to engine speed being within a threshold range, time since last learn being greater than a threshold time, a vacuum across the throttle blade being greater than a threshold value and AUNCOMP being less than a threshold value. If the stability conditions are not met, control inhibits learning in step 314 and control ends. If the stability conditions are met, control continues in step 326.
In step 326, control determine an air learn modifier (MODLRN). MODLRN is a throttle area correction determined based on RESLRN and is discussed in further detail below with regard to
Referring now to
In step 404, control determines whether FLAGLOLTD is equal to FALSE. If FLAGLOLTD is not equal to FALSE, learning lower correction terms is inhibited and control continues in step 412. If FLAGLOLTD is equal to FALSE, learning higher correction terms is enabled and control continues in step 414. In step 412, control sets MODLRNRTLIM equal to 0 and control continues in step 410. In step 414, control looks up MODLRNRTLIM from a look-up table based on AUNCOMP. This look-up table provides values for the maximum allowable throttle area correction decrease per learning cycle. In this manner, control ensures the throttle area correction is small enough to avoid idle instability, but large enough to provide an effective learning value for a new or clean throttle.
In step 410, control calculates a second term (TERM2) as the product of RESLRN and AUNCOMP. In step 416, control determines whether the absolute value of TERM2 is greater than the absolute value of MODLRNRTLIM. If the absolute value of TERM2 is greater than the absolute value of MODLRNRTLIM, control continues in step 418. If the absolute value of TERM2 is not greater than the absolute value of MODLRNRTLIM, control continues in step 420. In step 418, control calculates MODLRN as the sum of ACORR and MODLRNRTLIM and control ends. In step 420, control calculates MODLRN as the sum of ACORR and TERM2 and control ends.
Referring now to
In step 506, control calculates LIMLOWER according to the following equation:
LIMLOWER=ACORRLO(INDEXLRN+1)−DELTALOMAX
In this manner, LIMLOWER is equal to the next highest correction value in the LO region look-up table, minus a maximum delta (DELTALOMAX) that is a calibration value corresponding to the LO region. In step 510, control calculates LIMUPPER according to the following equation:
LIMUPPER=ACORRLO(INDEXLRN+1)+DELTALOMAX
In this manner, LIMUPPER is equal to the next highest correction value in the table, plus DELTALOMAX.
In step 508, control determines whether INDEXLRN is equal to INDEXn. If INDEXLRN is not equal to INDEXn, INDEXLRN is not equal to the last index value in the LO region look-up table and control continues in step 512. If INDEXLRN is equal to INDEXn, INDEXLRN is equal to the last index value in the LO region look-up table and control continues in step 514. Because INDEXn of the LO region look-up table and INDEX0 of the HI region look-up table are common to both tables as a result of overlap, INDEXLRN is considered a common index or break point. In step 514, control sets a common break point flag (FLAGCOMBP) equal to TRUE. In step 516, control calculates LIMLOWER according to the following equation:
LIMLOWER=ACORRLO(INDEXLRN−1)−DELTALOMAX
In this manner, LIMLOWER is equal to the next lowest correction value in the table, minus DELTALOMAX. In step 518, control calculates LIMUPPER according to the following equation:
LIMUPPER=ACORRLO(INDEXLRN−1)+DELTALOMAX
In this manner, LIMUPPER is equal to the next lowest correction value in the table, plus DELTALOMAX.
In step 512, control determines whether the look-up table is an increasing slope table. More specifically, if ACORRLO corresponding to the index immediately above INDEXLRN is greater than ACORRLO corresponding to the index immediately below INDEXLRN, the look-up table is considered to be increasing in slope. If ACORRLO corresponding to the index immediately above INDEXLRN is not greater than ACORRLO corresponding to the index immediately below INDEXLRN, the look-up table is considered to be decreasing in slope. If the look-up table is increasing in slope, control continues in step 520. If the look-up table is decreasing in slope, control continues in step 522.
In step 520, control calculates LIMLOWER according to the following equation:
LIMLOWER=ACORRLO(INDEXLRN+1)−DELTALOMAX
In this manner, LIMLOWER is equal to the next highest correction value in the table, minus DELTALOMAX. In step 524, control calculates LIMUPPER according to the following equation:
LIMUPPER=ACORRLO(INDEXLRN−1)+DELTALOMAX
In this manner, LIMUPPER is equal to the next lowest correction value in the table, plus DELTALOMAX. In step 522, control calculates LIMLOWER according to the following equation:
LIMLOWER=ACORRLO(INDEXLRN−1)−DELTALOMAX
In this manner, LIMLOWER is equal to the next lowest correction value in the table, minus DELTALOMAX. In step 526, control calculates LIMUPPER according to the following equation:
LIMUPPER=ACORRLO(INDEXLRN+1)+DELTALOMAX
In this manner, LIMUPPER is equal to the next highest correction value in the table, plus DELTALOMAX.
In step 502, control determines whether INDEXLRN is equal to 0. If INDEXLRN is not equal to 0, control continues in step 528. If INDEXLRN is equal to 0, INDEXLRN is equal to the first break point of the HI region look-up table and control continues in step 530. Because INDEX0 of the HI region look-up table and INDEXn of the LO region look-up table are common to both tables as a result of overlap, INDEXLRN is considered a common index or break point. In step 530, control sets FLAGCOMBP equal to TRUE. In step 532, control calculates LIMLOWER according to the following equation:
LIMLOWER=ACORRHI(INDEXLRN+1)−DELTAHIMAX
In this manner, LIMLOWER is equal to the next highest correction value in the HI region look-up table, minus a maximum delta (DELTAHIMAX) that is a calibration value corresponding to the HI region. In step 534, control calculates LIMUPPER according to the following equation:
LIMUPPER=ACORRHI(INDEXLRN+1)+DELTAHIMAX
In this manner, LIMUPPER is equal to the next highest correction value in the table, plus DELTAHIMAX.
In step 528, control determines whether INDEXLRN is equal to INDEXn (i.e., the last index or break point in the HI region look-up table). If INDEXLRN is not equal to INDEXn, control continues in step 536. If INDEXLRN is equal to INDEXn, control continues in step 538. In step 538, control calculates LIMLOWER according to the following equation:
LIMLOWER=ACORRHI(INDEXLRN−1)−DELTAHIMAX
In this manner, LIMLOWER is equal to the next lowest correction value in the table, minus DELTAHIMAX. In step 540, control calculates LIMUPPER according to the following equation:
LIMUPPER=ACORRHI(INDEXLRN−1)+DELTAHIMAX
In this manner, LIMUPPER is equal to the next lowest correction value in the table, plus DELTAHIMAX.
In step 536, control determines the look-up table is an increasing slope table. More specifically, if ACORRHI corresponding to the index immediately above INDEXLRN is greater than ACORRHI corresponding to the index immediately below INDEXLRN, the look-up table is considered to be increasing in slope. If ACORRHI corresponding to the index immediately above INDEXLRN is not greater than ACORRHI corresponding to the index immediately below INDEXLRN, the look-up table is considered to be decreasing in slope. If the look-up table is increasing in slope, control continues in step 542. If the look-up table is decreasing in slope, control continues in step 544.
In step 542, control calculates LIMLOWER according to the following equation:
LIMLOWER=ACORRHI(INDEXLRN+1)−DELTAHIMAX
In this manner, LIMLOWER is equal to the next highest correction value in the table, minus DELTAHIMAX. In step 546, control calculates LIMUPPER according to the following equation:
LIMUPPER=ACORRHI(INDEXLRN−1)+DELTAHIMAX
In this manner, LIMUPPER is equal to the next lowest correction value in the table, plus DELTAHIMAX. In step 544, control calculates LIMLOWER according to the following equation:
LIMLOWER=ACORRHI(INDEXLRN−1)−DELTAHIMAX
In this manner, LIMLOWER is equal to the next lowest correction value in the table, minus DELTAHIMAX. In step 548, control calculates LIMUPPER according to the following equation:
LIMUPPER=ACORRHI(INDEXLRN+1)+DELTAHIMAX
In this manner, LIMUPPER is equal to the next highest correction value in the table, plus DELTAHIMAX.
Referring now to
In step 612, control determines whether FLAGCOMBP is equal to TRUE. If FLAGCOMBP is equal to TRUE, control continues in step 614. If FLAGCOMBP is not equal to TRUE, control continues in step 616. In step 614, control determines LIMAIRLRNPOS according to the following equation:
LIMAIRLRNPOS=MIN(LIMAIRLRNPOSLO,LIMAIRLRNPOSHI)
In step 618, control determines LIMAIRLRNNEG according to the following equation:
LIMAIRLRNNEG=MAX(LIMAIRLRNNEGLO,LIMAIRLRNNEGHI)
In step 616, control determines whether the throttle is operating in the HI region. If the throttle is operating in the HI region, control continues in step 620. If the throttle is not operating in the HI region, control continues in step 622. In step 620, control sets LIMAIRLRNPOS equal to LIMAIRLRNPOSHI. In step 624, control sets LIMAIRLRNNEG equal to LIMAIRLRNNEGHI. In step 622, control sets LIMAIRLRNPOS equal to LIMAIRLRNPOSLO. In step 626, control sets LIMAIRLRNNEG equal to LIMAIRLRNNEGLO.
In step 628, control determines whether MODLRN is greater than or equal to LIMAIRLRNPOS. If MODLRN is greater than or equal to LIMAIRLRNPOS, control limits MODLRN by setting MODLRN equal to LIMAIRLRNPOS in step 630. If MODLRN is not greater than or equal to LIMAIRLRNPOS, control determines whether MODLRN is less than or equal to LIMAIRLRNNEG in step 632. If MODLRN is less than or equal to LIMAIRLRNNEG, control limits MODLRN by setting MODLRN equal to LIMAIRLRNNEG in step 634. If MODLRN is less than or equal to LIMAIRLRNNEG, control continues in step 636. In step 636, control updates the look-up table based on INDEXLRN and MODLRN. If operating in the LO region, the LO region look-up table is updated. If operating in the HI region, the HI region look-up table is updated. If INDEXLRN is a common index or break point, both the LO region and HI region look-up tables are updated.
Referring now to
In step 704, control determines INDEXLRN from the HI region look-up table. In step 714, control determines RES, from the HI region residual look-up table based on INDEXLRN. In this case, INDEXLRN is not rounded to the nearest index to permit control to examine table values immediately above and below INDEXLRN. In step 716, control determines RES2 from the HI region residual look-up table based on INDEXLRN plus one (i.e., the next higher index). In step 718 control determines CORR1 from a HI region correction look-up table based on INDEXLRN. Control determines CORR2 from the HI region correction look-up table based on INDEXLRN plus one (i.e., the next higher index) in step 720.
In step 722, control determines whether barometer update conditions have been met. The barometer update conditions include, but are not limited to, the distance since the last unthrottled barometer update being above a threshold, CORR1 and CORR2 being not equal zero, and both RES, and RES2 being less than a barometer update enable threshold. If the barometer update conditions are met, control enables a barometer update routine in step 724 and control ends. If the barometer update conditions are not met, control inhibits the barometer update routine in step 726 and control ends. In this manner, the throttle control system checks both the residual look-up table and the correction look-up table to ensure that airflow variation has been learnt and sufficiently compensated before enabling a partial-throttle barometer update.
The throttle control system of the present invention provides the capability to perform airflow learning and retrieval in both the LO region and the HI region using limits tailored to each region. Another advantage includes expanded MAF table ranges and an expanded MAP based airflow versus MAF based airflow correlation test. The throttle control system further includes the ability to simultaneously learn common break points or indices in both the LO region and HI region look-up tables and uses smaller magnitude limiting at the common index. Further, the throttle control system resets or clears all four look-up tables (i.e., LO/HI region correction look-up tables and LO/HI region residual look-up tables) on initialization if any table sized is wrong.
The throttle control system of the present invention also implements a dual store for the correction term (i.e., ACORRDUAL) to increase security and protection against memory corruption and allow higher correction ability by always picking the minimum of the rate limited correction term and the non-rate limited dual store correction term. By using stored residuals airflow variation is reduced to enable part-throttle barometer updates.
Those skilled in the art can now appreciate from the foregoing description that the broad teachings of the present invention can be implemented in a variety of forms. Therefore, while this invention has been described in connection with particular examples thereof, the true scope of the invention should not be so limited since other modifications will become apparent to the skilled practitioner upon a study of the drawings, the specification and the following claims.
Number | Name | Date | Kind |
---|---|---|---|
4227507 | Takase et al. | Oct 1980 | A |
4577603 | Murakami et al. | Mar 1986 | A |
4640254 | Ninomiya | Feb 1987 | A |
6390055 | Sivashankar et al. | May 2002 | B1 |
6698398 | Bauerle | Mar 2004 | B2 |
Number | Date | Country |
---|---|---|
61-123731 | Jun 1986 | JP |