This invention relates to control systems for internal combustion engines, and more particularly to a control system for controlling an engine's fuel quantity and the gas flow output of its air handling devices.
Today's internal combustion engines are electronically controlled by processor-based engine control units (ECUs). An ECU can control many aspects of the engine's operation, such as fuel quantity, ignition timing, variable valve timing (VVT), turbocharger output, and other engine operating parameters.
An ECU determines these parameters primarily by monitoring the engine through various sensors. These sensors can include a MAP (manifold air pressure) sensor, throttle position sensor, air temperature sensor, oxygen sensor, coolant temperature sensor, mass air flow sensor, crankshaft angle sensor, camshaft angle sensor, knock sensor, and many others. The ECU monitors the output signals produced by these sensors, and adjusts the system inputs as necessary.
Considerable effort is devoted to designing ECU programming that will provide optimal engine operation. Modern engines have nonlinear dynamics, and various nonlinear control methods have been developed.
One such nonlinear control method is “sliding mode control”, which is a control method having high robustness with restraining influence from disturbance. As examples, applications of sliding mode control have been developed for engine throttle control and cam phase control. These control methods are described in U.S. Pat. No. 6,367,449 and in U.S. Pat. No. 6,718,922, respectively.
A more complete understanding of the present embodiments and advantages thereof may be acquired by referring to the following description taken in conjunction with the accompanying drawings, in which like reference numbers indicate like features, and wherein:
Engine 100 is equipped with a turbocharger 110, and a high pressure EGR (exhaust gas recirculation) loop 120. The tailpipe has various exhaust treatment devices, such as a diesel oxidation catalyst 171, diesel particulate filter 172, and lean NOx trap 173. Although not shown, engine 100 is equipped with fuel injectors for injecting a supply fuel quantity, q, into its cylinders 101.
Modeling system 30 models engine 100 for purposes of designing a control system 20 for optimal engine operation. Modeling system 30 can be implemented with computer equipment programmed to store and execute the equations and data described herein.
As explained above, control system 20 is designed using modeling system 30, and for production engines is implemented with appropriate engine control system hardware and software. Specifically, for purposes of this invention, during engine operation, control unit 20 determines fuel injection quantity and various gas flow amounts, and delivers corresponding control signals to the fuel injectors and various air handling devices. Thus, modeling system 30 is used for preproduction development, whereas control system 20 is an “on-line” real-time control system.
Various sections associated with the air intake and exhaust of engine 100 are each represented in the engine model. These include:
The engine model described herein may be generally described as an “engine intake and exhaust system dynamic model”. The air handling actuators of interest for the model are the turbocharger 110 (its output flow), the intake manifold throttle 130, and EGR throttle 150.
These actuators are used to control the fresh air and pressure so that these parameters are appropriate for a desired combustion. If a desired pressure or fresh air flow amount is known, control system 20 can be used to determine how to actuate throttles 130 and 150 and the output of turbocharger 110.
Turbocharger 110 has a compressor 111 and turbine 112, and is assumed to be a variable output turbocharger. An example of a suitable turbocharger is a variable nozzle turbocharger (VNT).
Engine 100 also has an EGR (exhaust gas recirculation loop), which is a high pressure loop. EGR cooler 121 cools the exhaust before it is mixed with fresh air from the compressor 111.
Temperatures at various intake and exhaust points of engine 100 are also represented in the model.
Detection signals from the various sensors are input to control unit 20, which is equipped with a microcomputer. The control unit 20 detects the engine rotation speed Ne from data provided by the crank angle sensor. Control unit 20 uses a sliding mode control method, as described herein, to provide control signals to various actuators, such as for fuel quantity injection control, control of various throttles, and the turbocharger.
Engine 100 may be modeled mathematically by the following nonlinear dynamical equation:
{dot over (x)}=f(x)+G(x)u (1)
where x represents the states of the manifolds (intake and exhaust), and u represents controllable flow rates (such as fresh air, recirculated exhaust gas, and fuel quantity). This dynamic model may be referred to as an “emptying and filling” model. A feature of the above model is that it does not include turbocharger dynamics.
Typical values of the state variable x (the manifold states conditions) are values of pressure (p) and oxygen (f) concentration/fraction. These values are an n-dimensional state vector, represented as:
x=(p1, f1, p3, f3)T
where p1 and f1 are pressure and oxygen concentration in the intake manifold, and p3 and f3 are pressure and oxygen concentration in the exhaust manifold, as illustrated in
For designing control unit 20, target manifold state values are predetermined, based on engine speed (Ne) and accelerator pedal position. As explained below, during engine operation, these target states are differenced with measured states to obtain an “error” value. Thus, it is assumed that all manifold state values may be measured or are otherwise available, such as by estimation.
The values of u are “flow values”, and are an m-dimensional input vector that is used for state feedback. Values of u are expressed herein with a “w” (gas flow rates) and an identifying subscript, or with “q” (fueling quantity). Thus, for example:
u=(wHPT, wHPE, wVNT, q)T
where the subscripts HPT, HPE, and VNT denote the high pressure throttle 130, high pressure EGR valve 150, and variable nozzle turbocharger 110, respectively.
The states and inputs of Equation (1) can be modified for engine variations, such as additional EGR loops. In general, the control method and system described herein may be used for these flow values, or for any subset of these flow values, or may be modified to include additional flow values.
A feature of the modeling method of this description is that the inputs enter Equation (1) in an affine linear manner (for a fixed x). This structure of the dynamics model makes Equation (1) suitable for a sliding mode control law.
In the context of this description, sliding mode control is characterized by choosing one sliding surface per state. The control method is designed to drive each system state onto the sliding surface from an initial state, and to maintain it along that surface for subsequent times. The dynamic behavior of the system is defined by the equation of the sliding surface and is a design choice. In other words, in “sliding mode”, the system slides along a surface, and any tendency of the system to depart from the surface is countered by a control effort. Such tendency is caused, for example, by parametric variations in the system. The control effort that drives the system to the sliding surface provides robustness against parametric variations.
For purposes of this description, s=0 represents a number of sliding surfaces (also referred to as switching surfaces), where the number of sliding surfaces is the number of states. Consistent with sliding mode control, the object of the control system is to arrive at and to maintain s=0. Doing so guarantees that given state targets are tracked, where the states are the pressure and the O2 amount in the intake and exhaust manifolds as described above.
Consistent with sliding mode control, the following expressions are true. The state error, e, is:
e=x−x*
where x* is a desired state, typically a function of pedal position and engine speed as stated above, and x is an actual (measured) state. Also, the integral error, σ, is:
{dot over (σ)}=e
The sliding surfaces, s, where s defines as many surfaces as the number of states, is:
s=Mσ+e
The quadratic Lyapunov function is used to derive a control law (expression for inputs u in terms of state x), where s=−A sgn(s):
{dot over (s)}=M{dot over (σ)}+ė
{dot over (s)}=Me+{dot over (x)}−{dot over (x)}*
−A sgn(s)=Me+f(x)+G(x)u−{dot over (x)}*
u=G
−1(x)[{dot over (x)}*−f(x)−Me−A sgn(s)]
where the equation for u is in sliding mode control form. The matrices M and A are constant gain matrices. A suitable matrix form is a diagonal matrix with real positive entries. Matrix M could be a general symmetric positive definite real matrix. Matrix M defines the dynamics on the sliding surface, in particular the rate of convergence to zero error.
The nonlinear function, sgn(s), is a sign function, which has a value of +1 for positive s, −1 for negative s, and 0 when s=0. As stated above, for the engine system of this description, s is vector-valued, and sgn(s) is applied to each component of the vector.
Sliding mode control with its discontinuous sgn(•) function is known to cause chattering. One of the standard ways of avoiding chattering is to replace sgn(•) with sat(•), a replacement that could be used here. Alternatively, sgn(•) can be replaced with s, yielding:
u=G
−1(x)[{dot over (x)}*−f(x)−Me−A(Mσ+e)]
u=G
−1(x)[−f(x)−(M+A)e−AMσ+{dot over (x)}*]
{feedforward}{P}{I}{D} (2)
As indicated above, Equation (2) can be rewritten as a multi-variable PID controller with feedforward.
In replacing sgn(s) with s, the finite reaching time to the sliding surface is lost, where the “reaching time” is the time for forcing values to the sliding surface, s=0. However, the basic stability characteristics of the controller are maintained.
The engine model used to derive Equation (2), particularly f(x) and G(x), is an approximation. A further simplification can be achieved by rewriting Equation (2) in terms of the change in flow rates away from current flow rates, that is, in terms of Δu. Thus,
where uff is the solution of 0={dot over (x)}=f(x)+G(x)u for a given steady state x. This information is available independently from the steady state characterization of the engine, and is more reliable. The focus is thus only on Δu.
where Ĝ is a constant matrix that represents the cross coupling between the flow rates and the manifold states over the feasible operating range. An approximation of Ĝ is obtained by singular value decomposition of the family G(x)|steady state. Experimentation has been successful in identifying Ĝ.
Values of Δu (changes in flowrates) are assigned to appropriate devices. For example, a change in the HPT valve 130 is effected by ΔwHPT. The Δwq value effects a change in fuel quantity, q, which is nominally based on the in-cylinder state.
For the various air handling devices described above (high pressure throttle, EGR throttle, turbocharger, etc.), actuator setpoints are determined. For a given engine speed (Ne) and pedal position, there is a setpoint, θ, for each air handling actuator that will provide a desired engine performance. A mapping memory 21 maps engine speed and pedal position values to these setpoints.
Also based on engine speed (Ne) and pedal position, target manifold states are set to achieve a desired engine performance. The desired engine performance typically reflects desired torque, emissions and other conditions. These target values, x*, are stored in a mapping memory 22.
During engine operation, current engine speed (Ne) and pedal position values are delivered to mapping memories 21 and 22 to obtain desired actuator setpoint values and desired manifold state values, respectively.
Control unit 20 differences the desired state values and the measured manifold state values to obtain e, the “error” value. These error values are delivered to the sliding mode control process 24. In accordance with Equation (3), the sliding mode control process 24 determines values of Δu, the changes in flow rates from their current values. Sliding mode control process 24 is described below in detail in connection with
For air handling control, an actuator controller 26 converts the flow change, Δu, values to Δθ values, which are added to the open loop actuator setpoints, θ, to generate actuator commands.
For fueling control, the state values, x, are delivered to a fueling control process 28, which receives other measured values and determines fueling parameter values. An example of a suitable process 28 is one based on in-cylinder condition estimation. For example, process 28 could receive, in addition to values of x, values from a MAF sensor, and temperature sensors for intake manifold and coolant. It uses these values to estimate the in-cylinder oxygen mass and concentration, as well as a representative temperature value. These estimations are then used to determine fueling control parameters, such as fueling quantity and injection timing. Examples of such a process are described in U.S. Pat. Pub. No. 2006/0122763; U.S. Pat. Pub. No. 2009/0007888, and U.S. patent application Ser. No. 12/134,598, each of which are incorporated herein by reference.
For purposes of the present invention, the fuel quantity value, q, from process 28 is added to the setpoint change value, Δq, from controller 26. This value is then used to generate a fueling quantity command to the appropriate fueling actuator.
Controller 26 may be a cross-coupled controller. However, controller 26 could be made diagonal if a dominant actuator (one actuator mostly affecting only one flow) is present in the system. In this manner, the change in flow rates, Δu, drives the most sensitive flow device to bring about the desired change in flow. No nominal flow rate information is needed.
The outputs of process 37 are the flow rate change values, Δu. As explained above in connection with