System and method for improving vehicle driveline operation
10597025 ยท 2020-03-24
Assignee
Inventors
- Kukhyun AHN (Ann Arbor, MI, US)
- Mohammad SHAKIBA-HERFEH (Royal Oak, MI, US)
- David Richens BRIGHAM (Ann Arbor, MI, US)
- Alexander T. ZAREMBA (Dearborn Heights, MI, US)
- Mark John JENNINGS (Saline, MI, US)
Cpc classification
B60W10/08
PERFORMING OPERATIONS; TRANSPORTING
B60K2006/4825
PERFORMING OPERATIONS; TRANSPORTING
B60W20/11
PERFORMING OPERATIONS; TRANSPORTING
B60W50/0098
PERFORMING OPERATIONS; TRANSPORTING
B60W10/06
PERFORMING OPERATIONS; TRANSPORTING
B60Y2300/188
PERFORMING OPERATIONS; TRANSPORTING
B60W50/00
PERFORMING OPERATIONS; TRANSPORTING
B60W20/15
PERFORMING OPERATIONS; TRANSPORTING
Y10S903/93
GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
B60W10/10
PERFORMING OPERATIONS; TRANSPORTING
B60W20/13
PERFORMING OPERATIONS; TRANSPORTING
B60K2006/268
PERFORMING OPERATIONS; TRANSPORTING
B60W2050/0019
PERFORMING OPERATIONS; TRANSPORTING
B60W20/16
PERFORMING OPERATIONS; TRANSPORTING
International classification
B60W20/15
PERFORMING OPERATIONS; TRANSPORTING
B60W10/10
PERFORMING OPERATIONS; TRANSPORTING
B60W20/13
PERFORMING OPERATIONS; TRANSPORTING
B60W50/00
PERFORMING OPERATIONS; TRANSPORTING
B60W20/16
PERFORMING OPERATIONS; TRANSPORTING
B60W10/08
PERFORMING OPERATIONS; TRANSPORTING
B60W10/06
PERFORMING OPERATIONS; TRANSPORTING
Abstract
Methods and systems for operating a hybrid driveline that includes an engine and an electric machine are presented. In one non-limiting example, the engine and electric machine are operated according to a solution of a Hamiltonian that includes a first co-state and a second co-state, an engine fuel flow parameter, a rate of change of battery state of charge parameter, and an emissions flow rate parameter.
Claims
1. A method for operating a driveline, comprising: operating a hybrid driveline via a controller adjusting one or more actuators based on a solution of a Hamiltonian, the Hamiltonian including a first co-state related to a rate of change of battery state of charge and a second co-state related to an emissions flow rate, an engine fuel flow parameter, a rate of change of battery state of charge parameter, and an emissions flow rate parameter, a solution to the Hamiltonian generated by increasing a value of the second co-state incrementally while holding the first co-state constant until a boundary of a domain of the second co-state is reached; and then, adjusting the first co-state to generate the solution to the Hamiltonian.
2. The method of claim 1, where the first co-state is a multiplier of the rate of change of battery state of charge parameter.
3. The method of claim 1, where the second co-state is a multiplier of the emissions flow rate parameter.
4. The method of claim 1, further comprising solving the Hamiltonian based on vehicle data or data from a simulation.
5. The method of claim 1, where the solution of the Hamiltonian is a value less than a threshold.
6. The method of claim 1, further comprising storing driveline control parameters to memory based on the solution of the Hamiltonian.
7. The method of claim 1, where the one or more actuators adjust engine torque.
8. A method for operating a driveline, comprising: determining co-states of a Hamiltonian vector, the Hamiltonian vector including a fuel flow parameter, a rate of change of battery state of charge parameter, and an emissions flow rate parameter; including: estimating first and second co-states of the Hamiltonian vector including a rate of change of battery state of charge as the first co-state and an emissions flow rate as the second co-state; increasing a value of the second co-state incrementally while holding the first co-state constant until a boundary of a domain of the second co-state is reached, and then adjusting the first co-state; and selecting a solution to the Hamiltonian vector from a plurality of solutions to the Hamiltonian vector; storing a fuel flow rate, a rate of change of battery state of charge, and an emissions flow rate to memory of a controller based on the solution; and adjusting an actuator of a driveline via the controller responsive to the stored fuel flow rate.
9. The method of claim 8, where the first co-state is a multiplier of the rate of change of battery state of charge and the second co-state is a multiplier of the emissions flow rate, and further comprising: adjusting the actuator of the driveline via the controller responsive to the emissions flow rate.
10. The method of claim 8, further comprising adjusting the actuator of the driveline via the controller responsive to the rate of change of battery state of charge.
11. The method of claim 8, where the first and second co-states are estimated via the controller.
12. The method of claim 8, further comprising incrementing the second co-state in response to a value of the second co-state being less than a threshold.
13. The method of claim 8, where the first co-state is incremented in response to a value of the first co-state being less than a threshold.
14. The method of claim 8, further comprising estimating the domain of the first co-state and the domain of the second co-state.
15. A vehicle system, comprising: an engine; an electric machine; a transmission including a torque converter; and a controller including executable instructions stored in non-transitory memory to adjust a state of an actuator in response to a solution of a Hamiltonian that includes a first co-state related to a rate of change of battery state of charge and a second co-state related to an emissions flow rate, an engine fuel flow parameter, a rate of change of battery state of charge parameter, and an emissions flow rate parameter, a solution to the Hamiltonian generated by increasing a value of the second co-state incrementally while holding the first co-state constant until a boundary of a domain of the second co-state is reached; and then, adjusting the first co-state to generate the solution to the Hamiltonian.
16. The vehicle system of claim 15, where the actuator is a throttle of the engine, where the first co-state is a multiplier of the rate of change of battery state of charge parameter, and where the second co-state is a multiplier of the emissions flow rate parameter.
17. The vehicle system of claim 15, where the actuator is a transmission gear actuator.
18. The vehicle system of claim 15, where the actuator is an electric machine controller.
19. The vehicle system of claim 15, further comprising additional instructions to select the solution from a plurality of solutions to the Hamiltonian.
20. The vehicle system of claim 19, where the plurality of solutions to the Hamiltonian is based on a plurality of values of the first co-state and the second co-state.
Description
BRIEF DESCRIPTION OF THE FIGURES
(1)
(2)
(3)
(4)
DETAILED DESCRIPTION
(5) The present description is related to operating a hybrid driveline based on optimization according to Pontryagin's minimization principal (PMP). The hybrid powertrain may include an engine as shown in
(6) Referring to
(7) Fuel injector 66 is shown positioned to inject fuel directly into cylinder 30, which is known to those skilled in the art as direct injection. Fuel injector 66 delivers liquid fuel in proportion to the pulse width from controller 12. Fuel is delivered to fuel injector 66 by a fuel system (not shown) including a fuel tank, fuel pump, and fuel rail (not shown). In one example, a high pressure, dual stage, fuel system may be used to generate higher fuel pressures.
(8) In addition, intake manifold 44 is shown communicating with turbocharger compressor 162 and engine air intake 42. In other examples, compressor 162 may be a supercharger compressor. Shaft 161 mechanically couples turbocharger turbine 164 to turbocharger compressor 162. Optional electronic throttle 62 adjusts a position of throttle plate 64 to control air flow from compressor 162 to intake manifold 44. Pressure in boost chamber 45 may be referred to a throttle inlet pressure since the inlet of throttle 62 is within boost chamber 45. The throttle outlet is in intake manifold 44. In some examples, throttle 62 and throttle plate 64 may be positioned between intake valve 52 and intake manifold 44 such that throttle 62 is a port throttle. Compressor recirculation valve 47 may be selectively adjusted to a plurality of positions between fully open and fully closed. Waste gate 163 may be adjusted via controller 12 to allow exhaust gases to selectively bypass turbine 164 to control the speed of compressor 162. Air filter 43 cleans air entering engine air intake 42.
(9) Distributorless ignition system 88 provides an ignition spark to combustion chamber 30 via spark plug 92 in response to controller 12. Universal Exhaust Gas Oxygen (UEGO) sensor 126 is shown coupled to exhaust manifold 48 upstream of catalytic converter 70. Alternatively, a two-state exhaust gas oxygen sensor may be substituted for UEGO sensor 126.
(10) Converter 70 can include multiple catalyst bricks, in one example. In another example, multiple emission control devices, each with multiple bricks, can be used. Converter 70 can be a three-way type catalyst in one example.
(11) Controller 12 is shown in
(12) During operation, each cylinder within engine 10 typically undergoes a four stroke cycle: the cycle includes the intake stroke, compression stroke, expansion stroke, and exhaust stroke. During the intake stroke, generally, the exhaust valve 54 closes and intake valve 52 opens. Air is introduced into combustion chamber 30 via intake manifold 44, and piston 36 moves to the bottom of the cylinder so as to increase the volume within combustion chamber 30. The position at which piston 36 is near the bottom of the cylinder and at the end of its stroke (e.g., when combustion chamber 30 is at its largest volume) is typically referred to by those of skill in the art as bottom dead center (BDC).
(13) During the compression stroke, intake valve 52 and exhaust valve 54 are closed. Piston 36 moves toward the cylinder head so as to compress the air within combustion chamber 30. The point at which piston 36 is at the end of its stroke and closest to the cylinder head (e.g., when combustion chamber 30 is at its smallest volume) is typically referred to by those of skill in the art as top dead center (TDC). In a process hereinafter referred to as injection, fuel is introduced into the combustion chamber. In a process hereinafter referred to as ignition, the injected fuel is ignited by known ignition means such as spark plug 92, resulting in combustion.
(14) During the expansion stroke, the expanding gases push piston 36 back to BDC. Crankshaft 40 converts piston movement into a rotational torque of the rotary shaft. Finally, during the exhaust stroke, the exhaust valve 54 opens to release the combusted air-fuel mixture to exhaust manifold 48 and the piston returns to TDC. Note that the above is shown merely as an example, and that intake and exhaust valve opening and/or closing timings may vary, such as to provide positive or negative valve overlap, late intake valve closing, or various other examples.
(15)
(16) For example, in response to a driver releasing an accelerator pedal and vehicle speed, vehicle system controller 255 may request a desired wheel torque to provide a desired rate of vehicle deceleration. The desired wheel torque may be provided by vehicle system controller requesting a first braking torque from electric machine controller 252 and a second braking torque from brake controller 250, the first and second torques providing the desired braking torque at vehicle wheels 216.
(17) In other examples, the partitioning of controlling powertrain devices may be partitioned differently than is shown in
(18) In this example, powertrain 200 may be powered by engine 10 and electric machine 240. In other examples, engine 10 may be omitted. Engine 10 may be started with an engine starting system shown in
(19) An engine output torque may be transmitted to an input side of powertrain disconnect clutch 236 through dual mass flywheel 215. Disconnect clutch 236 may be electrically or hydraulically actuated. The downstream side of disconnect clutch 236 is shown mechanically coupled to ISG input shaft 237.
(20) ISG 240 may be operated to provide torque to powertrain 200 or to convert powertrain torque into electrical energy to be stored in electric energy storage device 275 in a regeneration mode. ISG 240 has a higher output torque capacity than starter 96 shown in
(21) Torque converter 206 includes a turbine 286 to output torque to input shaft 270. Input shaft 270 mechanically couples torque converter 206 to automatic transmission 208. Torque converter 206 also includes a torque converter bypass lock-up clutch 212 (TCC). Torque is directly transferred from impeller 285 to turbine 286 when TCC is locked. TCC is electrically operated by controller 12. Alternatively, TCC may be hydraulically locked. In one example, the torque converter may be referred to as a component of the transmission.
(22) When torque converter lock-up clutch 212 is fully disengaged, torque converter 206 transmits engine torque to automatic transmission 208 via fluid transfer between the torque converter turbine 286 and torque converter impeller 285, thereby enabling torque multiplication. In contrast, when torque converter lock-up clutch 212 is fully engaged, the engine output torque is directly transferred via the torque converter clutch to an input shaft (not shown) of transmission 208. Alternatively, the torque converter lock-up clutch 212 may be partially engaged, thereby enabling the amount of torque directly relayed to the transmission to be adjusted. The controller 12 may be configured to adjust the amount of torque transmitted by torque converter 212 by adjusting the torque converter lock-up clutch in response to various engine operating conditions, or based on a driver-based engine operation request.
(23) Automatic transmission 208 includes gear clutches (e.g., gears 1-10) 211 and forward clutch 210. Automatic transmission 208 is a fixed ratio transmission. The gear clutches 211 and the forward clutch 210 may be selectively engaged to change a ratio of an actual total number of turns of input shaft 270 to an actual total number of turns of wheels 216. Gear clutches 211 may be engaged or disengaged via adjusting fluid supplied to the clutches via shift control solenoid valves 209. Torque output from the automatic transmission 208 may also be relayed to wheels 216 to propel the vehicle via output shaft 260. Specifically, automatic transmission 208 may transfer an input driving torque at the input shaft 270 responsive to a vehicle traveling condition before transmitting an output driving torque to the wheels 216. Transmission controller 254 selectively activates or engages TCC 212, gear clutches 211, and forward clutch 210. Transmission controller also selectively deactivates or disengages TCC 212, gear clutches 211, and forward clutch 210.
(24) Further, a frictional force may be applied to wheels 216 by engaging friction wheel brakes 218. In one example, friction wheel brakes 218 may be engaged in response to the driver pressing his foot on a brake pedal (not shown) and/or in response to instructions within brake controller 250. Further, brake controller 250 may apply brakes 218 in response to information and/or requests made by vehicle system controller 255. In the same way, a frictional force may be reduced to wheels 216 by disengaging wheel brakes 218 in response to the driver releasing his foot from a brake pedal, brake controller instructions, and/or vehicle system controller instructions and/or information. For example, vehicle brakes may apply a frictional force to wheels 216 via controller 250 as part of an automated engine stopping procedure.
(25) In response to a request to accelerate vehicle 225, vehicle system controller may obtain a driver demand torque from an accelerator pedal or other device. Vehicle system controller 255 then allocates a fraction of the requested driver demand torque to the engine and the remaining fraction to the ISG. Vehicle system controller 255 requests the engine torque from engine controller 12 and the ISG torque from electric machine controller 252. If the ISG torque plus the engine torque is less than a transmission input torque limit (e.g., a threshold value not to be exceeded), the torque is delivered to torque converter 206 which then relays at least a fraction of the requested torque to transmission input shaft 270. Transmission controller 254 selectively locks torque converter clutch 212 and engages gears via gear clutches 211 in response to shift schedules and TCC lockup schedules that may be based on input shaft torque and vehicle speed. In some conditions when it may be desired to charge electric energy storage device 275, a charging torque (e.g., a negative ISG torque) may be requested while a non-zero driver demand torque is present. Vehicle system controller 255 may request increased engine torque to overcome the charging torque to meet the driver demand torque.
(26) In response to a request to decelerate vehicle 225 and provide regenerative braking, vehicle system controller may provide a negative desired wheel torque based on vehicle speed and brake pedal position. Vehicle system controller 255 then allocates a fraction of the negative desired wheel torque to the ISG 240 (e.g., desired powertrain wheel torque) and the remaining fraction to friction brakes 218 (e.g., desired friction brake wheel torque). Further, vehicle system controller may notify transmission controller 254 that the vehicle is in regenerative braking mode so that transmission controller 254 shifts gears 211 based on a unique shifting schedule to increase regeneration efficiency. ISG 240 supplies a negative torque to transmission input shaft 270, but negative torque provided by ISG 240 may be limited by transmission controller 254 which outputs a transmission input shaft negative torque limit (e.g., not to be exceeded threshold value). Further, negative torque of ISG 240 may be limited (e.g., constrained to less than a threshold negative threshold torque) based on operating conditions of electric energy storage device 275, by vehicle system controller 255, or electric machine controller 252. Any portion of desired negative wheel torque that may not be provided by ISG 240 because of transmission or ISG limits may be allocated to friction brakes 218 so that the desired wheel torque is provided by a combination of negative wheel torque from friction brakes 218 and ISG 240.
(27) Accordingly, torque control of the various powertrain components may be supervised by vehicle system controller with local torque control for the engine 10, transmission 208, electric machine 240, and brakes 218 provided via engine controller 12, electric machine controller 252, transmission controller 254, and brake controller 250.
(28) As one example, an engine torque output may be controlled by adjusting a combination of spark timing, fuel pulse width, fuel pulse timing, and/or air charge, by controlling throttle opening and/or valve timing, valve lift and boost for turbo- or super-charged engines. In the case of a diesel engine, controller 12 may control the engine torque output by controlling a combination of fuel pulse width, fuel pulse timing, and air charge. In all cases, engine control may be performed on a cylinder-by-cylinder basis to control the engine torque output.
(29) Electric machine controller 252 may control torque output and electrical energy production from ISG 240 by adjusting current flowing to and from field and/or armature windings of ISG as is known in the art.
(30) Transmission controller 254 receives transmission input shaft position via position sensor 271. Transmission controller 254 may convert transmission input shaft position into input shaft speed via differentiating a signal from position sensor 271. Transmission controller 254 may receive transmission output shaft torque from torque sensor 272. Alternatively, sensor 272 may be a position sensor or torque and position sensors. If sensor 272 is a position sensor, controller 254 differentiates a position signal to determine transmission output shaft velocity. Transmission controller 254 may also differentiate transmission output shaft velocity to determine transmission output shaft acceleration.
(31) Brake controller 250 receives wheel speed information via wheel speed sensor 221 and braking requests from vehicle system controller 255. Brake controller 250 may also receive brake pedal position information from brake pedal sensor 154 shown in
(32) Thus, the system of
(33) It should be noted that the methods described herein are not limited to the system of
(34) Referring now to
(35) Actual or desired vehicle wheel torque and vehicle wheel speed are input to block 302. Simulation data may be input to block 302 where the simulation vehicle data is based on a desired vehicle speed and a desired wheel torque. Alternatively, actual requested vehicle wheel torque and actual wheel speed may be determined via an accelerator pedal position and a wheel speed sensors. The wheel torque and wheel speed are converted to a transmission output torque and a transmission output speed by multiplying the wheel torque and wheel speed by gear ratios in the driveline (e.g., an axle ratio). Further, the transmission output torque and speed may also include compensation for driveline losses. The transmission output torque and transmission output speed are input to block 304.
(36) At block 304, the transmission output torque is converted into a transmission input torque row vector with N elements that provides the transmission output torque, where N is the actual total number of transmission gears. Each of the N elements represents an input transmission torque that provides in the transmission output torque for a different gear. For example, element 1 of the row vector represents transmission input torque that provides the transmission output torque when the transmission is engaged in first gear. Element three of the row vector represents transmission input torque that provides the transmission output torque when the transmission is engaged in third gear. The values in the row vector may be determined by multiplying the transmission output torque by gear ratios in the transmission plus factors for transmission losses.
(37) The transmission output speed is converted into a transmission input speed row vector with N elements that provides the transmission output speed, where N is the actual total number of transmission gears. Each of the N elements represents an input transmission speed that provides the transmission output speed for a different gear. For example, element 1 of the row vector represents transmission input speed that provides the transmission output speed when the transmission is engage in first gear. Element three of the row vector represents transmission input speed that provides the transmission output speed when the transmission is engaged in third gear. The values in the row vector may be determined by multiplying the transmission output speed by gear ratios in the transmission plus factors for transmission losses. The transmission input torque and speed row vector are input to block 306.
(38) At 306, the transmission input speed row vector is a basis for providing a torque converter input speed vector. The torque converter input speed vector includes two torque converter input speed rows for each transmission input speed in the transmission input speed row vector. Thus, the number of columns in the transmission input speed row vector is doubled to provide the torque converter input row vector. The transmission input speed values in the transmission input speed row vector are modified to account for the two operating states of the torque converter clutch. For each speed value in the transmission input speed row vector, there is a corresponding torque converter input speed for a locked torque converter clutch and a torque converter input speed for an unlocked torque converter clutch in the torque converter input speed vector. The columns in the torque converter input speed vector correspond to particular transmission gears and torque converter states that result in the values in the torque converter input speed vector. For example, a first column in the torque converter input speed vector may be a torque converter input speed when the transmission is engaged in first gear and the torque converter clutch is open. An eight column in the torque converter input speed vector may be a torque converter input speed when the transmission is engaged in third gear and the torque converter is locked.
(39) Similarly, the transmission input torque row vector is a basis for providing a torque converter input torque vector. The torque converter input torque vector includes two torque convert input torque values for each transmission input torque in the transmission input torque row vector. Thus, the number of columns in the transmission input torque row vector is doubled to provide the torque converter input torque row vector. The transmission input torque values in the transmission input speed row vector are modified to account for the two operating states of the torque converter clutch. For each torque in the transmission input torque row vector, there is a corresponding torque converter input torque for a locked torque converter clutch and a torque converter input torque for an unlocked torque converter clutch in the torque converter input torque vector. The columns in the torque converter input torque vector correspond to particular transmission gears and torque converter states that result in the values in the torque converter input torque vector. For example, a first column in the torque converter input torque vector may be a torque converter input torque when the transmission is engaged in first gear and the torque converter clutch is open. An eight column in the torque converter input torque vector may be a torque converter input torque when the transmission is engaged in third gear and the torque converter is locked. For values that described a locked torque converter, the torque converter input torque matches the transmission input torque with small modification for torque converter clutch losses. If the torque converter clutch is open, the torque converter input torque is determined based on the torque converter's capacity factor, transmission input speed, and transmission input torque. The torque converter input torque row vector and the torque converter input speed row vector are input to block 308.
(40) At block 308, the torque converter input torque row vector and the torque converter input speed vector are the basis for providing a torque source row vector that includes entries for engine torque, engine speed, electric machine torque, and electric machine speed based on entries in the torque converter input torque row vector and torque converter input speed vector. The engine torque, engine speed, electric machine torque, and electric machine speed values in the torque source row vector are based on different torque split values (e.g., fraction of requested wheel torque provided by the engine and fraction of the requested wheel torque provided by the electric machine) for the present torque converter input speeds and torque converter input torques. For example, if an entry in the torque converter input torque row vector requires 100 N-m of torque to go with a torque converter input speed row vector entry of 2000 RPM, entries in the torque source vector may specify 80 N-m of engine torque at 2000 RPM and 20 N-m of electric machine torque at 2000 RPM. Of course, the size of the torque source vector may increase for each unique torque split requested between the engine and the electric machine. The columns in the torque source row vector correspond to particular transmission gears and torque converter states that result in the values in the torque converter input speed vector. For example, a first column in the torque source vector may be a torque converter input speed when the transmission is engaged in first gear and the torque converter clutch is open. An eight column in the torque source row vector may be a torque converter input speed when the transmission is engaged in third gear and the torque converter is locked.
(41) A torque source state row vector is determined from the engine speed, engine torque, electric machine speed, and electric machine torque in the torque source row vector. The torque source state row vector describes operating states of the torque sources that provide the speeds and torques in the torque source vector. In particular, engine fuel flow rate, engine emissions, and rate of change in state of charge for the battery are elements of the torque source state row vector and the torque source state row vector includes entries corresponding to entries in the torque source row vector. The engine fuel flow rate values may be determined from a model or empirically determined data stored in a table or function that is indexed by engine torque and engine speed. Likewise, engine emissions flow rates for NOx, CO, CO.sub.2, and hydrocarbons may be determined from a model or empirically determined data stored in a table or function that is indexed by engine torque and engine speed. Rate of change in battery charge may be determined based on a model of current consumption by the electric machine when the electric machine provides the torque in the torque source row vector. The columns in the torque source state row vector correspond to particular transmission gears and torque converter clutch states that result in the values in the torque converter input speed vector. For example, a first column in the torque source state vector may be a torque converter input speed when the transmission is engaged in first gear and the torque converter clutch is open. An eight column in the torque source state row vector may be a torque converter input speed when the transmission is engaged in third gear and the torque converter is locked. The torque source state row vector is input to block 310.
(42) At block 310, columns of the torque source state row vector that correspond to vehicle conditions that provide poor drivability are removed or alternatively values in the columns may be replace by predetermined values (e.g., 1,000,000). The drivability considerations may include but are not limited to skip shifting (e.g., shifting from 1.sup.st gear to 4.sup.th gear), shift/clutch engagement busyness (hunting), motor reserve torque for engine pull-up, transient motion of rotational inertias, and engine pull up and down busyness. The torque source state row vector is then input to block 312.
(43) At block 312, Pontryagin's minimization principal is applied. The minimization includes a Hamiltonian of the form: H={dot over (m)}.sub.f+.sub.SOCS{dot over (O)}C+.sub.e{dot over (m)}.sub.e where {dot over (m)}.sub.j is fuel flow rate to the engine, .sub.SOC is a co-state for rate of change in battery state of charge, S{dot over (O)}C is the rate of change in battery state of charge, .sub.e is a co-state for the engine emission flow rate, and {dot over (m)}.sub.e is the flow rate of exhaust from the engine. The Hamiltonian is minimized to determine which transmission gear, torque converter clutch state, engine torque, engine speed, electric machine torque, and electric machine speed that provides most desirable operating conditions for reduced fuel consumption by the engine, reduced battery state of charge reduction, and reduced engine emissions. Finding the minimum member of the Hamiltonian vector provides the optimal control decision at the present instant of the wheel torques and wheel speeds.
(44) The co-state for emissions flow rate and the co-state for rate of change of battery state of charge represent rates of change in the quantity being optimized (e.g., battery state of charge rate of change and engine emissions rate of change) as a function of a constraint parameter. They may also be described as Lagrange multipliers. The co-states may be initially estimated by a development engineer as discussed in further detail in the description of
(45) Values in the torque source state row vector are input to the Hamiltonian along with the co-state values and the Hamiltonian is solved for each value in the torque source state row vector, which corresponds to a particular transmission gear, torque converter clutch state, and torque sources providing the driveline torque. For example, if the engine is stopped, fuel flow is zero, engine emissions are zero, the emissions co-state is 5, the rate of change in battery state of charge is 0.003, and the battery state of charge rate of change is 1, at one condition for the torque source state row vector, the solution for the Hamiltonian is then given by: H={dot over (m)}.sub.f+.sub.SOCS{dot over (O)}C+.sub.e{dot over (m)}.sub.e0+(1).Math.(0.003)+5.Math.0=0.003. The solution to the minimized Hamiltonian, its corresponding engine fuel flow rate, its corresponding rate of change in battery state of charge, and its corresponding engine emissions flow rate are passed to 314. Further, the co-state values for the Hamiltonian are also passed to 314.
(46) At block 314, the PMP, or Hamiltonian minimum solution and its corresponding engine fuel flow rate, rate of change in battery state of charge, and engine emissions flow rate are stored to memory with the transmission gear, torque converter clutch state, and torque source split ratio (e.g., 30% electric machine torque and 70% engine torque) requirement that provide the minimum Hamiltonian solution. Further, the co-state values for the Hamiltonian may also be stored to memory. The transmission gear, torque converter clutch state, and battery state of charge rate of change are passed to block 315.
(47) At block 315, the hybrid powertrain or driveline operates the engine, electric machine, transmission, and torque converter clutch at optimized conditions based on driving conditions (e.g., requested wheel torque and present wheel speed) according to the engine fuel flow rate, rate of change in battery state of charge, and engine emissions where the Hamiltonian was minimized. For example, if the engine speed and electric machine speed were 2000 RPM for the vehicle's present speed and requested torque, a transmission gear is selected that adjusts engine and electric machine speed to 2000 RPM. Further, engine torque is adjusted via adjusting a throttle opening amount, fuel injection amount, and spark timing. Electric machine torque is adjusted such that the electric machine consumes charge from the battery at the rate of change in battery charge corresponding to a value of rate of change in battery charge where the Hamiltonian was minimized.
(48) Referring now to
(49) At 402, method 400 estimates of engine emissions co-state .sub.e domain. The domain of .sub.e may be a range of values (e.g., 5 to 10) of real numbers. The estimate may be provided by a development engineer (e.g., an estimate based on intuition or experience), or it may be based on the relationship between elements in the Hamiltonian, or it may be a range determined by a controller. Method 400 proceeds to 402 after the domain of co-state .sub.e is determined.
(50) At 404, method 400 estimates of battery state of charge rate of change co-state .sub.SOC domain. The domain of .sub.SOC may be a range of values (e.g., 0.01 to 1) of real numbers. The estimate may be provided by a development engineer (e.g., an estimate based on intuition or experience), or it may be based on the relationship between elements in the Hamiltonian, or it may be a range determined by a controller. Method 400 proceeds to 406 after the domain of co-state .sub.SOC is determined.
(51) At 406, method 400 estimates an initial value of the engine emissions co-state .sub.e. The initial value of .sub.e is selected to be within the domain of .sub.e. In one example, a first extent of the .sub.e domain is selected as the initial value of .sub.e so that the value of .sub.e may be incremented until a second extent of the .sub.e domain is reached by .sub.e. For example, if the domain of .sub.e is from 1 to 10, an initial value of .sub.e is 1 so that the value of .sub.e can be incremented until .sub.e=10.
(52) Method 400 also estimates an initial value of the battery state of charge rate of change co-state .sub.SOC. The initial value of .sub.SOC is selected to be within the domain of .sub.SOC. In one example, a first extent of the .sub.SOC domain is selected as the initial value of .sub.SOC so that the value of .sub.SOC may be decremented until a second extent of the .sub.SOC domain is reached by .sub.SOC. For example, if the domain of .sub.SOC is from 0.01 to 1, an initial value of .sub.SOC is 0.01 so that the value of .sub.SOC can be decremented until .sub.SOC=1. Method 400 proceeds to 408 after the initial values of .sub.e and .sub.COS are determined.
(53) At 408, method 400 increments the value of .sub.e each time method 400 returns to 408 from 418. The amount that .sub.e is incremented may be a fixed predetermined value. The value of .sub.e is not incremented the first time method 400 reaches 408 from 406. The value of .sub.e is incremented so that discrete values of .sub.e may be used to determine the minimized Hamiltonian over the .sub.e domain. Further, the value of .sub.SOC is set to its initial value (e.g., the minimum extent value of the .sub.SOC domain) if method 400 is returning to 408 from 418 so that the Hamiltonian may be evaluated over the .sub.SOC domain for each value of .sub.e. Method 400 proceeds to 410 after the incrementing (e.g., increasing) the value of .sub.e if method 400 is not passing through 408 from 406.
(54) At 410, method 400 increments the value of .sub.SOC each time method 400 returns to 410 from 416. The amount that .sub.SOC is incremented may be a fixed predetermined value. The value of .sub.SOC is not incremented each time method 400 reaches 410 from 408. The value of .sub.SOC is incremented so that discrete values of .sub.SOC may be used to determine the minimized Hamiltonian over the .sub.SOC domain.
(55) Alternatively, subsequent .sub.SOC co-state values may be determined based on Newton's method. In particular, after a simulation or drive cycle, a function that defines a relationship between the initial trial .sub.SOC and the final battery state of charge (SOC) may be expressed as:
f(.sub.SOC)=SOC.sub.final(.sub.SOC)SOC.sub.desired
where SOC.sub.final is the final value of SOC after the simulation or drive cycle, SOC.sub.desired is the desired final value of SOC after the simulation or drive cycle. Solving by Newton's method yields:
(56)
where n is the number of the .sub.SOC co-state estimate or guess, and f is the first derivative of function f, which may be numerically implemented as:
(57)
where .sub.SOC,n+2 is the nth plus two estimate of the .sub.SOC co-state. In this way, the .sub.SOC co-state root may be arrived at sooner than if the .sub.SOC co-state were simply decremented. Method 400 proceeds to 412 after incrementing or adjusting (e.g., increasing) the value of .sub.SOC if method 400 is not passing through 410 from 408.
(58) At 412, method 400 applies PMP optimization as described at 312 of
(59) At 414, method 400 determines the final battery state of charge value for the vehicle conditions that minimize the Hamiltonian. For example, if the initial battery state of charge before entering step 412 is 90 and the rate of change in battery state of charge reduces battery state of charge by 10 over the simulation or driving cycle, the SOC final is 80. The rate of change in battery state of charge is based on the .sub.SOC and .sub.e values that minimize the Hamiltonian. Method 400 proceeds to 416.
(60) At 416, method 400 judges if the final battery state of charge determined at 414 is approximately equal (e.g., within 3%) to a desired battery state of charge or if the value of .sub.SOC is equal to or less than a threshold, where the threshold is an extent of the .sub.SOC domain (e.g., 1 for the domain of .sub.SOC described above). The desired battery state of charge may be a predetermined value. If method 400 judges that the final battery state of charge is approximately equal to the desired battery state of charge, the answer is yes and method 400 proceeds to 418. Otherwise, the answer is no and method 400 returns to 410.
(61) At 418, method 400 judges if the value of .sub.e is equal to or greater than a threshold, where the threshold is an extent of the .sub.e domain (e.g., 10 for the .sub.e domain described above). If method 400 judges that the value of .sub.e is greater than the threshold, the answer is yes and method 400 proceeds to 420. Otherwise, the answer is no and method 400 returns to 408.
(62) At 420, method 400 outputs the solution to the minimized Hamiltonian, its corresponding engine fuel flow rate, its corresponding rate of change in battery state of charge, and its corresponding engine emissions flow rate. The engine fuel flow rate, rate of change in battery state of charge, and engine emissions flow rate are stored to controller memory with the transmission gear, torque converter clutch state, and torque source split ratio (e.g., 30% electric machine torque and 70% engine torque) requirement. The hybrid powertrain or driveline operates the engine, electric machine, transmission, and torque converter clutch at optimized conditions based on driving conditions (e.g., requested wheel torque and present wheel speed) according to the engine fuel flow rate, rate of change in battery state of charge, and engine emissions where the Hamiltonian was minimized. Method 400 proceeds to exit.
(63) In this way, the Hamiltonian may be evaluated according to a plurality of .sub.e co-states and .sub.SOC co-states. The .sub.e co-state may be incrementally increased from a first value to a last value to evaluate the Hamiltonian over a domain of the .sub.e co-state so that a least value solution of the Hamiltonian may be determined and used as a basis for controlling the hybrid driveline engine, transmission, and electric machine. Likewise, the .sub.SOC co-state may be incrementally increased from a first value to a last value to evaluate the Hamiltonian over a domain of the .sub.SOC co-state so that a least value solution of the Hamiltonian may be determined and used as a basis for controlling the hybrid driveline engine, transmission, and electric machine.
(64) Thus, the methods of
(65) Additionally, the methods of
(66) In some examples, the method further comprises adjusting the actuator of the driveline via the controller responsive to the emissions flow rate. The method further comprises adjusting the actuator of the driveline via the controller responsive to the rate of change of battery state of charge. The method includes where the first and second co-states are estimated via the controller. The method further comprises incrementing the second co-state in response to a value of the second co-state being less than a threshold. The method includes where the first co-state is incremented in response to a value of the first co-state being less than a threshold. The method further comprises estimating a domain of the first co-state and a domain of the second co-state.
(67) Note that the example control and estimation routines included herein can be used with various engine and/or vehicle system configurations. The control methods and routines disclosed herein may be stored as executable instructions in non-transitory memory and may be carried out by the control system including the controller in combination with the various sensors, actuators, and other engine hardware to manipulate operating states of the various devices disclosed. As will be appreciated by one of ordinary skill in the art, the methods described in
(68) This concludes the description. The reading of it by those skilled in the art would bring to mind many alterations and modifications without departing from the spirit and the scope of the description. For example, single cylinder, I2, I3, I4, I5, V6, V8, V10, V12 and V16 engines operating in natural gas, gasoline, diesel, or alternative fuel configurations could use the present description to advantage.