The present disclosure relates to internal combustion engines, and more specifically, to systems and methods for predicting a pedal position based on driver behavior and controlling one or more engine actuators based on the predicted pedal position.
The background description provided here is for the purpose of generally presenting the context of the disclosure. Work of the presently named inventors, to the extent it is described in this background section, as well as aspects of the description that may not otherwise qualify as prior art at the time of filing, are neither expressly nor impliedly admitted as prior art against the present disclosure.
Internal combustion engines combust an air and fuel mixture within cylinders to drive pistons, which produces drive torque. Air flow into the engine is regulated via a throttle. More specifically, the throttle adjusts throttle area, which increases or decreases air flow into the engine. As the throttle area increases, the air flow into the engine increases. A fuel control system adjusts the rate that fuel is injected to provide a desired air/fuel mixture to the cylinders and/or to achieve a desired torque output. Increasing the amount of air and fuel provided to the cylinders increases the torque output of the engine.
In spark-ignition engines, spark initiates combustion of an air/fuel mixture provided to the cylinders. In compression-ignition engines, compression in the cylinders combusts the air/fuel mixture provided to the cylinders. Spark timing and air flow may be the primary mechanisms for adjusting the torque output of spark-ignition engines, while fuel flow may be the primary mechanism for adjusting the torque output of compression-ignition engines.
A system according to the principles of the present disclosure includes a pedal position prediction module and an engine actuator control module. The pedal position prediction module predicts a pedal position at a future time based on driver behavior and vehicle driving conditions. The pedal position includes at least one of an accelerator pedal position and a brake pedal position. The engine actuator control module controls an actuator of an engine based on the predicted pedal position.
Further areas of applicability of the present disclosure will become apparent from the detailed description, the claims and the drawings. The detailed description and specific examples are intended for purposes of illustration only and are not intended to limit the scope of the disclosure.
The present disclosure will become more fully understood from the detailed description and the accompanying drawings, wherein:
In the drawings, reference numbers may be reused to identify similar and/or identical elements.
An engine control module (ECM) controls the torque output of an engine. More specifically, the ECM determines target values for actuators of the engine based on a requested amount of torque, and controls the actuators of the engine based on the target values. For example, the ECM controls intake and exhaust valve lift based on target intake and exhaust valve lift states, controls a throttle valve based on a target throttle opening, and controls a wastegate of a turbocharger based on a target wastegate duty cycle.
The ECM could determine the target values individually using multiple single input single output (SISO) controllers, such as proportional integral derivative (PID) controllers. However, when multiple SISO controllers are used, the target values may be set to maintain system stability at the expense of possible decreases in fuel consumption. Additionally, calibration and design of the individual SISO controllers may be costly and time consuming.
The ECM of the present disclosure generates the target values using a model predictive control (MPC) module. The MPC module identifies possible sets of target values based on an engine torque request. The MPC module predicts responses of the engine for each of the possible sets based on the possible sets target values and a mathematical model of the engine. In one example, the MPC module predicts the torque output of the engine, the pressure within the intake manifold of the engine, and the amount of air provided to each cylinder of the engine.
The MPC module may also determine a cost associated with use of each of the possible sets. The cost determined for a possible set may increase as differences between the target values of the possible set and reference values increase and vice versa. The MPC module may also apply weighting values to the differences between the target values of the possible set and reference values to adjust how much each of these differences affects the cost. The MPC module may select the possible set that has the lowest cost. Instead of or in addition to identifying possible sets of target values and determining the cost of each of the sets, the MPC module may generate a surface representing the cost of possible sets of target values. The MPC module may then identify the possible set that has the lowest cost based on the slope of the cost surface.
The MPC module may determine whether the predicted responses of the selected set satisfy constraints. If so, the MPC module may set the target values based on the selected set. Otherwise, the MPC module may select the possible set having the next lowest cost and test that set for satisfaction of the constraints. The process of selecting a set and testing the set for satisfaction of the constraints may be referred to as an iteration. Multiple iterations may be performed during each control loop.
Instead of or in addition to determining whether the predicted torque output of the engine satisfies a constraint, the MPC module may determine the cost associated with use of each of the possible sets based on differences between the predicted torque output and a torque request. In one example, the ECM determines the torque request based on a driver input such as an accelerator pedal position and/or a brake pedal position. Since the driver input is dependent on decisions made by the driver, future values of the driver input are unknown. Therefore, the MPC module could assume that the torque request remains constant in the prediction horizon. However, this assumption may be incorrect, which may degrade the performance of the engine.
An ECM according to the present disclosure overcomes this challenge by predicting the driver input based on the driving style or past driving behavior of the driver, and predicting the torque request based on the predicted driver input. The MPC module may then determine the cost associated with use of a possible set of target values for an engine actuator based on differences between the predicted torque output and the predicted torque request. In one example, the ECM identifies the driver and predicts the driver input based on current driver input, vehicle driving conditions, and the driver identification. In another example, the ECM develops a model that relates driver behavior data to the vehicle driving conditions and the driver identification, and predicts the driver input based on the vehicle driving conditions and the driver identification using the model.
The driver behavior data includes a history of the driver input and the corresponding vehicle driving conditions and driver identification. To save memory and computation costs, the ECM may transmit the driver behavior data to a remote server (e.g., in the cloud), which may store the driver behavior data. The ECM may then retrieve the driver behavior data from the cloud when the current driver identification matches the driver identification associated with the driver behavior data.
Predicting the driver input and determining future values of a torque request rather than assuming that the torque request remains constant may improve the engine performance (e.g., fuel economy and drivability). In addition, predicting the driver input based on the style of a particular driver has benefits outside of MPC. For example, determining future torque requests and/or future target values of an engine actuator based on a predicted driver input may improve engine performance regardless of whether an engine is controlled using a SISO controller or an MPC control module.
Referring now to
Air is drawn into the engine 102 through an intake system 108. The intake system 108 includes an intake manifold 110 and a throttle valve 112. The throttle valve 112 may include a butterfly valve having a rotatable blade. An engine control module (ECM) 114 controls a throttle actuator module 116, which regulates opening of the throttle valve 112 to control the amount of air drawn into the intake manifold 110.
Air from the intake manifold 110 is drawn into cylinders of the engine 102. While the engine 102 may include multiple cylinders, for illustration purposes a single representative cylinder 118 is shown. For example only, the engine 102 may include 2, 3, 4, 5, 6, 8, 10, and/or 12 cylinders. A cylinder actuator module 120 may deactivate some of the cylinders, which may improve fuel economy under certain engine operating conditions.
The engine 102 may operate using a four-stroke cycle. The four strokes, described below, are named the intake stroke, the compression stroke, the combustion stroke, and the exhaust stroke. During each revolution of a crankshaft (not shown), two of the four strokes occur within the cylinder 118. Therefore, two crankshaft revolutions are necessary for the cylinder 118 to experience all four of the strokes.
During the intake stroke, air from the intake manifold 110 is drawn into the cylinder 118 through an intake valve 122. The ECM 114 controls a fuel actuator module 124, which regulates fuel injections performed by a fuel injector 125 to achieve a desired air/fuel ratio. Fuel may be injected into the intake manifold 110 at a central location or at multiple locations, such as near the intake valve 122 of each of the cylinders. In various implementations, fuel may be injected directly into the cylinders or into mixing chambers associated with the cylinders. The fuel actuator module 124 may halt injection of fuel to cylinders that are deactivated.
The injected fuel mixes with air and creates an air/fuel mixture in the cylinder 118. During the compression stroke, a piston (not shown) within the cylinder 118 compresses the air/fuel mixture. The engine 102 may be a compression-ignition engine, in which case compression in the cylinder 118 ignites the air/fuel mixture. Alternatively, the engine 102 may be a spark-ignition engine, in which case a spark actuator module 126 energizes a spark plug 128 to generate a spark in the cylinder 118 based on a signal from the ECM 114, which ignites the air/fuel mixture. The timing of the spark may be specified relative to the time when the piston is at its topmost position, referred to as top dead center (TDC).
The spark actuator module 126 may be controlled by a spark timing signal specifying how far before or after TDC to generate the spark. Because piston position is directly related to crankshaft rotation, operation of the spark actuator module 126 may be synchronized with crankshaft angle. In various implementations, the spark actuator module 126 may halt provision of spark to deactivated cylinders.
Generating the spark may be referred to as a firing event. The spark actuator module 126 may have the ability to vary the timing of the spark for each firing event. The spark actuator module 126 may even be capable of varying the spark timing for a next firing event when the spark timing signal is changed between a last firing event and the next firing event. In various implementations, the engine 102 may include multiple cylinders and the spark actuator module 126 may vary the spark timing relative to TDC by the same amount for all cylinders in the engine 102.
During the combustion stroke, combustion of the air/fuel mixture drives the piston down, thereby driving the crankshaft. The combustion stroke may be defined as the time between the piston reaching TDC and the time at which the piston returns to bottom dead center (BDC). During the exhaust stroke, the piston begins moving up from BDC and expels the byproducts of combustion through an exhaust valve 130. The byproducts of combustion are exhausted from the vehicle via an exhaust system 134.
The intake valve 122 is actuated using an intake valve actuator 136, while the exhaust valve 130 is actuated using an exhaust valve actuator 138. A valve actuator module 139 may control the intake and exhaust valve actuators 136 and 138 based on signals from the ECM 114. In various implementations, the intake valve actuator 136 may actuate multiple intake valves (including the intake valve 122) of the cylinder 118. Similarly, the exhaust valve actuator 138 may actuate multiple exhaust valves (including the exhaust valve 130) of the cylinder 118. Additionally, a single valve actuator may actuate one or more exhaust valves of the cylinder 118 and one or more intake valves of the cylinder 118. Further, the intake valve actuator 136 may actuate multiple intake valves of multiple cylinders, and the exhaust valve actuator 138 may actuate multiple exhaust valves of multiple cylinders.
In various implementations, the intake valve actuator 136 may be driven by an intake camshaft 140, and the exhaust valve actuator 138 may be driven by an exhaust camshaft 142. For example, the intake valve actuator 136 may include a rocker arm and a cam follower coupled to the rocker arm. The rocker arm may lift the intake valve 122 from its valve seat when the cam follower engages a lobe on the intake camshaft 140. Similarly, the exhaust valve actuator 138 may include a rocker arm and a cam follower coupled to the rocker arm. The rocker arm may lift the exhaust valve 130 from its valve seat when the cam follower engages a lobe on the exhaust camshaft 142.
In other implementations, the intake and exhaust valve actuators 136 and 138 may actuate the intake and exhaust valves 122 and 130 independent of a camshaft. For example, the intake and exhaust valves 122 and 130 may be electromagnetic or electrohydraulic valve actuators. In these implementations, the intake and exhaust valve actuators 136 and 138 may be referred to as camless valve actuators.
The intake and exhaust valve actuators 136 and 138 may vary the amount by which the intake and exhaust valves 122 and 130 are lifted from their respective valve seats. For example, the intake and exhaust valve actuators 136 and 138 may switch between a first lift state and a second lift state. The intake and exhaust valve actuators 136 and 138 may cause the intake and exhaust valves 122 and 130 to lift from their respective valve seats by a first amount when operating in the first lift state. The intake and exhaust valve actuators 136 and 138 may cause the intake and exhaust valves 122 and 130 to lift from their respective valve seats by a second amount when operating in the second lift state. The first and second amounts may be predetermined, nonzero values. In addition, the second amount may be greater than the first amount. In this regard, the first lift state may be referred to as a low lift state, and the second lift state may be referred to as a high lift state.
When the intake and exhaust valve actuators 136 and 138 are cam driven, each of the intake and exhaust valve actuators 136 and 138 may include a cam follower having a height that is adjustable to vary the lift of the intake and exhaust valves 122 and 130. Alternatively, each of the intake and exhaust valve actuators 136 and 138 may include a solenoid that translates a camshaft segment along the length of one of the camshafts 140 and 142 to cause a cam follower to engage different lobes on the camshaft segment. The lobes may have different heights so that switching which one of the lobes the cam follower engages varies the lift of the intake and exhaust valves 122 and 130. Valve actuators such as these may be referred to as sliding cam actuators.
When the intake and exhaust valve actuators 136 and 138 are camless valve actuators, the valve actuators 136 and 138 may also adjust the timing of the intake and exhaust valves 122 and 130, respectively. When the intake and exhaust valve actuators 136 and 138 are cam driven, the timing of the intake and exhaust valves 122 and 130 may be adjusted by intake and exhaust cam phasers 148, 150, respectively. The valve actuator module 139 may adjust the position of the intake and exhaust cam phasers 148, 150 based on signals received from the ECM 114.
The cylinder actuator module 120 may deactivate the cylinder 118 by instructing the valve actuator module 139 to disable opening of the intake valve 122 and/or the exhaust valve 130. When the intake valve actuator 136 is cam driven, the intake valve actuator 136 may disable opening of the intake valve 122 by decoupling the intake valve 122 from the intake camshaft 140. Similarly, when the exhaust valve actuator 138 is cam driven, the exhaust valve actuator 138 may disable opening of the exhaust valve 130 by decoupling the exhaust valve 130 from the exhaust camshaft 142.
In various implementations, the valve actuator module 139 may disable opening of the intake and exhaust valves 122 and 130 by switching the intake and exhaust valve actuators 136 and 138 to a third lift state. The intake and exhaust valve actuators 136 and 138 may lift the intake and exhaust valves 122 and 130 from their respective valve seats by a third amount when operating in the third lift state. The third amount may be zero. Thus, the third lift state may be referred to as a zero lift state.
The vehicle system 100 may include a boost device that provides pressurized air to the intake manifold 110. For example,
A wastegate 162 may allow exhaust to bypass the turbine 160-1, thereby reducing the boost (the amount of intake air compression) of the turbocharger. The ECM 114 may control the turbocharger via a boost actuator module 164. The boost actuator module 164 may modulate the boost of the turbocharger by controlling the position of the wastegate 162. In various implementations, multiple turbochargers may be controlled by the boost actuator module 164. The turbocharger may have variable geometry, which may be controlled by the boost actuator module 164.
An intercooler (not shown) may dissipate some of the heat contained in the compressed air charge, which is generated as the air is compressed. The compressed air charge may also have absorbed heat from components of the exhaust system 134. Although shown separated for purposes of illustration, the turbine 160-1 and the compressor 160-2 may be attached to each other, placing intake air in close proximity to hot exhaust. A bypass valve 166 may allow exhaust to bypass the compressor 160-2 when the bypass valve 166 is open. The ECM 114 may control the bypass valve 166 via a bypass actuator module 168.
The exhaust system 134 may include an exhaust gas recirculation (EGR) valve 170, which selectively redirects exhaust gas back to the intake manifold 110. The EGR valve 170 may be located upstream of the turbocharger's turbine 160-1. The EGR valve 170 may be controlled by an EGR actuator module 172.
The vehicle system 100 may include a driver identification device 174 that generate a driver identification signal 176 indicating the identification of a driver of the vehicle. In one example, the driver identification device 174 includes a camera that is aimed at the driver's seat to generate an image of the driver when, for example, the driver enters the vehicle. The driver identification device 174 may further include image recognition software that identifies the driver based on the image generated by the camera. In another example, the driver identification device 174 includes a touchscreen that requests the driver to enter their identification by manipulating the touchscreen when, for example, the driver enters the vehicle.
In yet another example, the driver identification device 174 identifies the driver by communicating with a key fob (not shown). The driver identification device 174 may assume that only one driver uses the key fob, or the key fob may be programmable to associate the driver therewith. The driver identification device 174 may communicate with the key fob using, for example, radio frequency (RF) and/or bluetooth signals.
The vehicle system 100 may measure the position of the accelerator pedal 105 using an accelerator pedal position (APP) sensor 177. The position of the brake pedal 106 may be measured using a brake pedal position (BPP) sensor 178. The APP sensor 177 and the BPP sensor 178 may output the accelerator pedal position and the brake pedal position, respectively, to the driver input module 104 and/or the ECM 114.
The position of the crankshaft may be measured using a crankshaft position (CKP) sensor 180. The temperature of the engine coolant may be measured using an engine coolant temperature (ECT) sensor 182. The ECT sensor 182 may be located within the engine 102 or at other locations where the coolant is circulated, such as a radiator (not shown).
The pressure within the intake manifold 110 may be measured using a manifold absolute pressure (MAP) sensor 184. In various implementations, engine vacuum, which is the difference between ambient air pressure and the pressure within the intake manifold 110, may be measured. The mass flow rate of air flowing into the intake manifold 110 may be measured using a mass air flow (MAF) sensor 186. In various implementations, the MAF sensor 186 may be located in a housing that also includes the throttle valve 112.
The throttle actuator module 116 may monitor the position of the throttle valve 112 using one or more throttle position sensors (TPS) 190. The ambient temperature of air being drawn into the engine 102 may be measured using an intake air temperature (IAT) sensor 192. The rotational speed of one or more wheels (not shown) of the vehicle may be measured using one or more wheel speed (WS) sensors 193. The ECM 114 uses signals from the sensors to make control decisions for the vehicle system 100.
The ECM 114 may communicate with a transmission control module (TCM) 194 to coordinate shifting gears in a transmission (not shown). For example, the ECM 114 may reduce engine torque during a gear shift. The ECM 114 may communicate with a hybrid control module (HCM) 196 to coordinate operation of the engine 102 and an electric motor 198. The electric motor 198 may also function as a generator, and may be used to produce electrical energy for use by the vehicle's electrical systems and/or for storage in a battery. In various implementations, various functions of the ECM 114, the TCM 194, and the HCM 196 may be integrated into one or more modules.
Referring now to
The driver torque request 204 may be zero or have a positive value when the driver torque request 204 is determined based on the accelerator pedal position. The driver torque request 204 may be zero or have a negative value when the driver torque request 204 is determined based on the brake pedal position. If the driver torque request 204 is determined based on both the accelerator pedal position and the brake pedal position, the driver torque request 204 may be zero or have a positive or negative value.
The driver torque request 204 may include a current driver torque request and future driver torque requests. The driver torque module 202 may determine the current driver torque request based on a current pedal position such as the accelerator pedal position from the APP sensor 177 and/or the brake pedal position from the BPP sensor 178. In addition, the driver torque module 202 may predict a pedal position based on the current pedal position, vehicle driving conditions, and driver behavior, and determine the future driver torque requests based on the predicted pedal position.
An axle torque arbitration module 208 arbitrates between the driver torque request 204 and other axle torque requests 210. Axle torque (torque at the wheels) may be produced by various sources including an engine and/or an electric motor. For example, the axle torque requests 210 may include a torque reduction requested by a traction control system when positive wheel slip is detected. Positive wheel slip occurs when axle torque overcomes friction between the wheels and the road surface, and the wheels begin to slip against the road surface. The axle torque requests 210 may also include a torque increase request to counteract negative wheel slip, where a tire of the vehicle slips in the other direction with respect to the road surface because the axle torque is negative.
The axle torque requests 210 may also include brake management requests and vehicle over-speed torque requests. Brake management requests may reduce axle torque to ensure that the axle torque does not exceed the ability of the brakes to hold the vehicle when the vehicle is stopped. Vehicle over-speed torque requests may reduce the axle torque to prevent the vehicle from exceeding a predetermined speed. The axle torque requests 210 may also be generated by vehicle stability control systems.
The axle torque arbitration module 208 outputs an axle torque request 212 based on the results of arbitrating between the received axle torque requests 204 and 210. As described below, the axle torque request 212 from the axle torque arbitration module 208 may selectively be adjusted by other modules of the ECM 114 before being used to control the engine actuators.
The axle torque arbitration module 208 may output the axle torque request 212 to a propulsion torque arbitration module 214. In various implementations, the axle torque arbitration module 208 may output the axle torque request 212 to a hybrid optimization module 216. The hybrid optimization module 216 may determine how much torque should be produced by the engine 102 and how much torque should be produced by the electric motor 198. The hybrid optimization module 216 then outputs a modified axle torque request 218 to the propulsion torque arbitration module 214.
The propulsion torque arbitration module 214 converts the axle torque request 212 (or the modified axle torque request 218) from an axle torque domain (torque at the wheels) into a propulsion torque domain (torque at the crankshaft). The propulsion torque arbitration module 214 arbitrates between the (converted) axle torque request 212 and other propulsion torque requests 220. The propulsion torque arbitration module 214 generates a propulsion torque request 222 as a result of the arbitration.
For example, the propulsion torque requests 220 may include torque reductions for engine over-speed protection, torque increases for stall prevention, and torque reductions to accommodate transmission gear shifts. The propulsion torque requests 220 may also result from clutch fuel cutoff, which reduces the engine output torque when the driver depresses the clutch pedal in a manual transmission vehicle to prevent a flare in engine speed.
The propulsion torque requests 220 may also include an engine shutoff request, which may be initiated when a critical fault is detected. For example, critical faults may include detection of vehicle theft, a stuck starter motor, electronic throttle control problems, and unexpected torque increases. In various implementations, when an engine shutoff request is present, arbitration selects the engine shutoff request as the winning request. When the engine shutoff request is present, the propulsion torque arbitration module 214 may output zero as the propulsion torque request 222.
In various implementations, an engine shutoff request may simply shut down the engine 102 separately from the arbitration process. The propulsion torque arbitration module 214 may still receive the engine shutoff request so that, for example, appropriate data can be fed back to other torque requestors. For example, all other torque requestors may be informed that they have lost arbitration.
A torque reserve module 224 generates a torque reserve 226 to compensate for changes in engine operating conditions that may decrease engine output torque and/or to compensate for one or more loads. For example, the air/fuel ratio of the engine 102 and/or the mass air flow may be directly varied, such as by diagnostic intrusive equivalence ratio testing and/or new engine purging. Before beginning these processes, the torque reserve module 224 may create or increase the torque reserve 226 to quickly offset decreases in engine output torque that result from leaning the air/fuel mixture during these processes.
The torque reserve module 224 may also create or increase the torque reserve 226 in anticipation of a future load, such as power steering pump operation or engagement of an air conditioning (A/C) compressor clutch. The torque reserve module 224 may create or increase the torque reserve 226 for engagement of the A/C compressor clutch when the driver first requests air conditioning. Then, when the A/C compressor clutch engages, the torque reserve module 224 may decrease the torque reserve 226 by an amount equal to the estimated load of the A/C compressor clutch.
A target generating module 228 controls the engine actuators by generating target values for the engine actuators. In this regard, the target generating module 228 may be referred to as an engine actuator control module. The target generating module 228 generates target values for the engine actuators based on the propulsion torque request 222, the torque reserve 226, and other parameters as discussed further below. The target generating module 228 generates the target values using model predictive control (MPC). The propulsion torque request 222 may be a brake torque. Brake torque may refer to torque at the crankshaft under the current operating conditions.
The target values include a target wastegate opening area 230, a target throttle opening area 232, a target bypass valve position 233, a target EGR opening area 234, a target intake valve lift state 236, and a target exhaust valve lift state 238. The target values also include a target spark timing 240, a target number 242 of cylinders to be activated, and target fueling parameters 244. The boost actuator module 164 controls the wastegate 162 to achieve the target wastegate opening area 230. For example, a first conversion module 248 may convert the target wastegate opening area 230 into a target duty cycle 250 to be applied to the wastegate 162, and the boost actuator module 164 may apply a signal to the wastegate 162 based on the target duty cycle 250. In various implementations, the first conversion module 248 may convert the target wastegate opening area 230 into a target wastegate position (not shown), and convert the target wastegate position into the target duty cycle 250.
The throttle actuator module 116 controls the throttle valve 112 to achieve the target throttle opening area 232. For example, a second conversion module 252 may convert the target throttle opening area 232 into a target duty cycle 254 to be applied to the throttle valve 112, and the throttle actuator module 116 may apply a signal to the throttle valve 112 based on the target duty cycle 254. In various implementations, the second conversion module 252 may convert the target throttle opening area 232 into a target throttle position (not shown), and convert the target throttle position into the target duty cycle 254. The bypass actuator module 168 controls the bypass valve 166 to achieve the target bypass valve position 233.
The EGR actuator module 172 controls the EGR valve 170 to achieve the target EGR opening area 234. For example, a fourth conversion module 256 may convert the target EGR opening area 234 into a target duty cycle 258 to be applied to the EGR valve 170, and the EGR actuator module 172 may apply a signal to the EGR valve 170 based on the target duty cycle 258. In various implementations, the fourth conversion module 256 may convert the target EGR opening area 234 into a target EGR position (not shown), and convert the target EGR position into the target duty cycle 258.
The valve actuator module 139 controls the intake valve actuator 136 to achieve the target intake valve lift state 236. The valve actuator module 139 also controls the exhaust valve actuator 138 to achieve the target exhaust valve lift state 238. Each of the target intake and exhaust valve lift states 236 and 238 may be one of the first, second, or third lift states discussed above in regards to the possible lift states of the intake and exhaust valve actuators 136 and 138.
The target wastegate opening area 230, the target throttle opening area 232, the target bypass valve position 233, the target EGR opening area 234, the target intake valve lift state 236, and the target exhaust valve lift state 238 may be referred to as air control setpoints. The target throttle opening area 232 may only be used as an air control setpoint if the engine 102 is a spark-ignition engine. Thus, if the engine 102 is a compression-ignition engine, the target throttle opening area 232 may not be used as an air control setpoint. Instead, a target EGR flow, a target boost amount, and/or a target engine air flow may be used as air control setpoints. The target EGR flow, the target boost amount, and/or the target engine air flow may be achieved by adjusting the target wastegate opening area 230, a target variable geometry turbocharger (VGT) position (if applicable), the target EGR opening area 234, the target intake valve lift state 236, and/or the target exhaust valve lift state 238.
The spark actuator module 126 provides spark based on the target spark timing 240. The cylinder actuator module 120 selectively activates and deactivates the valves of cylinders based on the target number 242 of cylinders. Fueling and spark may also be disabled to cylinders that are deactivated. The target fueling parameters 244 may include a target fuel rail pressure, a target number of fuel injections for each combustion event, a target fueling amount for each injection, and/or target start timing for each injection. The fuel actuator module 124 controls fueling based on the target fueling parameters 244. In one example, the fuel actuator module 124 may command a pilot injection, a main injection, a post injection, an exhaust injection, and the target fueling parameters 244 may include a target fueling amount and/or a target start timing for each of the pilot, main, post, and exhaust injections.
An MPC (model predictive control) module 312 generates the target values 230-244 using MPC. The MPC module 312 may be a single module or may comprise multiple modules. For example, the MPC module 312 may include a sequence determination module 316. The sequence determination module 316 determines possible sequences of the target values 230-244 that could be used together during N future control loops. Each of the possible sequences identified by the sequence determination module 316 includes one sequence of N values for each of the target values 230-244. In other words, each possible sequence includes a sequence of N values for the target wastegate opening area 230, a sequence of N values for the target throttle opening area 232, a sequence of N values for the target bypass valve position 233, a sequence of N values for the target EGR opening area 234, a sequence of N values for the target intake valve lift state 236, and a sequence of N values for the target exhaust valve lift state 238. Each possible sequence also includes a sequence of N values for the target spark timing 240, the target number 242 of cylinders, and the target fueling parameters 244. Each of the N values corresponds to one of the N future control loops. N is an integer greater than one.
A prediction module 323 predicts responses of the engine 102 to the possible sequences of the target values 230-244 based on a mathematical model 324 of the engine 102, exogenous inputs 328, and feedback inputs 330. For example, based on a possible sequence of the target values 230-244, the exogenous inputs 328, and the feedback inputs 330, using the model 324, the prediction module 323 may generate a sequence of predicted torques of the engine 102 for the N control loops, a sequence of predicted MAPs for the N control loops, a sequence of predicted masses of air per cylinder (APCs) for the N control loops, a sequence of predicted amounts of external dilution for the N control loops, a sequence of predicted amounts of internal dilution for the N control loops, a sequence of predicted combustion phasing values for the N control loops, a sequence of predicted combustion quality values for the N control loops, and a sequence of predicted effective displacement values for the N control loops.
The model 324 may include a function or a mapping calibrated based on characteristics of the engine 102. Dilution may refer to an amount of exhaust from a prior combustion event trapped within a cylinder for a combustion event. External dilution may refer to exhaust provided for a combustion event via the EGR valve 170. Internal dilution (also referred to as residual dilution) may refer to exhaust that remains in a cylinder and/or exhaust that is pushed back into the cylinder following the exhaust stroke of a combustion cycle. Effective displacement may refer to the volume of air drawn into cylinders of an engine as pistons in the cylinders travel from TDC to BDC, minus losses in air volume due to pistons pushing air back into an intake manifold through intake valves of the cylinders.
Combustion phasing may refer to a crankshaft position where a predetermined amount of fuel injected is combusted within a cylinder relative to a predetermined crankshaft position for combustion of the predetermined amount of injected fuel. For example, combustion phasing may be expressed in terms of CA50 relative to a predetermined CA50. CA50 may refer to a crankshaft angle (CA) where 50 percent of a mass of injected fuel has been combusted within a cylinder. The predetermined CA50 may correspond to a CA50 where a maximum amount of work is produced from the fuel injected and may be approximately 8.5-approximately 10 degrees after TDC (top dead center) in various implementations. While combustion phasing will be discussed in terms of CA50 values, another suitable parameter indicative of combustion phasing may be used. Additionally, while combustion quality will be discussed as coefficient of variation (COV) of indicated mean effective pressure (IMEP) values, another suitable parameter indicative of combustion quality may be used.
The exogenous inputs 328 may include parameters that are not directly affected by the engine actuators. For example, the exogenous inputs 328 may include engine speed, turbocharger inlet air pressure, IAT, and/or one or more other parameters. The feedback inputs 330 may include, for example, an estimated torque output of the engine 102, an exhaust pressure downstream of the turbine 160-1 of the turbocharger, the IAT, an APC of the engine 102, an estimated internal dilution, an estimated external dilution, MAF, an air/fuel ratio of the engine 102, spark timing, and/or one or more other suitable parameters. The feedback inputs 330 may be measured using sensors (e.g., the IAT sensor 192) and/or estimated based on one or more other parameters.
The prediction module 323 also predicts, for each of the possible sequences of adjustments to the target values 230-246, levels of emissions in exhaust gas produced by the engine 102. The predicted emissions levels may include a level of nitrogen oxide (NOx) in exhaust gas produced by the engine 102, a level of hydrocarbon (HC) in exhaust gas produced by the engine 102, and/or a level of carbon monoxide (CO) in exhaust gas produced by the engine 102. The prediction module 323 may predict the emissions levels based on, for example, the exogenous inputs 328 and/or the feedback inputs 330. The prediction module 323 may make these predictions using linear physics-based models. For example, based on a possible sequence of the target values 266-270, the exogenous inputs 328, and the feedback inputs 330, using the physics-based models, the prediction module 323 may generate a sequence of predicted NOx levels for the N control loops, a sequence of predicted HC levels for the N control loops, and a sequence of predicted CO levels for the N control loops.
A cost module 332 determines a cost value for each of the possible sequences of the target values 230-244 based on the predicted parameters determined for a possible sequence and may determine the cost value based on reference values 340. The cost module 332 may determine the cost value for each of the possible sequences based on relationships between the predicted parameters and corresponding ones of the reference values 340. The relationships may be weighted, for example, to control the effect that each of the relationships has on the cost.
A selection module 344 selects one of the possible sequences of the target values 230-244 based on the respective costs of the possible sequences. For example, the selection module 344 may select the one of the possible sequences having the lowest cost while satisfying actuator constraints 348 and output constraints 352.
In various implementations, satisfaction of the actuator constraints 348 and/or the output constraints 352 may be considered in the cost determination. For example, the cost module 332 may determine the cost value for each of the possible sequences based on relationships between the predicted parameters and corresponding ones of the actuator constraints 348 and the output constraints 352.
The selection module 344 may set the target values 230-244 to the first ones of the N values of the selected possible sequence, respectively. In other words, the selection module 344 sets the target wastegate opening area 230 to the first one of the N values in the sequence of N values for the target wastegate opening area 230, set the target throttle opening area 232 to the first one of the N values in the sequence of N values for the target throttle opening area 232, set the target bypass valve position 233 to the first one of the N values in the sequence of N values for the target bypass valve position 233, set the target EGR opening area 234 to the first one of the N values in the sequence of N values for the target EGR opening area 234, set the target intake valve lift state 236 to the first one of the N values in the sequence of N values for the target intake valve lift state 236, and set the target exhaust valve lift state 238 to the first one of the N values in the sequence of N values for the target exhaust valve lift state 238. The selection module 344 also sets the target spark timing 240 to the first one of the N values in the sequence of N values for the target spark timing 240, the target number 242 of cylinders to the first one of the N values in the sequence of N values for the target number 242 of cylinders, and the target fueling parameters 244 to the first one of the N values in the sequence of N values for the target fueling parameters 244.
During a next control loop, the MPC module 312 identifies possible sequences, generates the predicted parameters for the possible sequences, determines the cost of each of the possible sequences, selects of one of the possible sequences, and sets of the target values 230-244 to the first set of the target values 230-244 in the selected possible sequence. This process continues for each control loop.
An actuator constraint module 360 (see
The actuator constraints 348 for each of the target values 230-244 may include a maximum value for an associated target value and a minimum value for that target value. The actuator constraint module 360 may generally set the actuator constraints 348 to predetermined operational ranges for the associated engine actuators. More specifically, the actuator constraint module 360 may generally set the actuator constraints 348 to predetermined operational ranges for the throttle valve 112, the EGR valve 170, the wastegate 162, the intake cam phaser 148, the exhaust cam phaser 150, the spark actuator module 126, the cylinder actuator module 120, and the fuel actuator module 124, respectively. Thus, the maximum value for a target value may be a maximum limit of a corresponding actuator and the minimum value for the target value may be a minimum limit of that actuator.
An output constraint module 364 (see
The output constraint module 364 may generally set the output constraints 352 to predetermined ranges for the associated predicted parameters, respectively. However, the output constraint module 364 may vary one or more of the output constraints 352 under some circumstances. For example, the output constraint module 364 may retard the maximum CA50, such as when knock occurs within the engine 102. In another example, the output constraint module 364 may increase the maximum COV of IMEP under low load conditions, such as during engine idling where a higher COV of IMEP may be needed to achieve a given torque request.
A reference value module 368 (see
The reference value module 368 may determine the reference values 340 based on the propulsion torque request 222. The reference values 340 provide references for setting the target values 266-270. The reference values 340 may be used to determine the cost values for possible sequences, as discussed further below. The reference values 340 may also be used for one or more other reasons, such as by the sequence determination module 316 to determine possible sequences.
Instead of or in addition to generating sequences of possible target values and determining the cost of each of the sequences, the MPC module 312 may identify a sequence of possible target values having the lowest cost using convex optimization techniques. For example, the MPC module 312 may determine the target values 230-244 using a quadratic programming (QP) solver, such as a Dantzig QP solver. In another example, the MPC module 312 may generate a surface of cost values for the possible sequences of the target values 230-244 and, based on the slope of the cost surface, identify a sequence of possible target values having the lowest cost. The MPC module 312 may then test that sequence of possible target values to determine whether that sequence of possible target values satisfies the actuator constraints 348 and the output constraints 352. If so, the MPC module 312 may set the target values 230-244 to the first ones of the N values of that selected possible sequence, respectively, as discussed above.
If the actuator constraints 348 or the output constraints 352 are not satisfied, the MPC module 312 selects another sequence of possible target values with a next lowest cost and tests that sequence of possible target values for satisfaction of the actuator constraints 348 and the output constraints 352. The process of selecting a sequence and testing the sequence for satisfaction of the actuator constraints 348 and the output constraints 352 may be referred to as an iteration. Multiple iterations may be performed during each control loop.
The MPC module 312 performs iterations until a sequence with the lowest cost that satisfies the actuator constraints 348 and the output constraints 352 is identified. In this manner, the MPC module 312 selects the sequence of possible target values having the lowest cost while satisfying the actuator constraints 348 and the output constraints 352. If a sequence cannot be identified, the MPC module 312 may indicate that no solution is available.
The cost module 332 may determine the cost for the possible sequences of the target values 266-270 based on: a relationship between the predicted torque and the propulsion torque request 222; the target fueling amount, and the predicted emissions levels. For example only, the cost module 332 may determine the cost for a possible sequence of the target values 266-270 based on the following relationship:
Cost=Σi=1N[wTi*∥TPi−PTRi∥2+wFi*PTFi+wEiEPi],
subject to the actuator constraints 348 and the output constraints 352. Cost is the cost for the possible sequence of the target values 266-270, TPi is the actual torque delivered by the engine 102 for an i-th one of the N control loops, PTRi is a predicted torque request for the i-th one of the N control loops, and wTi is a weighting value for the i-th one of the N control loops. The actual torque delivered by the engine 102 for the i-th one of the N control loops may be predicted based on the predicted torque request for the i-th one of the N control loops. In this regard, the actual torque delivered by the engine 102 may be the predicted torque output generated by the prediction module 323. The predicted torque request for the i-the one of the N control loops may be the propulsion torque request 222 for the i-th one of the N control loops. The propulsion torque request for the first one of the N control loops may be determined based on the current driver torque request determined by the driver torque module 202. The propulsion torque requests for all subsequent ones of the N control loops may be determined based on the future driver torque requests predicted by the driver torque module 202. The weighting value wTi is associated with the difference between the actual torque delivered by the engine 102 for the i-th one of the N control loops and the predicted torque request for the i-th one of the N control loops. The cost increases as the difference between the actual engine torque delivered and the predicted torque request increases and vice versa.
PFi is a possible target fueling amount for the i-th one of the N control loops, and wTFi is a weighting value associated with the possible target fueling amount for the i-th one of the N control loops. The cost increases as the possible target fueling amount increases and vice versa. Thus, the possible target fueling amount may be included in the cost relationship provided above to reduce fuel consumption. In this regard, the possible target fueling amount may be referred to as a fuel consumption term.
EPi is the predicted emissions levels for the i-th one of the N control loops, and wEi is a weighting value associated with the predicted emissions levels for the i-th one of the N control loops. The cost increases as the predicted emissions levels increase and vice versa. Thus, the predicted emissions levels may be included in the cost relationship provided above to reduce emissions.
The weighting value wTi may be greater than the weighting value wFi and the weighting value wEi. In this manner, the relationship between the relationship between the actual engine torque delivered and the predicted torque request may have a larger effect on the cost than the target fueling amount or the predicted emissions levels. Therefore, the relationship between the actual engine torque delivered and the predicted torque request may have a larger effect on the selection of one of the possible sequences relative to the target fueling amount or the predicted emissions levels.
Referring now to
In other examples, the traffic condition may be classified as normal, bad, or heavy, the road slope may be classified as normal, less than normal, or greater than normal, and the road condition may be classified as normal or bad. The road condition may be classified as bad when the road on which the vehicle is travelling is slippery or very rocky. The road slope may be classified as normal when the road slope is within a predetermined range. The road slope may be classified as less than normal when the road slope is less than a first predetermined value. The road slope may be classified as greater than normal when the road slope is greater than a second predetermined value. The first predetermined value may be the lowest value in the predetermined range, and the second predetermined value may be the highest value in the predetermined range. Alternatively, the first predetermined value may be less than all of the values in the predetermined range, and the second predetermined value may be greater than all of the values in the predetermined range.
The vehicle driving conditions module 402 may determine the vehicle driving conditions based on one or more signals received from the sensors of
The vehicle driving conditions module 402 may determine the vehicle driving conditions based on one or more signals received from a wireless communication network such as a wireless telephone network and/or a satellite communication network (e.g., OnStar®). In the example shown in
The driver identification module 404 identifies the driver of using the driver identification signal 176 and outputs the driver identification. In one of the examples discussed above, the driver identification device 174 includes a camera that generates an image of the driver, and the driver identification device 174 includes image recognition software that identifies the driver based on the image generated. Alternatively, the driver identification signal 176 may simply contain the image of the driver, and the driver identification module 404 may include image recognition software that identifies the driver based on the image.
In another example discussed above, the driver identification device 174 includes a touchscreen that requests the driver to enter their identification by manipulating the touchscreen. In this example, the driver identification module 404 may instruct the driver identification device 174 to prompt the driver for their identification when, for example, the driver enters the vehicle. The driver identification module 404 may determine when the driver enters the vehicle based on an input received from a sensor (not shown) that detects when a door of the vehicle is opened.
In yet another example discussed above, the driver identification device 174 identifies the driver by communicating with the key fob. Alternatively, the driver identification module 404 may identify the driver by communicating with the key fob, and the driver identification device 174 may be omitted. The driver identification module 404 may assume that only one driver uses the key fob, or the key fob may be programmable to associate the driver therewith. The driver identification module 404 may communicate with the key fob using, for example, RF and/or bluetooth signals.
The driver behavior module 406 determines the behavior of the driver based on the driver identification and driver behavior data associated with the driver identification. The driver behavior module 406 may classify the driver behavior into multiple categories such as aggressive, typical, and conservative. The driver behavior data may include a history of the accelerator pedal position from the APP sensor 177 associated with the driver identification and one or more of the vehicle driving conditions. Additionally or alternatively, the driver behavior data may include a history of the brake pedal position from the BPP sensor 178 associated with the driver identification and one or more of the vehicle driving conditions. The driver behavior module 406 outputs the driver behavior, which may include the classification of the driver behavior associated with the driver identification and/or the driver behavior data associated with the driver identification.
The driver behavior may be classified as aggressive, typical, or conservative based on the magnitude and/or frequency of the driver acceleration and/or the driver braking. For example, the driver behavior may be classified as typical when the magnitude and/or frequency of the driver acceleration and/or the driver braking is/are within a predetermined range. The driver behavior may be classified as conservative when the magnitude and/or frequency of the driver acceleration and/or the driver braking is/are less than the predetermined range. The driver behavior may be classified as aggressive when the magnitude and/or frequency of the driver acceleration and/or the driver braking is/are greater than the predetermined range.
Additionally or alternately, the driver behavior may be classified as aggressive, typical, or conservative based on a relationship between (1) the driver acceleration and/or the driver braking, and (2) the vehicle driving conditions. For example, the driver behavior may be classified as aggressive when the driver consistently accelerates while the current vehicle speed is greater than the speed limit. In another example, the predetermined range(s) used to classify the driver behavior may vary depending on the vehicle driving conditions.
The driver behavior module 406 may store the driver behavior data. Alternatively, to save memory and computation costs, the driver behavior module 406 may transmit the driver behavior data and the corresponding driver identification and vehicle driving conditions to a second server 416. The second server 416 may store the driver behavior data, and the driver behavior module 406 may retrieve the driver behavior data when the current driver identification matches the driver identification associated with the driver behavior data. In this regard, the driver behavior module 406 may communicate with an antenna 418 that enables the driver behavior module 406 to communicate with the second server 416. The first and second servers 410 and 416 are separate from the vehicle and therefore may be referred to as remote servers.
In one example, the driver behavior module 406 uses the antenna 418 to transmit a third wireless signal 420 indicating the measured accelerator pedal position, the measured brake pedal position, the driver identification, and the vehicle driving conditions. The second server 416 stores a history of the measured accelerator and brake pedal positions, as well as the driver identification and the vehicle driving conditions associated therewith, and transmits a fourth wireless signal 422 indicating that driver behavior data. The driver behavior module 406 may then retrieve that driver behavior data when the driver identification matches the driver identification associated with the driver identification data, and determine the driver behavior based on the driver behavior data and the current vehicle driving conditions.
The example implementation of the driver torque module 202 shown in
In various implementations, the pedal position probability module 424 may develop a model of the driver behavior and use that model to determine the probability of a possible future pedal position. In one example, the model may include the probabilities of various pedal positions in various vehicle driving conditions. The pedal position probability module 424 may determine the probabilities in the model based on the driver behavior data. For example, the pedal position probability module 424 may increase the probability of a pedal position in certain vehicle driving conditions as the number of occurrences of that pedal position in those vehicle driving conditions increases. The pedal position probability module 424 may use interpolation to determine the probability of a pedal position in certain vehicle driving conditions where there are no occurrences of that pedal position in those vehicle driving conditions.
As discussed above, the vehicle driving conditions module 402 and the driver behavior module 406 may classify the vehicle driving conditions and the driver behavior, respectively, into multiple categories. Alternatively, the pedal position probability module 424 may classify the vehicle driving conditions and/or the driver behavior into multiple categories in the manner described above. In addition, the pedal position probability module 424 may determines the P probabilities of the P pedal positions for each of the N control loops based on which one of the multiples categories corresponds to the current vehicle driving conditions and/or the current driver.
In various implementations, the driver behavior module 406 and/or the pedal position probability module 424 may be separate from the vehicle (e.g., in the cloud). In these implementations, the vehicle driving conditions module 402 and the pedal position prediction module 426 may wirelessly communicate with the driver behavior module 406 and/or the pedal position probability module 424 using an antenna (not shown). In addition, the vehicle driving conditions module 402 may be omitted, and the pedal position prediction module 426 may receive the vehicle driving conditions directly from the vehicle sensors and/or the first server 410.
In addition, the pedal position probability module 424 may use one or more predetermined models of driver behavior to determine the probability of a possible future pedal position. For example, the predetermined models may include first, second, and third models that contain the probabilities of various pedal positions in various vehicle conditions for a typical driver, a conservative driver, and an aggressive driver, respectively. The pedal position probability module 424 may select one of the first, second, and third models based on the driver behavior model that matches the behavior of the current driver, and determine the probability of a possible future pedal position using the model selected.
The pedal position prediction module 426 predicts the pedal position for each of the N future control loops based on the P probabilities of the P possible values of the pedal position. For example, the pedal position prediction module 426 may set the predicted pedal position equal to the one of the P possible values having the highest one of the P probabilities. If more than one of the P possible values has the highest one of the P probabilities, the pedal position prediction module 426 may set the predicted pedal position equal to the one of those P possible values that is closest to the current pedal position. The pedal position prediction module 426 outputs the predicted pedal position for each of the N control loops.
The torque request module 428 determines the driver torque request 204. As discussed above, the driver torque request 204 may include a current driver torque request and future driver torque requests. The torque request module 428 may determine the current driver torque request based on a current value of a measured pedal position such as the accelerator pedal position from the APP sensor 177 and/or the brake pedal position from the BPP sensor 178. The torque request module 428 may determine the future driver torque requests based on the predicted pedal positions. For example, the torque request module 428 may determine a future driver torque request for each of the N future control loops based on a corresponding one of the N predicted pedal positions.
Referring now to
At 503, the pedal position prediction module 426 predicts a pedal position for each of the N future control loops. The pedal position predicted by the pedal position prediction module 426 may include a brake pedal position and/or an accelerator pedal position. As discussed above, the pedal position prediction module 426 may predict the pedal position for each of the N future control loops based on the current pedal position and the vehicle driving conditions.
At 504, the propulsion torque arbitration module 214 determines the propulsion torque request 222. The propulsion torque arbitration module 214 may determine the propulsion torque request 222 for the first one of the N control loops based on the current driver torque request, which may be determined based on the current pedal position. The propulsion torque arbitration module 214 may determine the propulsion torque request 222 for all subsequent ones of the N control loops based on the future driver torque requests, which may be determined based on the predicted pedal positions.
At 508, the reference value module 368 determines the reference values 340. As discussed above, the setpoint module 368 may determine the reference values 340 based on the propulsion torque request 222. At 510, the sequence determination module 316 determines possible sequences of the target values 230-244.
At 512, the prediction module 323 predicts parameters for each of the possible sequences of the target values 230-244. The prediction module 323 predicts the parameters for the possible sequences based on the model 324 of the engine 102, the exogenous inputs 328, and the feedback inputs 330. More specifically, based on a possible sequence of the target values 266-270, the exogenous inputs 328, and the feedback inputs 330, using the model 324, the prediction module 323 generates a sequence of predicted torques of the engine 102 for the N control loops, a sequence of predicted APCs for the N control loops, a sequence of predicted amounts of external dilution for the N control loops, a sequence of predicted amounts of residual dilution for the N control loops, a sequence of predicted combustion phasing values for the N control loops, and a sequence of predicted combustion quality values for the N control loops.
At 514, the cost module 332 determines the costs for the possible sequences of the target values 230-244. For example, the cost module 332 may determine the cost for a possible sequence of the target values 230-244 based on the equation:
Cost=Σi=1N[wTi*∥TPi−BATRi∥2+wFi*PTFi+wEiEPi],
subject to the actuator constraints 348 and/or the output constraints 352, as discussed above.
At 516, the selection module 344 selects one of the possible sequences of the target values 230-244 based on the costs of the possible sequences. For example, the selection module 344 may select the one of the possible sequences having the lowest cost. The selection module 344 may therefore select the one of the possible sequences that best achieves the predicted torque request while minimizing the APC. Instead of or in addition to determining possible sequences of the target values 230-244 at 510 and determining the cost of each of the sequences at 514, the MPC module 312 may identify a sequence of possible target values having the lowest cost using convex optimization techniques as discussed above.
At 518, the MPC module 312 determines whether the selected one of the possible sequences satisfies the actuator constraints 348 and the output constraints 352. If the selected one of the possible sequences satisfies the actuator constraints 348 and the output constraints 352, the method continues at 520. Otherwise, the method continues at 522, where the MPC module 312 selects the one of the possible sequences with the next lowest cost. The method then returns to 518. In this manner, the sequence with the lowest cost that satisfies the actuator constraints 348 and the output constraints 352 is used.
At 520, the first conversion module 248 converts the target wastegate opening area 230 into the target duty cycle 250 to be applied to the wastegate 162, the second conversion module 252 converts the target throttle opening area 232 into the target duty cycle 254 to be applied to the throttle valve 112. Also, at 520, the fourth conversion module 256 converts the target EGR opening area 234 into the target duty cycle 258 to be applied to the EGR valve 170.
At 524, the throttle actuator module 116 controls the throttle valve 112 to achieve the target throttle opening area 232. For example, the throttle actuator module 116 may apply a signal to the throttle valve 112 at the target duty cycle 254 to achieve the target throttle opening area 232. Also at 524, the bypass actuator module 168 controls the bypass valve 166 to achieve the target bypass valve position 233, and the valve actuator module 139 controls the intake and exhaust valve actuators 136 and 138 to achieve the target intake and exhaust valve lift states 236 and 238, respectively.
Also at 524, the EGR actuator module 172 controls the EGR valve 170 to achieve the target EGR opening area 234, and the boost actuator module 164 controls the wastegate 162 to achieve the target wastegate opening area 230. For example, the EGR actuator module 172 may apply a signal to the EGR valve 170 at the target duty cycle 258 to achieve the target EGR opening area 234, and the boost actuator module 164 may apply a signal to the wastegate 162 at the target duty cycle 250 to achieve the target wastegate opening area 230. Also at 524, the spark actuator module 126 controls the spark timing based on the target spark timing 240, the cylinder actuator module 120 controls cylinder activation and deactivation based on the target number 242 of cylinders, and the fuel actuator module 124 controls fueling based on the target fueling parameters 244. At 526, the method may end. Alternatively,
Referring now to
At 604, the vehicle driving conditions module 402 determines the vehicle driving conditions. As discussed above, the vehicle driving conditions may include a weather condition, current vehicle speed, a speed limit, a traffic condition, a road slope, and/or a road condition. In addition, the vehicle driving conditions module 402 may determine the vehicle driving conditions based on signals received from vehicle sensors and/or a wireless communication network.
At 606, the driver identification module 404 identifies the driver of the vehicle. At 608, the driver behavior module 406 determines whether driver behavior data is available for the driver identified. If driver behavior data is available, the method continues at 610. Otherwise, the method returns to 604 and does not predict the pedal position. In the latter case, the method may assume that the propulsion torque request remains constant during the N future control loops.
At 610, the driver behavior module 406 retrieves the driver behavior data. As discussed above, to save memory and computation time, the driver behavior module 406 may transmit the driver behavior data to the second server 416, which may store the driver behavior data. The driver behavior module 406 may then retrieve the driver behavior data when the current driver identification matches the driver identification associated with the driver behavior data.
At 612, the pedal position probability module 424 determines the P possible pedal positions for each of the N future control loops. For example, the pedal position probability module 424 may determine the P possible pedal positions based on the current pedal position and a predetermined range of possible rates of change in pedal position. At 614, the pedal position probability module 424 determines the P probabilities of the P possible pedal positions for each of the N future control loops.
At 616, the pedal position prediction module 426 predicts the pedal position for each of the N future control loops based on the P probabilities of the P possible pedal positions. In one example, the pedal position prediction module 426 sets the predicted pedal position for a future control loop equal to the one of the P possible pedal positons for that control loop which has the highest probability. If more than one of the possible pedal positions has the highest probability, the pedal position prediction module 426 may set the predicted pedal position equal to the one of those possible pedal positions that is closest to the current pedal position.
At 618, the torque request module 428 determines a driver torque request for each of the N future control loops based on the pedal position predicted for that control loop. At 620, the MPC module 312 determines the target values 230-244 based on the future torque requests. For example, the MPC module 312 may determine the cost associated with possible sequences of the target values 230-244 for the N control loops based on differences between the predicted torque output and the future torque request for each of the N control loops. The MPC module 312 may then select the possible sequence of the target values 230-244 that has the lowest cost while satisfying the actuator constraints 348 and the output constraints 352.
Instead of determining a future torque request based on a predicted pedal position and determining a target value for an engine actuator based on the future torque request, a system and method according to the present disclosure may determine the target value based directly on the predicted pedal positon. In addition, a system and method according to the present disclosure may determine the target value of the engine actuator based on the predicted pedal position without using MPC. For example, a system and method according to the present disclosure may determine the target value of the engine actuator using a function and/or a mapping that relates predicted pedal positions to target actuator values.
Referring now to
A system and method according to the present disclosure prevents compressor surge by controlling the wastegate 162 and/or the bypass valve 166 to avoid operating the compressor 160-2 in a surge region where compressor surge is likely to occur. In one example, the system and method opens the wategate 162 to avoid increasing compressor outlet pressure to a high level and thereby prevent compressor surge. In another example, the system and method opens the bypass valve 166 to relieve high compressor outlet pressure and thereby prevent compressor surge. In yet another example, the system and method determines the target bypass valve position 233 based on the mass flow rate of airflow through the compressor 160-2 and pressure downstream of the compressor 160-2 to avoid operating the compressor 160-2 in the surge region.
In yet another example, the system and method determines the reference wastegate opening area based on the compressor mass flow and the post compressor pressure to avoid the surge region. The system and method then determines the cost of possible sequences of the target values 230-244 for N future control loops based on a difference between the target wastegate opening area 230 and the reference wastegate opening area. Thus, the cost increases as the difference between the target wastegate opening area 230 and the reference wastegate opening area increases and vice versa.
In yet another example, the system and method determines the reference bypass valve position based on the compressor mass flow and the post compressor pressure to avoid the surge region. The system and method then determines the cost of possible sequences of the target values 230-244 for N future control loops based on a difference between the target bypass valve position 233 and the reference bypass valve position. Thus, the cost increases as the difference between the target bypass valve position 233 and the reference bypass valve position increases and vice versa.
In
A system and method may open a compressor bypass valve before a throttle is fully or substantially closed in order to prevent compressor surge. The throttle opening is typically determined based on an accelerator pedal position. However, the target compressor bypass valve position 902 and the target throttle opening 906 are not determined based on a predicted pedal position. Thus, a system and method that generates the signals shown in
The situation described above is illustrated at 914. At 914, the system and method starts to decrease the target throttle opening 906. Thus, shortly thereafter, the system and method starts to adjust the target compressor bypass valve position 902 from the fully closed position to the fully open position. In turn, the actual compressor bypass valve position 904 starts to move from the fully closed position to the fully open position. However, the compressor outlet pressure is not relieved fast enough to prevent compressor surge.
A system and method that generates the signals shown in
The foregoing description is merely illustrative in nature and is in no way intended to limit the disclosure, its application, or uses. The broad teachings of the disclosure can be implemented in a variety of forms. Therefore, while this disclosure includes particular examples, the true scope of the disclosure should not be so limited since other modifications will become apparent upon a study of the drawings, the specification, and the following claims. As used herein, the phrase at least one of A, B, and C should be construed to mean a logical (A OR B OR C), using a non-exclusive logical OR, and should not be construed to mean “at least one of A, at least one of B, and at least one of C.” It should be understood that one or more steps within a method may be executed in different order (or concurrently) without altering the principles of the present disclosure.
In this application, including the definitions below, the term “module” or the term “controller” may be replaced with the term “circuit.” The term “module” may refer to, be part of, or include: an Application Specific Integrated Circuit (ASIC); a digital, analog, or mixed analog/digital discrete circuit; a digital, analog, or mixed analog/digital integrated circuit; a combinational logic circuit; a field programmable gate array (FPGA); a processor circuit (shared, dedicated, or group) that executes code; a memory circuit (shared, dedicated, or group) that stores code executed by the processor circuit; other suitable hardware components that provide the described functionality; or a combination of some or all of the above, such as in a system-on-chip.
The module may include one or more interface circuits. In some examples, the interface circuits may include wired or wireless interfaces that are connected to a local area network (LAN), the Internet, a wide area network (WAN), or combinations thereof. The functionality of any given module of the present disclosure may be distributed among multiple modules that are connected via interface circuits. For example, multiple modules may allow load balancing. In a further example, a server (also known as remote, or cloud) module may accomplish some functionality on behalf of a client module.
The term code, as used above, may include software, firmware, and/or microcode, and may refer to programs, routines, functions, classes, data structures, and/or objects. The term shared processor circuit encompasses a single processor circuit that executes some or all code from multiple modules. The term group processor circuit encompasses a processor circuit that, in combination with additional processor circuits, executes some or all code from one or more modules. References to multiple processor circuits encompass multiple processor circuits on discrete dies, multiple processor circuits on a single die, multiple cores of a single processor circuit, multiple threads of a single processor circuit, or a combination of the above. The term shared memory circuit encompasses a single memory circuit that stores some or all code from multiple modules. The term group memory circuit encompasses a memory circuit that, in combination with additional memories, stores some or all code from one or more modules.
The term memory circuit is a subset of the term computer-readable medium. The term computer-readable medium, as used herein, does not encompass transitory electrical or electromagnetic signals propagating through a medium (such as on a carrier wave); the term computer-readable medium may therefore be considered tangible and non-transitory. Non-limiting examples of a non-transitory, tangible computer-readable medium are nonvolatile memory circuits (such as a flash memory circuit, an erasable programmable read-only memory circuit, or a mask read-only memory circuit), volatile memory circuits (such as a static random access memory circuit or a dynamic random access memory circuit), magnetic storage media (such as an analog or digital magnetic tape or a hard disk drive), and optical storage media (such as a CD, a DVD, or a Blu-ray Disc).
The apparatuses and methods described in this application may be partially or fully implemented by a special purpose computer created by configuring a general purpose computer to execute one or more particular functions embodied in computer programs. The functional blocks, flowchart components, and other elements described above serve as software specifications, which can be translated into the computer programs by the routine work of a skilled technician or programmer.
The computer programs include processor-executable instructions that are stored on at least one non-transitory, tangible computer-readable medium. The computer programs may also include or rely on stored data. The computer programs may encompass a basic input/output system (BIOS) that interacts with hardware of the special purpose computer, device drivers that interact with particular devices of the special purpose computer, one or more operating systems, user applications, background services, background applications, etc.
The computer programs may include: (i) descriptive text to be parsed, such as HTML (hypertext markup language) or XML (extensible markup language), (ii) assembly code, (iii) object code generated from source code by a compiler, (iv) source code for execution by an interpreter, (v) source code for compilation and execution by a just-in- time compiler, etc. As examples only, source code may be written using syntax from languages including C, C++, C#, Objective C, Haskell, Go, SQL, R, Lisp, Java®, Fortran, Perl, Pascal, Curl, OCaml, Javascript®, HTML5, Ada, ASP (active server pages), PHP, Scala, Eiffel, Smalltalk, Erlang, Ruby, Flash®, Visual Basic®, Lua, and Python®.
None of the elements recited in the claims are intended to be a means-plus-function element within the meaning of 35 U.S.C. §112(f) unless an element is expressly recited using the phrase “means for,” or in the case of a method claim using the phrases “operation for” or “step for.”