The present invention relates to a control system for a throttle valve actuating device for actuating a throttle valve of an internal combustion engine, and more particularly to a control system having a function for determining abnormality of the throttle valve actuating device.
In a throttle valve actuating device including a motor for actuating a throttle valve and configured so that the throttle valve is biased to be maintained at a fully-closed position when an electric current is not supplied to the motor, a method for detecting an abnormality such that the throttle valve does not normally operate is disclosed in Japanese Patent Publication No. 2538731.
According to this method shown in this publication, it is determined that there is an abnormality, when the throttle valve opening detected by a throttle opening sensor is not in the vicinity of a fully-closed opening in the condition where the electric current supply to the motor is stopped.
In the above conventional method, the abnormality determination is performed in the condition where the current supply to the motor is stopped. Accordingly, the opportunity for executing the abnormality determination is limited so that the detection of abnormality may sometimes be delayed.
It is accordingly an object of the present invention to provide a control system for a throttle valve actuating device, which can quickly perform the abnormality determination of the throttle valve actuating device.
To achieve the above object, the present invention provides a control system for a throttle valve actuating device (10) having a throttle valve (3) of an internal combustion engine (1) and actuating means (6) for actuating the throttle valve (3). The control system includes control means (21), identifying means (22), and abnormality determining means. The control means (21) controls an opening (TH) of the throttle valve (3) to a target opening (THR) based on a controlled object model obtained by modeling the throttle valve actuating device (10). The identifying means (22) identifies model parameters (a1″, a2″, b1″, c1″) of the controlled object model. The identifying means (22) identifies a specific model parameter (c1″) irrelevant to an input (DUT) and an output (DTH) of the controlled object model. The abnormality determining means determines that the throttle valve actuating device (10) is abnormal when the value of the specific model parameter (c1″) becomes greater than a predetermined value (C1STICK).
With this configuration, when the value of the model parameter, which is irrelevant to the input and output of the controlled object model, identified by the identifying means becomes greater than the predetermined value, it is determined that the throttle valve actuating device is abnormal. Accordingly, the abnormality determination can be executed during normal operation of the throttle valve, and an abnormality can be quickly detected when it occurs.
Preferably, the abnormality determining means determines that movement of the throttle valve (3) is impeded when the absolute value of the specific model parameter (c1″) continues to be greater than a first predetermined value (C1STICK) for a first predetermined period (TMSTICK) or more.
Preferably, the throttle valve actuating device (10) further includes first biasing means (4) for biasing the throttle valve (3) in a valve closing direction and second biasing means (5) for biasing the throttle valve (3) in a valve opening direction. The opening (TH) of the throttle valve (3) is maintained at a predetermined retention opening (THDEF) when the throttle valve (3) is not actuated by the actuating means (6).
Preferably, the abnormality determining means determines that the first biasing means (4) is abnormal when the opening (TH) of the throttle valve (3) is greater than the predetermined retention opening (THDEF), a parameter (SGMABSAVE) indicative of a control deviation is less than a predetermined deviation (SGMRTSPNG), and the value of the specific model parameter (c1″) continues to be greater than a second predetermined value (C1RTNSP) for a second predetermined period (TMRTSPNG) or more.
Preferably, the abnormality determining means determines that the second biasing means (5) is abnormal when the opening (TH) of the throttle valve (3) is less than the predetermined retention opening (THDEF), a parameter (SGMABSAVE) indicative of a control deviation is less than a predetermined deviation (SGMRTSPNG), and the value of the specific model parameter (c1″) continues to be greater than a second predetermined value (C1RTNSP) for a second predetermined period (TMRTSPNG) or more.
The preferred embodiments of the present invention will be described with reference to the drawings.
The motor 6 is connected to an electronic control unit (hereinafter referred to as “ECU”) 7. The operation of the motor 6 is controlled by the ECU 7. The throttle valve 3 is associated with a throttle valve opening sensor 8 for detecting the throttle valve opening TH. A detected signal from the throttle valve opening sensor 8 is supplied to the ECU 7.
Further, the ECU 7 is connected to an acceleration sensor 9 for detecting a depression amount ACC of an accelerator pedal to detect an output demanded by the driver of the vehicle on which the engine 1 is mounted. A detected signal from the acceleration sensor 9 is supplied to the ECU 7.
The ECU 7 has an input circuit, an A/D converter, a central processing unit (CPU), a memory circuit, and an output circuit. The input circuit is supplied with detected signals from the throttle valve opening sensor 8 and the acceleration sensor 9. The A/D converter converts input signals into digital signals. The CPU carries out various process operations. The memory circuit has a ROM (read only memory) for storing processes executed by the CPU, and maps and tables that are referred to in the processes, a RAM for storing results of executing processes by the CPU. The output circuit supplies an energizing current to the motor 6. The ECU 7 determines a target opening THR of the throttle valve 3 according to the depression amount ACC of the accelerator pedal, determines a control quantity DUT for the motor 6 in order to make the detected throttle valve opening TH coincide with the target opening THR, and supplies an electric signal according to the control quantity DUT to the motor 6.
The control quantity DUT indicates a polarity and a duty ratio of the electric signal supplied to the motor 6. Therefore, the control quantity DUT is also referred to as “duty ratio”. When the throttle valve opening TH is greater than the default opening THDEF, the control quantity DUT takes a positive value so that the motor 6 generates an actuating force for actuating the throttle valve 3 in the opening direction. When the throttle valve opening TH is less than the default opening THDEF, the control quantity DUT takes a negative value so that the motor 6 generates an actuating force for actuating the throttle valve 3 in the closing direction.
In the present embodiment, a throttle valve actuating device 10 that includes the throttle valve 3, the return spring 4, the default spring 5, and the motor 6 is a controlled object. An input to be applied to the controlled object is the duty ratio DUT of the electric signal applied to the motor 6. An output from the controlled object is the throttle valve opening TH detected by the throttle valve opening sensor 8.
A model defined by the equation (1) shown below is set as a controlled object model according to the frequency response characteristics of the throttle valve actuating device 10. It has been confirmed that the frequency response characteristics of the model can be approximated to the characteristics of the throttle valve actuating device 10.
where “n” is a parameter representing a discrete sampling time or a discrete control time which is digitized with an identification period ΔTID, and DTH(n) is a throttle valve opening deviation amount defined by the equation (2) shown below. Further, a1, a2, b1, and c1 are model parameters determining the characteristics of the controlled object model, and d is a dead time. The dead time d is a delay between the input and output of the controlled object model.
DTH(n)=TH(n)−THDEF (2)
where TH is a detected throttle valve opening, and THDEF is the default opening.
In this embodiment, “n” which is indicative of a sampling time or a control time corresponding to the identification period ΔTID is used as a discrete time for defining the controlled object model. The time interval of calculating and outputting the control input DUT is set to a control period ΔTCTL which is shorter than the identification period ΔTID. The control period TCTL is set to, for example, one fifth of the identification period ΔTID. The discrete time corresponding to the control period ΔTCTL will be indicated by “k” in the following description. The reason why the identification period ΔTID is set to a period which is longer than the control period ΔTCTL is as follows: if the model parameters are identified based on data sampled at intervals of a relatively short sampling period compared with the change rate (change period) of the output of the controlled object model, then the accuracy of the identified model parameters becomes greatly lowered, and the performance of adapting to variations and aging of the characteristics of the controlled object becomes insufficient.
For reducing the amount of calculations, it is effective to define a controlled object model by the equation (1a) shown below where the dead time d is set to “0”. A modeling error (a difference between the characteristics of the controlled object model and the characteristics of an actual controlled object (plant)) caused by setting the dead time d to “0”, is compensated by employing a sliding mode controller having robustness. “Robustness” of a control system means that control performance or control stability of the control system is not easily deteriorated even when the characteristics of the controlled object or disturbances change largely compared with an ordinary condition.
In the equation (1a), the model parameter c1 which is irrelevant to the input and output of the controlled object, is employed in addition to the model parameters a1 and a2 which are relevant to the throttle valve opening deviation amount DTH which is the output of the controlled object, and the model parameter b1 which is relevant to the input duty ratio DUT which is the input of the controlled object. The model parameter c1 is a parameter representing a deviation amount of the default opening THDEF and disturbance applied to the throttle valve actuating device 10. In other words, the default opening deviation amount and the disturbance can be identified by identifying the model parameter c1 simultaneously with the model parameters a1, a2, and b1 by a model parameter identifier described below.
The adaptive sliding mode controller 21 calculates a duty ratio DUT according to an adaptive sliding mode control in order to make the detected throttle valve opening TH coincide with the target opening THR, and outputs the calculated duty ratio DUT.
By using the adaptive sliding mode controller 21, it is possible to change (specify) the response characteristics of the throttle valve opening TH to the target opening THR, using a specific parameter (a switching function setting parameter VPOLE to be described later). As a result, an optimum response characteristic can be specified according to the throttle valve opening TH. For example, it is possible to avoid shocks at the time the throttle valve 3 moves from an open position to a fully closed position, i.e., at the time the throttle valve 3 collides with a stopper for stopping the throttle valve 3 at the fully closed position. It is also possible to make the engine response corresponding to the operation of the accelerator pedal variable. Further, the sliding mode control makes it possible to obtain a good stability against errors of the model parameters.
The model parameter identifier 22 calculates a corrected model parameter vector θL (θLT=[a1, a2, b1, c1]) and supplies the calculated corrected model parameter vector θL to the adaptive sliding mode controller 21. More specifically, the model parameter identifier 22 calculates a model parameter vector θ based on the throttle valve opening TH and the duty ratio DUT. The model parameter identifier 22 then carries out a first limit process, an oversampling and moving-averaging process, and a second limit process of the model parameter vector θ to calculate a corrected model parameter vector θL. The corrected model parameter vector θL is supplied to the adaptive sliding mode controller 21. In this manner, the model parameters a1, a2, and b1 which are optimum for making the throttle valve opening TH follow up the target opening THR are obtained, and also the model parameter c1 indicative of disturbance and a deviation amount of the default opening THDEF is obtained. The first limit process, the oversampling and moving-averaging process, and the second limit process will be described later.
By using the model parameter identifier 22 for identifying the model parameters on a real-time basis, adaptation to changes in engine operating conditions, compensation for hardware characteristics variations, compensation for power supply voltage fluctuations, and adaptation to aging-dependent changes of hardware characteristics are possible.
The model parameter scheduler 25 calculates a reference model parameter vector θbase (θbaseT=[a1base, a2base, b1base, c1base]) according to a target value DTHR which is defined as a deviation amount between a target opening THR(n) and the default opening THDEF by the following equation (3), the calculated reference model parameter vector θbase is supplied to the model parameter identifier 22. The calculation of the reference model parameter vector θbase is executed at intervals of the identification period ΔTID.
DTHR(n)=THR(n)−THDEF (3)
The subtractor 26 calculates a deviation amount between the default opening THDEF and the throttle valve opening TH as the throttle valve opening deviation amount DTH, and the subtractor 27 calculates a deviation amount between the default opening THDEF and the target opening THR as the target value DTHR (see the equations (2) and (3)).
Principles of operation of the adaptive sliding mode controller 21 will be described below.
If a deviation e(n) between the throttle valve opening deviation amount DTH and the target value DTHR is defined by the following equation (4), then a switching function value σ(n) of the adaptive sliding mode controller is set by the following equation (5).
e(n)=DTH(n)−DTHR(n) (4)
where VPOLE is a switching function setting parameter that is set to a value greater than “−1” and less than “1”.
On a phase plane defined by a vertical axis representing a deviation e(n) and a horizontal axis representing a preceding deviation e(n−1), a pair of the deviation e(n) and the preceding deviation e(n−1) satisfying the equation of “σ(n)=0” represents a straight line. The straight line is generally referred to as a switching straight line. A sliding mode control is a control contemplating the behavior of the deviation e(n) on the switching straight line. The sliding mode control is carried out so that the switching function value σ(n) becomes “0”, i.e., the pair of the deviation e(n) and the preceding deviation e(n−1) exists on the switching straight line on the phase plane, to thereby achieve a robust control against disturbance and the modeling error. As a result, the throttle valve opening deviation amount DTH is controlled with good robustness to follow up the target value DTHR.
By changing the value of the switching function setting parameter VPOLE in the equation (5), it is possible to change a damping characteristic of the deviation e(n), i.e., the follow-up characteristic of the throttle valve opening deviation amount DTH to follow up the target value DTHR. Specifically, if VPOLE equals “−1”, then the throttle valve opening deviation amount DTH completely fails to follow up the target value DTHR. As the absolute value of the switching function setting parameter VPOLE is reduced, the speed at which the throttle valve opening deviation amount DTH follows up the target value DTHR increases. Since the sliding mode controller is capable of specifying the damping characteristic of the deviation e(n) as a desired characteristic, the sliding mode controller is referred to as a response-specifying controller.
According to the sliding mode control, the converging speed can easily be changed by changing the switching function setting parameter VPOLE. Therefore, in the present embodiment, the switching function setting parameter VPOLE is set according to the throttle valve opening deviation amount DTH to obtain a response characteristic suitable for the operating condition of the throttle valve 3.
As described above, according to the sliding mode control, the deviation e(n) is converged to “0” at an indicated speed and robustly against disturbance and the modeling error by constraining the pair of the deviation e(n) and the preceding deviation e(n−1) on the switching straight line (the pair of e(n) and e(n−1) will be referred to as “deviation state quantity”). Therefore, in the sliding mode control, it is important how to place the deviation state quantity onto the switching straight line and constrain the deviation state quantity on the switching straight line.
From the above standpoint, an input DUT(k) (also indicated as Usl(k)) to the controlled object (an output of the controller) is basically calculated as a sum of an equivalent control input Ueq(k), a reaching law input Urch(k), an adaptive law input Uadp(k), a nonlinear input Unl(k), and a damping input Udamp(k) by the following equation (6).
The equivalent control input Ueq(k) is an input for constraining the deviation state quantity on the switching straight line. The reaching law input Urch(k) is an input for placing the deviation state quantity onto the switching straight line. The adaptive law input Uadp(k) is an input for placing the deviation state quantity onto the switching straight line while reducing the modeling error and the effect of disturbance.
The nonlinear input Unl(k) is an input for suppressing a nonlinear modeling error due to backlash of speed reduction gears for actuating the valve body of the throttle valve 3, and placing the deviation state quantity onto the switching straight line. The damping input Udamp is an input for preventing the throttle valve opening deviation amount DTH from overshooting with respect to the target value DTHR.
Methods of calculating these inputs Ueq(k), Urch(k), Uadp(k), Unl(k), and Udamp(k) will be described below.
Since the equivalent control input Ueq(k) is an input for constraining the deviation state quantity on the switching straight line, a condition to be satisfied is given by the following equation (7).
σ(n)=σ(n+1) (7)
Using the equations (1), (4), and (5), the duty ratio DUT(n) satisfying the equation (7) is determined by the equation (8) shown below. The duty ratio DUT(n) calculated with the equation (8) represents the equivalent control input Ueq(n).
Since it is actually difficult to obtain a future value DTHR(n+1) of the target value, the equivalent control input Ueq(n) is calculated by the following equation (8a) from which the term relative to the target value DTHR is removed. Further, in the equation (8a), the discrete time “n” is replaced with the discrete time “k”.
where k0 represents a ratio of the identification period ΔTID and the control period ΔTCTL (ΔTID/ΔTCTL, e.g., “5”).
The reaching law input Urch(n) and the adaptive law input Uadp(n) are defined by the respective equations (9) and (10) shown below.
where F and G represent respectively a reaching law control gain and an adaptive law control gain, which are set so that the deviation state quantity can stably be placed onto the switching straight line. Further, σ(k) corresponds to the switching function value σ(n), and is expressed by using the discrete time “k” instead of “n”. The switching function value σ(k) is defined by the equation (5a) shown below.
The nonlinear input Unl is calculated by the equation (11) shown below.
Unl(k)=−Knl×sgn(σ(k))/b1 (11)
where sgn(σ(k)) represents a sign function whose value equals “1” when σ (k) has a positive value, and equals “−1” when σ(k) has a negative value. Knl is a nonlinear input gain which is set according to the throttle valve opening deviation amount DTH.
By using the nonlinear input Unl(k), the convergence of the steady deviation is prevented from being delayed, when the target value DTHR is slightly changing.
The damping input Udamp is calculated by the equation (13) shown below.
Udamp=−Kdamp(DTH(k)−DTH(k−1))/b1 (13)
where Kdamp is a damping control gain which is calculated by the equation (14) shown below.
Kdamp=Kdampbs×Kkdamp (14)
where Kdampbs is a basic value which is set according to the throttle valve opening deviation amount DTH. Kkdamp is a correction coefficient which is calculated according to a moving average value DDTHRAV of amounts of change in the target value DTHR.
The moving average value DDTHRAV is calculated by the following equation (15):
where iAV represents a number that is set to “50”, for example.
As described above, the equivalent control input Ueq(k), the reaching law input Urch(k), the adaptive law input Uadp(k), the nonlinear input Unl(k), and the damping input Udamp(k) are calculated, and the duty ratio DUT(k) is calculated as a sum of those inputs.
Principles of operation of the model parameter identifier 22 will be described below.
The model parameter identifier 22 calculates a model parameter vector of the controlled object model, based on the input (DUT(n)) and output (TH(n)) of the controlled object, as described above. Specifically, the model parameter identifier 22 calculates a model parameter vector θ(n) according to a sequential identifying algorithm (generalized sequential method-of-least-squares algorithm) represented by the following equation (16).
θ(n)=θ(n−1)+KP(n)ide(n) (16)
θ(n)T=[a1″,a2″,b1″,c1″] (17)
where a1″, a2″, b1″, and c1″ represent model parameters before a first limit process, described later, is carried out, ide(n) represents an identifying error defined by the equations (18), (19), and (20) shown below, where DTHHAT(n) represents an estimated value of the throttle valve opening deviation amount DTH(n) (hereinafter referred to as “estimated throttle valve opening deviation amount”) which is calculated using the latest model parameter vector θ(n−1), and KP(n) represents a gain coefficient vector defined by the equation (21) shown below. In the equation (21), P(n) represents a quartic square matrix calculated by the equation (22) shown below.
ide(n)=DTH(n)−DTHHAT(n) (18)
DTHHAT(n)=θ(n−1)Tζ(n) (19)
ζ(n)T=[DTH(n−1), DTH(n−2), DUT(n−1), 1] (20)
In accordance with the setting of coefficients λ1 and λ2 in the equation (22), the identifying algorithm from the equations (16) through (22) becomes one of the following four identifying algorithm:
If the fixed gain algorithm is used to reduce the amount of calculations, then the equation (21) is simplified into the following equation (21a) where P represents a square matrix with constants as diagonal elements.
There are situations where model parameters calculated from the equations (16) through (20), and (21a) gradually shifts from desired values. Specifically, if a residual identifying error caused by nonlinear characteristics such as friction characteristics of the throttle valve exists after the model parameters have been converged to a certain extent, or if a disturbance whose average value is not zero is steadily applied, then the residual identifying errors are accumulated, causing a drift in the model parameter. To prevent such a drift of the model parameters, the model parameter vector θ(n) is calculated by the following equation (16a) instead of the equation (16).
where DELTA represents a forgetting coefficient matrix in which the forgetting coefficient δi (i=1 through 3) and “1” are diagonal elements and other elements are all “0”, as shown by the following equation (23).
The forgetting coefficient δi is set to a value between “0” and “1” (0<δi<1) and has a function to gradually reduce the effect of past identifying errors. In the equation (23), the coefficient which is relevant to the calculation of the model parameter c1″ is set to “1”, holding the effect of past values. By setting one of the diagonal elements of the forgetting coefficient matrix DELTA, i.e., the coefficient which is relevant to the calculation of the model parameter c1″, to “1”, it is possible to prevent a steady deviation between the target value DTHR and the throttle valve opening deviation amount DTH. The model parameters are prevented from drifting by setting other elements δ1, δ2, and δ3 of the forgetting coefficient matrix DELTA to a value which is greater than “0” and less than “1”.
When the equation (16a) is rewritten into a recursive form, the following equations (16b) and (16c) are obtained. A process of calculating the model parameter vector θ(n) using the equations (16b) and (16c) rather than the equation (16) is hereinafter referred to as “δ correcting method”, and dθ(n) defined by the equation (16c) is referred to as “updating vector”.
θ(n)=θ(0)+dθ(n) (16b)
dθ(n)=DELTA·dθ(n−1)+KP(n)ide(n) (16c)
According to an algorithm using the δ correcting method, in addition to the drift preventing effect, a model parameter stabilizing effect can be obtained. Specifically, an initial vector θ(0) is maintained at all times, and values which can be taken by the elements of the updating vector dθ(n) are limited by the effect of the forgetting coefficient matrix DELTA. Therefore, the model parameters can be stabilized in the vicinity of their initial values.
Furthermore, since model parameters are calculated while adjusting the updating vector dθ(n) according to identifying process based on the input and output data of the actual controlled object, it is possible to calculate model parameters that match the actual controlled object.
It is preferable to calculate the model parameter vector θ(n) from the following equation (16d) which uses a reference model parameter vector θ base instead of the initial vector θ(0) in the equation (16b).
θ(n)=θbase+dθ(n) (16d)
The reference model parameter vector θbase is set according to the target value DTHR by the model parameter scheduler 25. Consequently, the reference model parameter vector θbase can be adapted to changes in the dynamic characteristics which correspond to changes in the throttle valve opening TH.
Further, in the present embodiment, the identifying error ide(n) is subjected to a low-pass filtering. Specifically, when model parameters are identified by the model parameter identifier 22 with respect to the controlled object which has low-pass characteristics (characteristics of attenuating high-frequency components), the identified model parameters are largely affected by the high-frequency-rejection characteristics, so that the gain of the controlled object model becomes lower than actual characteristics in a low-frequency range. As a result, the sliding mode controller 21 excessively corrects the control input.
Therefore, according to the low-pass filtering, the frequency characteristics of the controlled object are changed to coincide with the actual frequency characteristics, or the low frequency gain of the controlled object model is corrected to a level which is slightly higher than the actual gain. Accordingly, it is possible to prevent the control input from being excessively corrected by the sliding mode controller 21, to thereby improve the robustness of the control system and further stabilize the control system.
The low-pass filtering is carried out by storing past values ide(n−i) of the identifying error (e.g., 10 past values for i=1 through 10) in a ring buffer, multiplying the past values by weighting coefficients, and adding the products of the past values and the weighting coefficients.
When the identifying error which has been subjected to the low-pass filtering is represented by idef(n) as shown in the equation (30) shown below, then the updating vector dθ(n) is calculated from the following equation (16e) instead of the equation (16c).
idef(n)=LF(ide(n)) (30)
dθ(n)=DELTA×dθ(n−1)+KP(n)idef(n) (16e)
As described above, the adaptive sliding mode controller 21, the model parameter identifier 22, and the model parameter scheduler 25 is constructed based on the model which is modeled with a sampling period (control period) that is equal to the identification period ΔTID. Accordingly, the model parameter identifier 22 identifies the model parameter vector θ at intervals of the identification period ΔTID, and the model parameter scheduler 25 calculates the reference model parameter vector θbase at intervals of the identification period ΔTID. It should be noted that the adaptive sliding mode controller calculates a control input at intervals of the control period ΔTCTL.
When employing the above calculation timings, the period of updating model parameters which are used to calculate the control input DUT becomes longer than the period of updating the control input DUT by the controller 21. As a result, the period of updating model parameters affects the control input DUT, which may possibly cause resonance in the control system.
Therefore, in the present embodiment, such resonance in the control system is prevented by sampling (oversampling) model parameters which are identified at intervals of the identification period ΔTID, at intervals of the control period ΔTCTL, storing the sampled data in a ring buffer, and using values obtained by effecting a moving-averaging process on the data stored in the ring buffer as model parameters for the control.
The elements a1″, a2″, b1″, and c1″ of the model parameter vector θ(n) calculated by the equation (16d) are subjected to a limit process described below in order to improve robustness of the control system.
If the model parameter b1″ falls outside a range between an upper limit value XIDB1H and a lower limit value XIDB1L, then a limit process is performed to change the model parameter b1″ to the upper limit value XIDB1H or the lower limit value XIDB1L. If the model parameter c1″ falls outside of a range between an upper limit value XIDC1H and a lower limit value XIDC1L, then a limit process is performed to change the model parameter c1″ to the upper limit value XIDC1H or the lower limit value XIDC1L.
A set of the above limit processes (first limit process) is expressed by the equation (31) shown below. θ*(n) represents the limited model parameter vector, whose elements are expressed by the equation (32) shown below.
θ*(n)=LMT(θ(n)) (31)
θ*(n)T=[a1*(n), a2*(n), b1*(n), c1*(n)] (32)
In the control system disclosed in International Patent Publication No. WO 02/086630, the preceding updating vector dθ(n−1) which is used to calculate the updating vector dθ(n) from the equation (16e) and the preceding model parameter vector θ(n−1) which is used to calculate the estimated throttle valve opening deviation amount DTHHAT(k) includes model parameters that are not subjected to the limit process. In the present embodiment, a vector calculated by the equation (33) shown below is used as the preceding updating vector dθ(n−1), and a limited model parameter vector θ*(n−1) is used as the preceding model parameter vector which is used to calculate the estimated throttle valve opening deviation amount DTHHAT(k), as shown by the following equation (19a).
dθ(n−1)=θ*(n−1)−θbase(n−1) (33)
DTHHAT(n)=θ*(n−1)Tζ(n) (19a)
The reasons for the above process are described below.
If a point corresponding to coordinates determined by the model parameters a1″ and a2″ (hereinafter referred to as “model parameter coordinates”) is located at a point PA1 shown in
Therefore, in the present embodiment, the limited model parameter vector θ*(n−1) is applied to the equations (33) and (19a) to calculate the present model parameter vector θ(n).
A model parameter vector θ*(k) obtained at time k by oversampling the model parameter vector θ*(n) after the first limit process is expressed by the following equation (32a).
θ*(k)T=[a1*(k), a2*(k), b1*(k), c1*(k)] (32a)
When a model parameter vector θ′(k) obtained by moving-averaging of the oversampled model parameter vector θ*(k) is expressed by the following equation (32b), then elements a1′(k), a2′(k), b1′(k), and c1′(k) of the model parameter vector θ′(k) are calculated by the following equations (34) through (37).
θ′(k)T=[a1′(k), a2′(k), b1′(k), c1′(k)] (32b)
where (m+1) represents the number of data which are subjected to the moving-averaging, and “m” is set to “4”, for example.
Then, as shown by the equation (38) described below, the model parameter vector θ′(k) is subjected to a limit process (second limit process) similar to the above limit process, thus calculating a corrected model parameter vector θL(k) expressed by the equation (39) shown below, because the model parameter a1′ and/or the model parameter a2′ may change so that a point corresponding to the model parameters a1′ and a2′ moves out of the stable region shown in
θL(k)=LMT(θ′(k)) (38)
θL(k)T=[a1, a2, b1, c1] (39)
Processes executed by the CPU of the ECU 7 for realizing the above functions of the controller 21, the model parameter identifier 22, and the model parameter scheduler 25 will be described below.
In step S11, a process of setting a state variable shown in
In step S12, it is determined whether or not the value of a counter IDCOUNT is “0”. Since the counter IDCOUNT is initially set to “0”, the process proceeds from step S12 to step S14, in which a process of identifying a model parameter shown in
In step S16, the counter IDCOUNT is set to the predetermined number N. Therefore, in the next execution of this process, the answer to step S12 becomes negative (NO), and the value of the counter IDCOUNT is decremented by “1” in step S13. Thereafter, the process proceeds to step S17. Therefore, steps from S14 to S16 are carried out once in every N times.
In step S17, a model parameter vector θ′(k) is calculated by the moving-averagimg of the limited model parameter vector θ*(n). Specifically, the model parameter stored in the ring buffer is applied to the equations (34) through (37) to calculate model parameters a1′(k), a2′(k), b1′(k), and c1′(k).
In step S18, a second limit process shown in
In step S19, a process of calculating a control input Usl(k) shown in
In step S20, a process of stability determination of the sliding mode controller shown in
In step S21, a process of abnormality determination shown in
In step S41, the gain coefficient vector KP(n) is calculated from the equation (21a). Then, the estimated throttle valve opening deviation amount DTHHAT(n) is calculated from the equation (19a) in step S42.
In step S43, a process of calculating ide(n) shown in
In step S46, the model parameter vector θ(n) is calculated from the equation (16d). Thereafter, the process shown in
In step S51, the identifying error ide(n) is calculated from the equation (18). Then, it is determined whether or not the value of a counter CNTIDST which is incremented in step S53 is greater than a predetermined value XCNTIDST that is set according to the dead time d of the controlled object (step S52). XCNTIDST is set to “2”, since the dead time d is approximated to “0” in the present embodiment. Since the counter CNTIDST has an initial value of “0”, the process first proceeds to step S53, in which the counter CNTIDST is incremented by “1”. Next, the identifying error ide(n) is set to “0” in step S54, and the process proceeds to step S55. Immediately after the identification of the model parameter vector θ(n) starts, no correct identifying error is obtained by the calculation of the equation (18). Therefore, the identifying error ide(n) is set to “0” by steps S52 through S54, without using the calculated result of the equation (18).
If the answer to the step S52 is affirmative (YES), the process immediately proceeds to step S55.
In step S55, the identifying error ide(n) is subjected to a low-pass filtering process. Specifically, a process of correcting the frequency characteristics of the controlled object model is carried out.
In step S56, it is determined whether or not the identifying error ide(n) is greater than a predetermined upper limit value IDEMAX (e.g., “0.2”). If ide(n) is greater than IDEMAX, the identifying error ide(n) is set to the predetermined upper limit value IDEMAX (step S57).
If ide(n) is less than or equal to IDEMAX in step S56, it is further determined whether or not the identifying error ide(n) is less than a predetermined lower limit value IDEMIN (e.g., “−0.15”) in step S58. If ide(n) is less than IDEMIN, the identifying error ide(n) is set to the predetermined lower limit value IDEMIN (step S59). If the answer to step S58 is negative, this process immediately ends.
In step S71, flags FA1STAB, FA2STAB, FB1LMT, and FC1LMT used in this process are initialized by setting each flag to “0”. In step S72, the limit process of the model parameters a1″ and a2″ shown in
In
In step S81, it is determined whether or not the model parameter a2″ is greater than or equal to a predetermined a2 lower limit value XIDA2L. The predetermined a2 lower limit value XIDA2L is set to a negative value greater than “−1”. Stable model parameters a1* and a2* are obtained when setting the predetermined a2 lower limit value XIDA2L to “−1”. However, the predetermined a2 lower limit value XIDA2L is set to a negative value greater than “−1” because the matrix A defined by the equation (40) to the “n”th power may occasionally become unstable (which means that the model parameters a1″ and a2″ do not diverge, but oscillate).
If a2″ is less than XIDA2L in step S81, then the model parameter a2* is set to the lower limit value XIDA2L, and an a2 stabilizing flag FA2STAB is set to “1” in step S82. When the a2 stabilizing flag FA2STAB is set to “1”, this indicates that the model parameter a2* is set to the lower limit value XIDA2L. In
If the answer to step S81 is affirmative (YES), i.e., if a2″ is greater than or equal to XIDA2L, then the model parameter a2* is set to the model parameter a2″ in step S83.
In steps S84 and S85, it is determined whether or not the model parameter a1″ is in a range defined by a predetermined a1 lower limit value XIDA1L and a predetermined a1 upper limit value XIDA1H. The predetermined a1 lower limit value XIDA1L is set to a value which is equal to or greater than “−2” and less than “0”, and the predetermined a1 upper limit value XIDA1H is set to 2, for example.
If the answers to steps S84 and S85 are affirmative (YES), i.e., if a1″ is greater than or equal to XIDA1L and less than or equal to XIDA1H, then the model parameter a1* is set to the model parameter a1″ in step S88.
If a1″ is less than XIDA1L in step S84, then the model parameter a1* is set to the lower limit value XIDA1L and an a1* stabilizing flag FA1STAB is set to “1” in step S86. If a1″ is greater than XIDA1H in step S85, then the model parameter a1 is set to the upper limit value XIDA1H and the a1 stabilizing flag FA1STAB is set to “1” in step S87. When the a1 stabilizing flag FA1STAB is set to “1”, this indicates that the model parameter a1* is set to the lower limit value XIDA1L or the upper limit value XIDA1H. In
In step S90, it is determined whether or not the sum of the absolute value of the model parameter a1* and the model parameter a2* is equal to or less than a predetermined stability determining value XA2STAB. The predetermined stability determining value XA2STAB is set to a value close to “1” but less than “1” (e.g., “0.99”).
Straight lines L1 and L2 shown in
a2*+|a1*|=XA2STAB (41)
Therefore, in step S90, it is determined whether or not the combination of the model parameters a1* and a2* is placed at a position on or lower than the straight lines L1 and L2 shown in FIG. 11. If the answer to step S90 is affirmative (YES), then the limit process immediately ends, since the combination of the model parameters a1* and a2* is in the stable region shown in FIG. 11.
If the answer to step S90 is negative (NO), then it is determined whether or not the model parameter a1* is less than a value obtained by subtracting the predetermined a2 lower limit value XIDA2L from the predetermined stability determining value XA2STAB in step S91 (since XIDA2L is less than “0”, (XA2STAB−XIDA2L) is greater than XA2STAB). If the model parameter a1* is equal to or less than (XA2STAB−XIDA2L), then the model parameter a2* is set to (XA2STAB−|a1*|) and the a2 stabilizing flag FA2STAB is set to “1” in step S92.
If the model parameter a1* is greater than (XA2STAB−XIDA2L) in step S91, then the model parameter a1* is set to (XA2STAB−XIDA2L) in step S93. Further in step S93, the model parameter a2* is set to the predetermined a2 lower limit value XIDA2L, and the a1 stabilizing flag FA1STAB and the a2 stabilizing flag FA2STAB are set to “1”.
In
As described above, the limit process shown in
In steps S101 and S102, it is determined whether or not the model parameters b1″ is in a range defined by a predetermined b1 lower limit value XIDB1L and a predetermined b1 upper limit value XIDB1H. The predetermined b1 lower limit value XIDB1L is set to a predetermined positive value (e.g., “0.1”), and the predetermined b1 upper limit value XIDB1H is set to “1”, for example.
If the answer to steps S101 and S102 is affirmative (YES), i.e., if b1″ is greater than or equal to XIDB1L and less than or equal to XIDB1H, then the model parameter b1* is set to the model parameter b1″ in step S105.
If b1″ is less than XIDB1L in step S101, then the model parameter b1* is set to the lower limit value XIDB1L, and a b1 limiting flag FB1LMT is set to “1” in step S104. If b1″ is greater than XIDB1H in step S102, then the model parameter b1* is set to the upper limit value XIDB1H, and the b1 limiting flag FB1LMT is set to “1” in step S103. When the b1 limiting flag FB1LMT is set to “1”, this indicates that the model parameter b1* is set to the lower limit value XIDB1L or the upper limit value XIDB1H.
In steps S111 and S112, it is determined whether or not the model parameters c1″ is in a range defined by a predetermined c1 lower limit value XIDC1L and a predetermined c1 upper limit value XIDC1H. The predetermined c1 lower limit value XIDC1L is set to “−60”, for example, and the predetermined c1 upper limit value XIDC1H is set to “60”, for example.
If the answer to steps S111 and S112 is affirmative (YES), i.e., if c1″ is greater than or equal to XIDC1L and less than or equal to XIDC1H, then the model parameter c1* is set to the model parameter c1″ in step S115.
If c1″ is less than XIDC1L in step S111, then the model parameter c1* is set to the lower limit value XIDC1L, and a c1 limiting flag FC1LMT is set to “1” in step S114. If c1″ is greater than XIDC1H in step S112, then the model parameter c1* is set to the upper limit value XIDC1H, and the c1 limiting flag FC1LMT is set to “1” in step S113. When the c1 limiting flag FC1LMT is set to “1”, this indicates that the corrected model parameter c1 is set to the lower limit value XIDC1L or the upper limit value XIDC1H.
In step S201, a process of calculating a switching function value σ shown in
In step S208, it is determined whether or not the stability determination flag FSMCSTAB set in a process shown in
If FSMCSTAB is equal to “0” in step S208, indicating that the adaptive sliding mode controller 21 is stable, then the control inputs Ueq, Urch, Uadp, Unl, and Udamp calculated in steps S202 through S207 are added, thereby calculating the control input Usl in step S209.
If FSMCSTAB is equal to “1” in step S208, indicating that the adaptive sliding mode controller 21 is unstable, then the sum of the reaching law input Urch and the adaptive law input Uadp is calculated as the control input Usl. In other words, the equivalent control input Ueq, the nonlinear input Unl, and the damping input Udamp are not used for calculating the control input Usl, which prevents the control system from becoming unstable.
In steps S211 and S212, it is determined whether or not the calculated control input Usl is in a range defined by a predetermined upper limit value XUSLH and a predetermined lower limit value XUSLL. If the control input Usl is in this range, then the process shown in
In step S221, a VPOLE calculation process shown in
In steps S223 and 224, it is determined whether or not the calculated switching function value σ(k) is in a range defined by a predetermined upper limit value XSGMH and a predetermined lower limit value XSGML. If the calculated switching function value σ(k) is in this range, then the process shown in
In step S231 shown in
If FSMCSTAB is equal to “0”, indicating that the adaptive sliding mode controller 21 is stable, then a VPOLE table shown in
In steps S235 and S236, it is determined whether or not the calculated switching function setting parameter VPOLE is in a range defined by a predetermined upper limit value XPOLEH and a predetermined lower limit value XPOLEL. If the switching function setting parameter VPOLE is in this range, then the process shown in
In step S251, it is determined whether or not the switching function value σ is equal to or less than a predetermined lower limit value −XSGMSL. If σ is less than or equal to −XSGMSL, then a switching function parameter SGMS is set to the predetermined lower limit value −XSGMSL in step S252. If σ is greater than −XSGMSL, it is determined whether or not the switching function value σ is equal or greater than a predetermined upper limit value XSGMSL in step S253. If σ is greater than or equal to XSGMSL, then the switching function parameter SGMS is set to the predetermined upper limit value XSGMSL in step S254. If the switching function value σ falls between the predetermined lower limit value −XSGMSL and the predetermined upper limit value XSGMSL, then the switching function parameter SGMS is set to the switching function value σ in step S255.
The switching function value σ used in calculating the reaching law input Urch is limited in steps S251 through S255. The switching function parameter SGMS is a parameter corresponding to the limited switching function value σ. The limit process makes it possible to prevent the throttle valve opening deviation amount DTH from overshooting with respect to the target value DTHR when the target value DTHR changes abruptly.
In step S261, it is determined whether or not the stability determination flag FSMCSTAB is “1”. If the stability determination flag FSMCSTAB is “0”, indicating that the adaptive sliding mode controller 21 is stable, then the control gain F is set according to the switching function value σ (Step S262).
The reaching law input Urch is calculated according to the following equation (42) in step S263. The equation (42) is similar to the equation (9) except that the switching function value σ in the equation (9) is replaced with the switching function parameter SGMS.
Urch=−F×SGMS/b1 (42)
If the stability determination flag FSMCSTAB is “1”, indicating that the adaptive sliding mode controller 21 is unstable, then the control gain F is set to a predetermined stabilizing gain XKRCHSTB in step S264, and the reaching law input Urch is calculated according to the following equation (43), which does not include the model parameter b1, in step S265.
Urch=−F×SGMS (43)
In steps S266 and S267, it is determined whether or not the calculated reaching law input Urch is in a range defined by a predetermined upper limit value XURCHH and a predetermined lower limit value XURCHL. If the reaching law input Urch is in this range, then the process shown in
As described above, when the adaptive sliding mode controller 21 becomes unstable, the control gain F is set to the predetermined stabilizing gain XKRCHSTB, and the reaching law input Urch is calculated without using the model parameter b1, which brings the adaptive sliding mode controller 21 back to its stable state. When the identifying process carried out by the model parameter identifier 22 becomes unstable, the adaptive sliding mode controller 21 becomes unstable. Therefore, by using the equation (43) that does not include the model parameter b1 which has become unstable, the adaptive sliding mode controller 21 can be stabilized.
In step S271, it is determined whether or not the switching function value σ is equal to or less than a predetermined lower limit value −XSGMSL. If σ is less than or equal to −XSGMSL, then a switching function parameter SGMS is set to the predetermined lower limit value −XSGMSL in step S272. If σ is greater than −XSGMSL, it is determined whether or not the switching function value σ is equal or greater than a predetermined upper limit value XSGMSL in step S273. If σ is greater than or equal to XSGMSL, then the switching function parameter SGMS is set to the predetermined upper limit value XSGMSL in step S274. If the switching function value σ falls between the predetermined lower limit value −XSGMSL and the predetermined upper limit value XSGMSL, then the switching function parameter SGMS is set to the switching function value σ in step S275.
The switching function value σ used in calculating the adaptive law input Uadp is limited in steps S271 through S275. The switching function parameter SGMS is a parameter corresponding to the limited switching function value σ. The limit process makes it possible to prevent the throttle valve opening deviation amount DTH from overshooting with respect to the target value DTHR when the target value DTHR changes abruptly.
In step S276, it is determined whether or not the stability determination flag FSMCSTAB is “1”. If FSMCSTAB is equal to “0”, indicating that the adaptive sliding mode controller 21 is stable, then the control gain G is set according to the switching function value σ in step S279.
Then, the switching function parameter SGMS and the control gain G are applied to the equation (44) shown below to calculate an adaptive law input Uadp(k) in step S280. The equation (44) is similar to the equation (10) except that the switching function value σ in the equation (10) is replaced with the switching function parameter SGMS.
Uadp(k)=Uadp(k−1)−G×SGMS×ΔTCTL/b1 (44)
If FSMCSTAB is equal to “1” in step S276, indicating that the adaptive sliding mode controller 21 is unstable, then the control gain G is set to a predetermining stabilized gain XKADPSTB in step S277, and an adaptive law input Uadp(k) is calculated from the equation (45) in step S278. The equation (45) is an equation obtained by removing the model parameter b1 from the equation (44).
Uadp(k)=Uadp(k−1)−G×SGMS×ΔTCTL (45)
In steps S281 and 282, it is determined whether or not the calculated adaptive law input Uadp is in a range defined by a predetermined upper limit value XUADPH and a predetermined lower limit value XUADPL. If the adaptive law input Uadp is in this range, then the process shown in
In step S301, a nonlinear input gain Knl is calculated according to the throttle valve opening deviation amount DTH. In step S302, it is determined whether or not the switching function value σ is equal to or less than a predetermined lower limit value −XNLTH. If σ is greater than −XNLTH, then it is determined whether the switching function value σ is equal to or greater than a predetermined upper limit value XNLTH in step S304. If the switching function value σ falls between the predetermined upper limit value XNLTH and the predetermined lower limit value −XNLTH, then a nonlinear input parameter SNL is set to the switching function value σ (step S306).
If the switching function value σ is equal to or less than the predetermined lower limit value −XNLTH, then the nonlinear input parameter SNL is set to “−1” in step S303. If the switching function value σ is equal to or greater than the predetermined upper limit value XNLTH, then the nonlinear input parameter SNL is set to “1” in step S305.
In step S307, a nonlinear input Unl(k) is calculated according to the following equation (46).
Unl(k)=−Knl×SNL/b1 (46)
In the process shown in
In step S331, a moving average value DTHRAV of an amount of change in the target value DTHR is calculated according to the above-described equation (15). In step S332, a basic value Kdampbs of a damping control gain is calculated according to the throttle valve opening deviation amount DTH. In step S333, a correction coefficient Kkdamp of a damping control gain is calculated according to the moving average value DDTHRAV in step S333.
In step S334, a damping control gain Kdamp is calculated by multiplying the basic value Kdampbs by the correction coefficient Kkdamp. Then, a damping input Udamp(k) is calculated according to the following equation (13) (shown again).
Udamp(k)=−Kdamp×(DTH(k)−DTH(k−1))/b1 (13)
In step S351, a switching function change amount Dσ is calculated from the following equation (50). A stability determining parameter SGMSTAB is calculated from the following equation (51) in step S352.
Dσ=σ(k)−σ(k−k0) (50)
SGMSTAB=Dσ×σ(k) (51)
In step S353, it is determined whether or not the stability determining parameter SGMSTAB is equal to or less than a stability determining threshold XSGMSTAB. If SGMSTAB is greater than XSGMSTAB, then it is determined that the adaptive sliding mode controller 21 may possibly be unstable, and an unstability detecting counter CNTSMCST is incremented by “1” in step S355. If SGMSTAB is less than or equal to XSGMSTAB, then the adaptive sliding mode controller 21 is determined to be stable, and the count of the unstability detecting counter CNTSMCST is not incremented but maintained in step S354.
In step S356, it is determined whether or not the value of the unstability detecting counter CNTSMCST is equal to or less than a predetermined count XSSTAB. If CNTSMCST is less than or equal to XSSTAB, then the adaptive sliding mode controller 21 is determined to be stable, and a first determination flag FSMCSTAB1 is set to “0” in step S357. If CNTSMCST is greater than XSSTAB, then the adaptive sliding mode controller 21 is determined to be unstable, and the first determination flag FSMCSTAB1 is set to “1” in step S358. The value of the unstability detecting counter CNTSMCST is initialized to “0” when the ignition switch is turned on.
In step S359, a stability determining period counter CNTJUDST is decremented by “1”. It is then determined whether or not the value of the stability determining period counter CNTJUDST is “0” in step S360. The value of the stability determining period counter CNTJUDST is initialized to a predetermined determining count XCJUDST when the ignition switch is turned on. Initially, therefore, the answer to step S360 is negative (NO), and the process immediately goes to step S365.
If the value of the stability determining period counter CNTJUDST subsequently becomes “0”, then the process goes from step S360 to step S361, in which it is determined whether or not the first determination flag FSMCSTAB1 is “1”. If the first determination flag FSMCSTAB1 is “0”, then a second determination flag FSMCSTAB2 is set to “0” in step S363. If the first determination flag FSMCSTAB1 is “1”, then the second determination flag FSMCSTAB2 is set to “1” in step S362.
In step S364, the value of the stability determining period counter CNTJUDST is set to the predetermined determining count XCJUDST, and the unstability detecting counter CNTSMCST is set to “0”. Thereafter, the process goes to step S365.
In step S365, the stability determination flag FSMCSTAB is set to the logical sum of the first determination flag FSMCSTAB1 and the second determination flag FSMCSTAB2. The second determination flag FSMCSTAB2 is maintained at “1” until the value of the stability determining period counter CNTJUDST becomes “0”, even if the answer to step S356 becomes affirmative (YES) and the first determination flag FSMCSTAB1 is set to “0”. Therefore, the stability determination flag FSMCSTAB is also maintained at “1” until the value of the stability determining period counter CNTJUDST becomes “0”.
In step S401, a sticking determination process shown in
In step S412, it is determined whether or not the absolute value of the model parameter c1″ is greater than a sticking determination threshold C1STICK (e.g., 0.03). If the answer to step S412 is negative (NO), a downcount timer TSTICK is set to a predetermined determination period TMSTICK (e.g., 5 sec) and then started (step S413). Thereafter, this process ends.
If |c1″| is greater than C1STICK in step S412, it is determined whether or not the value of the timer TSTICK is “0” (step S414). If TSTICK is greater than “0”, this process immediately ends. If TSTICK is equal to “0”, it is determined that the throttle valve 3 is sticking (cannot be actuated), and a sticking flag FSTICK is set to “1”. When the sticking flag FSTICK is set to “1”, a warning lamp for indicating this abnormality is turned on.
In step S421, a C1RTNSP table shown in
If the answer to step S422 is negative (NO), a downcount timer TRTNSPNG is set to a predetermined period TMRTSPNG (e.g., 3 sec) and then started (step S427). Thereafter, this process ends.
If TH is greater than or equal to THRTSPNG in step S422, an averaged switching function value SGMABSAVE is calculated from the equation (52) shown below.
SGMABSAVE=[|σ(k−4)|+|σ(k−3)|+|σ(k−2)|+|σ(k−1)|+|σ(k)|]/5 (52)
In step S424, it is determined whether or not the averaged switching function value SGMABSAVE is less than a predetermined value SGMRTSPNG (e.g., 0.004). If the answer to step S424 is affirmative (YES), which indicates that the control deviation is small, it is determined whether or not the model parameter c1″ is greater than the return spring abnormality determination threshold C1RTNSP (step S425). If the answer to step S425 is affirmative (YES), it is determined whether or not the battery voltage VBAD is higher than a predetermined voltage VBRTSPNG (e.g., 10.53 V) (step S426).
If the answer to any one of steps S424 to S426 is negative (NO), the program proceeds to step S427 mentioned above. If the answer to step S426 is affirmative (YES), which indicates that the control deviation is small, the model parameter c1″ is greater than the return spring abnormality determination threshold C1RTNSP, and the battery voltage VBAD is in the normal level, it is determined whether or not the value of the timer TRTNSPNG is “0” (step S428). If TRTNSPNG is greater than “0”, this process immediately ends. If TRTNSPNG is equal to “0”, it is determined that the return spring 4 is abnormal. Accordingly, a return spring abnormality flag FRETSPRGNG is set to “1” (step S429), an abnormality detection flag FFSD40H is set to “1” (step S430), and a return spring check end flag FSPRGCHKEND is set to “1” (step S431).
According to the process of
When the return spring abnormality flag FRETSPRGNG is set to “1”, a warning lamp for indicating this abnormality is turned on.
The abnormality determination process of the default spring 5 is obtained by modifying the step S422 in
In this embodiment as mentioned above, the sticking determination of the throttle valve 3 and the abnormality determination of the return spring 4 and the default spring 5 are performed according to the model parameter c1″ which is irrelevant to the control input and the control output. Accordingly, the throttle valve actuating device 10 is always monitored and the above-described abnormalities can be quickly detected.
In this embodiment, the ECU 7 constitutes the control means, the identifying means, and the abnormality determining means. More specifically, step S19 in
The present invention is not limited to the above embodiments, but various modifications may be made. For example, the response-specifying controller that performs a feedback control to make an output of a controlled object coincide with a target value and specifies the damping characteristic of a control deviation of the feedback control process, is not limited to an adaptive sliding mode controller. A controller for performing a back stepping control which realizes control results similar to those of the sliding mode control, may be used as a response-specifying controller.
The present invention may be embodied in other specific forms without departing from the spirit or essential characteristics thereof. The presently disclosed embodiments are therefore to be considered in all respects as illustrative and not restrictive, the scope of the invention being indicated by the appended claims, rather than the foregoing description, and all changes which come within the meaning and range of equivalency of the claims are, therefore, to be embraced therein.
Number | Date | Country | Kind |
---|---|---|---|
2002-241344 | Aug 2002 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5447133 | Kamio et al. | Sep 1995 | A |
6047679 | Matsumoto et al. | Apr 2000 | A |
6073610 | Matsumoto et al. | Jun 2000 | A |
6167866 | Jakisch et al. | Jan 2001 | B1 |
6386178 | Rauch | May 2002 | B1 |
Number | Date | Country |
---|---|---|
2538731 | Jul 1996 | JP |
WO 02086630 | Oct 2002 | WO |
Number | Date | Country | |
---|---|---|---|
20040035393 A1 | Feb 2004 | US |