Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
SYSTEM AND APPROACH FOR VEHICLE CRUISE CONTROL
Document Type and Number:
WIPO Patent Application WO/2016/168213
Kind Code:
A2
Abstract:
Methods and systems presented for improving performance of a vehicle operating in a cruise control mode where a controller adjusts torque output from a vehicle to maintain vehicle speed within a desired range. The methods and systems may incorporate adapting a vehicle dynamics model and a vehicle fuel consumption model that provide input to nonlinear model predictive controller.

Inventors:
PEKAR JAROSLAV (CZ)
SANTIN ONDREJ (CZ)
MICHELINI JOHN OTTAVIO (US)
D'AMATO ANTHONY MARIO (US)
FILEV DIMITAR PETROV (US)
MULLEN JONATHAN THOMAS (US)
Application Number:
PCT/US2016/027165
Publication Date:
October 20, 2016
Filing Date:
April 12, 2016
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
HONEYWELL INT INC (US)
International Classes:
B60K31/00; B60W50/00; B60W30/14
Other References:
None
Attorney, Agent or Firm:
SHUDI, Jr., John et al. (Tufte & Wickhem LLP,100 South 5th Street, Suite 60, Minneapolis MN, US)
Download PDF:
Claims:
What is claimed is:

1. A vehicle system, comprising:

a vehicle including a motive torque source;

one or more sensors sensing one or more parameters related to operation of the

vehicle; and

a controller in the vehicle and in communication the one or more sensors, the

controller including executable instructions stored in non-transitory memory, the instructions including an adaptive nonlinear model predictive cruise control routine; and

wherein the controller executes the executable instructions to maintain the vehicle within a user defined parameter based, at least in part, on signals from the one or more sensors.

2. The vehicle system of claim 1, wherein the adaptive nonlinear model predictive cruise control routine includes a vehicle dynamics model and instructions for adapting the vehicle dynamics model.

3. The vehicle system of claim 2, wherein the vehicle dynamics model is adapted via recursive least squares.

4. The vehicle system of claim 1, wherein the adaptive nonlinear model predictive cruise control routine includes a vehicle fuel consumption model and instructions for adapting the vehicle fuel consumption model.

5. The vehicle system of claim 4, wherein the vehicle fuel consumption model is adapted via recursive least squares.

6. The vehicle system of claim 1, wherein the adaptive nonlinear model predictive cruise control routine adapts a vehicle dynamics model and a vehicle fuel consumption model realtime while the vehicle is operating on a road in a cruise control mode.

7. The vehicle system of claim 1, wherein the adaptive nonlinear model predictive cruise control routine outputs a torque demand to the motive torque source.

8. A vehicle system, comprising:

a vehicle including a motive torque source;

one or more sensors sensing one or more parameters related to operation of the

vehicle;

a controller in the vehicle and in communication with the one or more sensors, the controller including executable instructions stored in non-transitory memory, the instructions including an adaptive nonlinear model predictive cruise control routine with transmission neutral state activation; and wherein the controller is configured to execute the executable instructions to send a signal that selectively switches the vehicle from a neutral state to a geared state and vice versa to improve fuel efficiency of the vehicle based, at least in part, on signals from the one or more sensors.

9. The vehicle system of claim 8, further comprising a transmission coupled to the motive torque source, and wherein the adaptive nonlinear model predictive cruise control routine instructions include instructions for evaluating operating the vehicle with the transmission in neutral.

10. The vehicle system of claim 8, wherein adaptive nonlinear model predictive cruise control routine instructions include instructions for evaluating operating the vehicle at road conditions the vehicle is expected to encounter at a future time.

1 1. The vehicle system of claim 10, wherein the adaptive nonlinear model predictive cruise control routine instructions include instructions for evaluating operating the vehicle at road conditions the vehicle is expected to encounter at the future time responsive to a prediction horizon based on mapped road conditions.

12. The vehicle system of claim 8, wherein the adaptive nonlinear model predictive cruise control routine instructions include instructions to output a command to the motive torque source.

13. The vehicle system of claim 8, wherein the adaptive nonlinear model predictive cruise control routine instructions include instructions to adjust a torque command supplied to the motive torque source responsive to data derived from a lead vehicle operating on a same road as the vehicle.

14. The vehicle system of claim 8, wherein the adaptive nonlinear model predictive cruise control routine instructions include instructions to determine an optimal vehicle velocity profile and corresponding torque profile based on a predicted road grade ahead of a present position of the vehicle.

15. A vehicle cruise control method, comprising:

receiving vehicle information from one or more sensors to a controller;

providing a torque command responsive to output of an adaptive nonlinear model predictive cruise control routine executed by the controller and based, at least in part, on the received vehicle information; and

adjusting a torque actuator of a motive torque source responsive to the torque

command.

16. The method of claim 15, wherein the adaptive nonlinear model predictive cruise control routine provides for selectively shifting a transmission of a vehicle into neutral while the vehicle is operating in a cruise control mode.

17. The method of claim 15, wherein the torque command is within a first threshold range bounded by a first lower torque threshold and a first upper torque threshold if the adaptive nonlinear model predictive cruise control routine receives data from a convex shaped vehicle fuel consumption model while the vehicle is operating under a first set of conditions.

18. The method of claim 17, wherein the torque command is within a second threshold range bounded by a second lower torque threshold and a second upper torque threshold if the adaptive nonlinear model predictive cruise control routine receives data from a nonconvex shaped vehicle fuel consumption model while the vehicle is operating under the first set of conditions, the second threshold range greater than the first threshold range, the second lower torque threshold less than the first lower torque threshold.

19. The method of claim 15, wherein the motive torque source is an engine, the torque command is based on a prediction horizon, and the prediction horizon includes road grade data.

20. The method of claim 19, wherein the torque command is further based on a state of a lead vehicle ahead of a vehicle including the controller.

Description:
SYSTEM AND APPROACH FOR VEHICLE CRUISE CONTROL

Cross-Reference To Related Applications

This application claims the benefit of U.S. Provisional Patent Application No. 62/146,880, filed on April 13, 2015, and entitled "Method and System for Vehicle Cruise Control". U.S. Provisional Patent Application No. 62/146,880, filed on April 13, 2015, is hereby incorporated by reference.

This application claims the benefit of U.S. Provisional Patent Application No. 62/148,095, filed on April 15, 2015, and entitled "System and Approach for Fuel Economy Optimization in Cruise Control". U.S. Provisional Patent Application No. 62/148,095, filed on April 15, 2015, is hereby incorporated by reference.

Background

The present description relates generally to approaches and systems for controlling speed of a vehicle operating in a cruise control mode where a vehicle driver requests vehicle speed to be controlled automatically.

A vehicle may have its speed controlled automatically to a desired speed via a controller with little input from a vehicle driver. One example way for a controller to regulate vehicle speed is to operate the vehicle in a cruise control mode. Cruise control mode may be described as a vehicle operating mode where vehicle speed is maintained within a desired vehicle speed range bounded by upper and lower vehicle speed thresholds without the driver requesting torque from a vehicle motive power source. The controller maintains vehicle speed within the desired speed range via adjusting torque output of the vehicle's motive power source. Thus, vehicle speed is maintained within a desired speed range by increasing and decreasing torque output of the vehicle motive power source. One way for the controller to maintain vehicle speed is to proportionately adjust torque output from the vehicle motive power source based on an error in vehicle speed. The controller may apply a proportional/integral/derivative (PID) algorithm or some similar variant to adjust torque output of the vehicle motive power source and maintain vehicle speed within the desired vehicle speed range. However, PID vehicle speed control algorithms are reactionary in that they rely predominantly on a present or current vehicle speed error to provide a revised vehicle speed trajectory. Summary

Due to the above and because vehicles are often operated in a higher gear in cruise control mode, a controller of a vehicle may make large changes in torque it requests from the vehicle's motive power source. The swings in requested torque may increase vehicle fuel consumption and disturb the driver.

The above-mentioned issue may be noted and a vehicle system may be provided incorporating: a vehicle including a motive torque source; and a controller in the vehicle, the controller including executable instructions stored in non-transitory memory, the instructions including an adaptive nonlinear model predictive cruise control routine.

By adapting vehicle models and providing output from the adapted vehicle models to a nonlinear model predictive cruise control routine, it may be possible to provide the technical result of reducing vehicle torque demand swings while operating a vehicle in a cruise control mode. The torque swings may be reduced, at least in part, based on a priori road grade information. Further, adapting the vehicle model and a vehicle fuel consumption model real-time while the vehicle is in cruise control mode allows the nonlinear model predictive cruise control mode to adjust torque control strategy from a constant torque output to a pulse and glide torque output, thereby allowing multiple torque solution strategies from the controller for same driving conditions, excepting for changes in a vehicle fuel consumption model due to fuel properties or other changes in engine operating characteristics. The fuel economy optimal strategy is therefore selected automatically based on actual characteristic of the vehicle fuel consumption model.

The present description may provide several advantages. In particular, the approach may reduce the propensity for larger changes in requested vehicle torque to maintain vehicle speed. Additionally, the approach may reduce a vehicle's operating cost via reducing fuel consumption. Further, the approach may further reduce vehicle fuel consumption by actively requesting a transmission shift to neutral while operating the vehicle in cruise control mode.

The advantages and features of the present description may be readily apparent from the following the description when taken alone or in connection with the accompanying drawings. A summary may be provided to introduce in simplified form a selection of concepts that are further described in the detailed description. It is not necessarily meant to identify key or essential features of the claimed subject matter, the scope of which is defined uniquely by the claims that follow the description. Furthermore, the claimed subject matter is not necessarily limited to implementations that solve any disadvantages noted herein or in any part of this disclosure. Brief Description of the Drawings

Fig. 1 shows an example vehicle that may be included in the systems and methods described herein;

Fig. 2 shows an example vehicle and its electronic horizon;

Fig. 3 shows an example vehicle motive power source;

Fig. 4 shows an example vehicle driveline including the vehicle motive power source; Fig. 5 shows a block diagram of an example vehicle cruise control system;

Figs. 6A and 6B show an example method for adaptive nonlinear model predictive cruise control with fuel optimization and possibly with neutral select;

Fig. 7 shows a detailed example method of optimization for nonlinear model predictive cruise control, named at sequential quadratic programing (SQP) Iterations;

Fig. 8 shows a detailed example method for nonlinear model predictive cruise control with fuel optimization and with neutral select;

Figs. 9A and 9B show example vehicle fuel consumption models; and

Fig. 10 shows an example vehicle cruise control sequence with neutral select.

Description

The present description relates to systems and methods for improving operation of a vehicle operating in a cruise control mode. Fig. 1 shows a non-limiting example vehicle for operating in a cruise control mode where a controller applies a nonlinear model predictive cruise control algorithm with fuel optimization. Fig. 2 shows the example vehicle and an electronic horizon which provides input to the adaptive nonlinear model predictive cruise control algorithm. Figs. 3 and 4 show non-limiting vehicle motive power sources within a vehicle driveline. Fig. 5 is a block diagram of an example vehicle cruise control system. Methods for operating a vehicle in cruise control including one example version of the adaptive nonlinear model predictive cruise control algorithm are provided in Figs. 6A-8. Example vehicle motive power source fuel consumption models are shown in Figs. 9A and 9B. Fig. 10 is an example vehicle cruise control mode operating sequence.

Referring now to Fig. 1 , vehicle 100 may include a controller 12 for receiving sensor data, adjusting actuators, and/or other purposes. Controller 12 may operate vehicle 100 in a cruise control mode where vehicle speed is maintained within a desired vehicle speed range bounded by upper and lower vehicle speed thresholds. In some examples, controller 12 may cooperate with additional controllers to operate vehicle 100. Vehicle 100 is shown with global positioning system (GPS) receiver 130. Satellite 102 may provide time stamped information to GPS receiver 130 which may relay the information to vehicle position determining system 140. Vehicle positioning determination system 140 may relay present and future road grade data to controller 12. Vehicle 100 may also be equipped with optional camera 135 for surveying road conditions in the path of vehicle 135 and/or other purposes. For example, camera 135 may acquire road conditions from road side signs 166 or displays. Vehicle position determining system 140 may additionally or alternatively acquire information for determining vehicle position from stationary broadcast tower 104 via receiver 132. In some examples, vehicle 100 may also include a sensor 138 for determining the proximity of vehicles in the travel path of vehicle 100. Sensor 138 may be laser, sound, and/or radar signal based.

In this example, vehicle 100 is shown as a passenger vehicle. However, in some examples, vehicle 100 may be a commercial vehicle such as a freight hauling semi -trailer and truck, a train, a ship, and/or other type of vehicle.

Referring now to Fig. 2, an example vehicle 100 and a distance 210 corresponding to the vehicle's electronic horizon is shown. Vehicle 100 generates an electronic horizon (e.g., a data vector) comprised of road grade information for road 214. The electronic horizon may be made up of a plurality of blocks 220 or segments, and the blocks may have a single associated or corresponding road grade or slope. The block's length may be based on distance or time. The road grade information may be provided for a predetermined distance 210 or a predetermined amount of time in the vehicle's travel path. The road grade information may be provided to controller 12 shown in Fig. 1. For example, the road grade may be provided for a predetermined distance in the path of vehicle 100 (e.g., 100 meters, 200 meters, 300 meters, 500 meters, 1000 meters, 1500 meters, 2000 meters, and/or other distance). Alternatively or in addition, road grade may be provided for a predetermined amount of time into the future of the vehicle's travel path. For example, road grade may be provided 10 seconds into the future for a vehicle traveling at 1 10 Km/hr, or about 1833 meters.

Road grade data may be stored in memory of vehicle position determining system 140 shown in Fig. 1 and/or it may be determined based on road altitude values stored in memory. In one example, the road grade values may be retrieved from memory by indexing the memory based on vehicle position and heading. Values of road grade that occur over the predetermined distance or time may be stored as an array or vector in memory, and updates to the array may be provided as the vehicle moves (e.g., in a first-in first-out basis and/or in different basis). For example, if a road grade value is provided for every 100 meters of road surface, an array corresponding to 1500 meters of road grade data includes 15 blocks and corresponding road grade values. The road grade values may change step-wise between blocks.

Referring now to Fig. 3, an example vehicle motive power source is shown. In this example, the vehicle motive power source is a spark ignition engine. However, the vehicle motive power source may be a diesel engine, a turbine, or an electric machine.

Fig. 3 is schematic diagram showing one cylinder of a multi-cylinder engine 330 in an engine system 300. Engine 330 may be controlled at least partially by a control system including a controller 12 and by input from a vehicle operator 382 via an input device 380. In this example, the input device 380 includes an accelerator pedal and a pedal position sensor 384 for generating a proportional pedal position signal.

A combustion chamber 332 of the engine 330 may include a cylinder formed by cylinder walls 334 with a piston 336 positioned therein. The piston 336 may be coupled to a crankshaft 340 so that reciprocating motion of the piston is translated into rotational motion of the crankshaft. The crankshaft 340 may be coupled to at least one drive wheel of a vehicle via an intermediate transmission system. Further, a starter motor may be coupled to the crankshaft 340 via a flywheel to enable a starting operation of the engine 330.

Combustion chamber 332 may receive intake air from an intake manifold 344 via an intake passage 342 and may exhaust combustion gases via an exhaust passage 348. The intake manifold 344 and the exhaust passage 348 may selectively communicate with the combustion chamber 332 via respective intake valve 352 and exhaust valve 354. In some examples, the combustion chamber 332 may include two or more intake valves and/or two or more exhaust valves.

In this example, the intake valve 352 and exhaust valve 354 may be controlled by cam actuation via respective cam actuation systems 351 and 353. The cam actuation systems 351 and 353 may each include one or more cams and may utilize one or more of cam profile switching (CPS), variable cam timing (VCT), variable valve timing (VVT), and/or variable valve lift (VVL) systems that may be operated by the controller 12 to vary valve operation. The position of the intake valve 352 and exhaust valve 354 may be determined by position sensors 355 and 357, respectively. In alternative examples, the intake valve 352 and/or exhaust valve 354 may be controlled by electric valve actuation. For example, the cylinder 332 may alternatively include an intake valve controlled via electric valve actuation and an exhaust valve controlled via cam actuation including CPS and/or VCT systems. A fuel injector 369 is shown coupled directly to combustion chamber 332 for injecting fuel directly therein in proportion to the pulse width of a signal received from the controller 12. In this manner, the fuel injector 369 provides what is known as direct injection of fuel into the combustion chamber 332. The fuel injector may be mounted in the side of the combustion chamber or in the top of the combustion chamber, for example. Fuel may be delivered to the fuel injector 369 by a fuel system (not shown) including a fuel tank, a fuel pump, a fuel rail, and/or one or more other elements. In some examples, the combustion chamber 332 may alternatively or additionally include a fuel injector arranged in the intake manifold 344 in a configuration that provides what is known as port injection of fuel into the intake port upstream of the combustion chamber 332.

A spark may be provided to combustion chamber 332 via spark plug 366. The ignition system may further comprise an ignition coil (not shown) for increasing voltage supplied to spark plug 366. In other examples, such as a vehicle that runs on diesel, spark plug 366 may be omitted.

The intake passage 342 may include a throttle 362 having a throttle plate 364. In this particular example, the position of throttle plate 364 may be varied by the controller 12 via a signal provided to an electric motor or actuator included with the throttle 362, a configuration that is commonly referred to as electronic throttle control (ETC). In this manner, the throttle 362 may be operated to vary the intake air provided to the combustion chamber 332 among other engine cylinders. The position of the throttle plate 364 may be provided to the controller 12 by a throttle position signal. The intake passage 342 may include a mass air flow sensor 320 and a manifold air pressure sensor 322 for sensing an amount of air entering engine 330.

An exhaust gas sensor 327 is shown coupled to the exhaust passage 348 upstream of an emission control device 370 according to a direction of exhaust flow. The sensor 327 may be any suitable sensor for providing an indication of exhaust gas air-fuel ratio such as a linear oxygen sensor or UEGO (universal or wide-range exhaust gas oxygen) sensor, a two-state oxygen sensor or EGO sensor, a HEGO (heated EGO) sensor, a NO x sensor, HC sensor, or CO sensor. In one example, upstream exhaust gas sensor 327 may be a UEGO sensor configured to provide output, such as a voltage signal, that is proportional to the amount of oxygen present in the exhaust. Controller 12 may convert oxygen sensor output into exhaust gas air-fuel ratio via an oxygen sensor transfer function.

The emission control device 370 is shown arranged along the exhaust passage 348 downstream of the exhaust gas sensor 327. The device 370 may be a three way catalyst (TWC), NOx trap, various other emission control devices, or combinations thereof. In some examples, during operation of the engine 330, the emission control device 370 may be periodically reset by operating at least one cylinder of the engine within a particular air-fuel ratio.

The controller 12 is shown in Fig. 3 as a microcomputer, including a microprocessor unit 302, input/output ports 304, an electronic storage medium for executable programs and calibration values shown as read only memory chip 306 (e.g., non-transitory memory) in this particular example, random access memory 308, keep alive memory 310, and a data bus. The controller 12 may receive various signals from sensors coupled to the engine 330 in addition to those signals previously discussed, including signals indicating measurement of inducted mass air flow (MAF) from the mass air flow sensor 320; signals indicating engine coolant temperature (ECT) from a temperature sensor 323 coupled to a cooling sleeve 314; signals indicating an engine position signal from a Hall effect sensor 318 (or other type) sensing a position of crankshaft 340; signals indicating throttle position from a throttle position sensor 365; and signals indicating manifold absolute pressure (MAP) signal from the sensor 322. An engine speed signal may be generated by the controller 12 based, at least in part, on signals from crankshaft position sensor 318. Manifold pressure signals may provide an indication of vacuum, or pressure, in the intake manifold 344. Note that various combinations of the above sensors may be used, such as a MAF sensor without a MAP sensor, or vice versa. During engine operation, engine torque may be inferred from the output of MAP sensor 322 and engine speed. Further, signals from MAP sensor 322, along with the detected engine speed, may be a basis for estimating charge (including air) inducted into the cylinder. In one example, the crankshaft position sensor 318, which may be used as an engine speed sensor, may produce a predetermined number of equally spaced pulses every revolution of the crankshaft.

The storage medium read-only memory 306 may be programmed with computer readable data representing non-transitory instructions executable by the processor 302 for performing at least portions of the methods described herein as well as other variants that are anticipated but not specifically listed.

During operation, each cylinder within engine 330 may undergo 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 354 closes and intake valve 352 opens. Air may be introduced into combustion chamber 332 via intake manifold 344, and piston 336 may move to the bottom of the cylinder so as to increase the volume within combustion chamber 332. The position at which piston 336 is near the bottom of the cylinder and at the end of its stroke (e.g., when combustion chamber 332 is at its largest volume) may be referred to by those of skill in the art as bottom dead center (BDC).

During the compression stroke, intake valve 352 and exhaust valve 354 may be closed. Piston 336 may move toward the cylinder head so as to compress the air within combustion chamber 332. The point at which piston 336 is at the end of its stroke and closest to the cylinder head (e.g., when combustion chamber 332 is at its smallest volume) may be referred to by those of skill in the art as top dead center (TDC). In a process hereinafter referred to as inj ection, fuel is introduced into the combustion chamber. In a process hereinafter referred to as ignition, the injected fuel may be ignited by known ignition means such as spark plug 366, resulting in combustion.

During the expansion stroke, the expanding gases may push piston 336 back to BDC. Crankshaft 340 may convert piston movement into a rotational torque of the rotary shaft. Finally, during the exhaust stroke, the exhaust valve 354 may open to release the combusted air-fuel mixture to exhaust manifold 348 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.

As described above, Fig. 3 shows only one cylinder of a multi-cylinder engine, and each cylinder may similarly include its own set of intake/exhaust valves, fuel inj ector, spark plug, and so forth.

Referring now to Fig. 4, a schematic of a vehicle drive-train 400 is shown. Drive- train 400 may be powered by engine 330 as shown in greater detail in Fig. 3. In one example, engine 330 may be a gasoline engine. In alternate examples, other engine configurations may be employed, for example, a diesel engine. Engine 330 may be started with an engine starting system (not shown). Further, engine 330 may generate or adjust torque via torque actuator 404, such as a fuel injector, throttle, cam, and so on.

An engine output torque may be transmitted to torque converter 406 to drive a step- ratio automatic transmission 408 by engaging one or more clutches, including forward clutch 410, where the torque converter may be referred to as a component of the transmission. Torque converter 406 may include an impeller 420 that transmits torque to turbine 422 via hydraulic fluid. One or more gear clutches 424 may be engaged to change gear ratios between engine 310 and vehicle wheels 414. The output of the torque converter 406 may in turn be controlled by torque converter lock-up clutch 412. As such, when torque converter lock-up clutch 412 is fully disengaged, torque converter 406 may transmit torque to automatic transmission 408 via fluid transfer between the torque converter turbine 422 and torque converter impeller 420, thereby enabling torque multiplication. In contrast, when torque converter lock-up clutch 412 is fully engaged, the engine output torque may be directly transferred via the torque converter clutch 412 to an input shaft of transmission 408. Alternatively, the torque converter lock-up clutch 412 may be partially engaged, thereby enabling the amount of torque relayed to the transmission to be adjusted. A controller 12 may be configured to adjust the amount of torque transmitted by the torque converter by adjusting the torque converter lock-up clutch in response to various engine operating conditions, or based on a driver-based engine operation request.

Torque output from the automatic transmission 408 may in turn be relayed to wheels 414 to propel the vehicle. Specifically, automatic transmission 408 may adjust an input driving torque at the input shaft (not shown) responsive to a vehicle traveling condition before transmitting an output driving torque to the wheels. Vehicle speed may be determined via speed sensor 430.

Further, wheels 414 may be locked by engaging wheel brakes 416. In one example, wheel brakes 416 may be engaged in response to the driver pressing his foot on a brake pedal (not shown). In the similar way, wheels 414 may be unlocked by disengaging wheel brakes 416 in response to the driver releasing his foot from the brake pedal.

Referring now to Fig. 5, a block diagram of an example vehicle cruise control system is shown. Cruise control system 500 may include vehicle sensors as shown at block 502. Vehicle sensors may include but are not limited to sensors for determining vehicle motive power source torque, speed, energy consumption or fuel consumption, ambient environmental operating conditions, distance measuring devices, GPS signals, road conditions, and driver inputs. Driver inputs may include a desired vehicle speed, brake pedal position, accelerator pedal position, a higher vehicle speed threshold, and a lower vehicle speed threshold. Vehicle sensor information may be input to electronic horizon 510, controller constraints 508, the vehicle dynamics model 512, the model predictive cruise control optimizer 530, a recursive least squares parameter adaptor 504, a vehicle fuel consumption model 514, an engine torque model 516, and a lead vehicle model 518.

Electronic horizon block 510 may be included in controller 12 of Fig. 1 or it may be included in vehicle position determining system 140 shown in Fig. 1. An electronic horizon may be comprised of an array of memory locations or a vector of data and the array may include a plurality of road grade values that describe road grade of the road the vehicle is traveling. In one example, the electronic horizon extracts road grade values from a database that describes road conditions (e.g., grade values stored in memory, such as grade values extracted from a three dimensional map of the earth's surface). The road grade values may include road grade at the vehicle's present position as well as road grade values in front of the vehicle in the vehicle's path of travel. The road grade may be converted to road angle. Electronic horizon block 510 may update the array or vector of road grade values at selected times and sends the updated array to cruise control optimizer 530. The road grade values may be provided for a predetermined travel time in the future or for a predetermined distance in front of the vehicle.

At block 512, cruise control system 500 may incorporate a vehicle dynamics model.

The vehicle dynamics model is physics based and may be described as:

M —- F - F - F - F - F

dt Trac Aero Roll grad Γ Brake

where m is the vehicle mass, v is vehicle speed, Frrac is traction force defined as:

FAero is aerodynamic resistance defined as:

F Aero

FROII is rolling resistance of tires defined as:

F ROII = mg(k l v 2 +k 2 )coscp

Fgrad or F Grade is grade force defined as:

F Grade = mg sin φ

wheel brake force is Fbrake, driveline losses are ξ ΒΙ ; effective wheel radius is RWH; transmission gear ratio is y(G) ; selected gear ratio is G; the vehicle's final drive ratio is RFDR; motive power source brake torque is T; ambient air density is p ; the vehicle's frontal area is A; the vehicle's aerodynamic drag coefficient is <¾ gravitational acceleration is g; tire rolling resistance coefficients are ki and fe; road angle is φ ; / s time; and vehicle mass is m.

The vehicle dynamics model may be simplified to:

^ β,Τ + β^ + β,φ + β,

dt

where β ι - β^ are adaptive coefficients. The simplification allows for recursive least squares (RLS) adaptation, or another suitable method, of the β ι - β^ terms. The adaptive parameters may improve the vehicle dynamics model performance, and may improve vehicle dynamics model performance improves nonlinear model predictive controller performance. The adaptive parameters may be adjustable to compensate for changes in vehicle mass, wind, tire condition, and other vehicle operating conditions. The vehicle dynamics model may be further augmented by adding in a disturbance term d v , as shown here:

^ = β ι Τ + β 2 ν 2 3 φ +β 4 + ά ν .

at

The value of d v may be estimated more frequently than the beta terms, and in one example, it may be estimated via an Extended Kalman Filter. The parameter d v may be used in a diagnostic model to monitor the quality of the model. If the model accuracy is high, then d v 0.

At block 514, cruise control system 500 includes a vehicle fuel consumption model.

The vehicle fuel consumption model estimates vehicle fuel consumption, and it provides input to optimizing vehicle fuel economy in optimizer block 530. The vehicle fuel consumption may be expressed as a polynomial of the form:

m Fml = c 5 T 3 + c 2 + c 3 T + c 2 Tv + c x v + c 0

where m Fuel % fuel flow to the vehicle's motive power source; and co-cs are adaptive coefficients. The vehicle fuel flow model may allow for recursive least squares (RLS) adaption, or another suitable method, of the co-cs terms. The adapted parameters improve the vehicle fuel consumption model performance, and an improved vehicle fuel consumption model performance may improve nonlinear model predictive controller performance.

At block 504, cruise control system 500 may include a recursive least squares parameter estimator for adjusting the β and c coefficients for the vehicle dynamics model and the vehicle fuel consumption model, respectively. It is desirable to adjust the β and c coefficients as vehicle operating conditions change so that a desired level of controller performance may be achieved. The recursive least square estimator may recursively adapt the parameter vector x satisfying the set of equations (in a matrix form):

Λ

The new parameter estimate is:

where Hit is an m x n matrix, Kk is an n x m estimator gain, and y k - H k x k _ x is a correction term.

where the noise vk has zero mean and covariance Rt The estimator gain Kk and covariance matrix Pk may be updated as follows: The recursive least square estimator may be initialized by:

x 0 = E(x),

P 0 = E((x - x 0 ))(x - x 0 ) T )

where P 0 =∞I when there is no prior knowledge of x, and P 0 = 0 when x is known. Actual vehicle data used in the vehicle dynamics model and the vehicle fuel consumption model may be gathered and model coefficients may be adjusted using recursive least squares.

At block 516, cruise control system 500 includes an engine torque model for the vehicle's motive power source. The engine torque model may describe the delay in engine torque production from a time engine torque is requested. The engine torque model may be expressed as:

^ = l —T + l —T d

dt T(T d , N e ) T(T d , N e )

where τ is a time constant expressed as a function of engine speed N e and demand torque 7¾ and where T is engine or motive power source output torque. The demand torque is a function of a transmission in neutral flag or integer variable in memory. Specifically, engine torque demand may be:

Td=T in (l-Nfl) +T ld ieNfl

where T m is input torque; N z is the neutral flag (e.g., 1 for in neutral 0 for in a gear); and Tidie is engine idle torque. Engine speed is also a function of the transmission in neutral flag:

N e = & L Vi . ( i - Nfl ) + N e . Nfl where Nidie is engine idle speed, vi is vehicle speed, and the other variables are as previously described.

At block 518, cruise control system 500 may include a lead vehicle model (e.g., a model of a vehicle being followed by the vehicle operating in cruise control mode). The lead vehicle model may be applied for systems that have knowledge of vehicles in the path of the vehicle operating in cruise control mode. The lead vehicle model has little lead vehicle information, but it may be used to predict when vehicle acceleration is permitted and when vehicle deceleration may be desired. The lead vehicle may be modeled as:

dv l da x 1

— t ^ I

dt dt τ ι where vi is the actual speed of the lead vehicle, ai is acceleration of the lead vehicle and s a time constant representing time constant of expected acceleration. The distance between the lead vehicle and the vehicle operating in cruise control mode may be expressed as:

dD,

- v. - v

dt

where Di is the distance between the lead vehicle and the vehicle operating in cruise control mode and v is the speed of the vehicle operating in cruise control mode. The speed of the lead vehicle, vi, may be estimated from the following vehicle's radar or laser distance measuring device.

At block 506, vehicle cruise control system 500 includes a cost function. The cost function may describe control objectives or goals for the optimizer 530. For example, the cost function may seek to minimize fuel consumption, hold vehicle speed within a predetermined vehicle speed range bounded by an upper vehicle speed and a lower vehicle speed, maintain a minimum distance between vehicles, and/or constrain torque output of the vehicles motive power to less than a threshold torque. Specific details of one example cost function are described at 708 of Fig. 7.

At block 508, cruise control system 500 operating constraints may be determined from driver inputs and/or from variables or functions stored in memory. In one example, the driver may input a desired vehicle speed and upper and lower vehicle speed thresholds may be determined based on the desired vehicle speed. For example, a driver may input a desired vehicle speed of 100 KPH and an upper speed threshold of 110 KPH and a lower threshold of 90 KPH may be determined by adding and subtracting an offset value from the desired vehicle speed. In other examples, the vehicle system may adjust the upper threshold vehicle speed based on a posted road speed. For example, if a driver selects a desired vehicle speed of 90 KPH and the road speed limit is 100 KPH, the upper vehicle threshold speed may be adjusted to 100 KPH. The maximum motive power source torque and minimum vehicle following distance may be predetermined and stored in memory. Alternatively, the driver may input constraint values. Further, the desired vehicle speed and speed constraints may be temporarily adjusted via a driver applying the accelerator pedal.

At block 530, cruise control system 500 may apply input from blocks 506 through 518 to determine an optimal torque command or demand to output to the vehicle's motive power source. Further, optimizer 530 may selectively disengage a transmission forward gear putting the transmission into neutral (e.g., no engaged transmission gears decoupling the motive power source from vehicle wheels) to cause the vehicle to glide and increase vehicle fuel economy. Optimizer 530 may selectively engage a forward transmission gear after the transmission was previously shifted to neutral to maintain or increase vehicle speed. The optimizer may solve the optimization problem using sequential quadratic programming, see Fig.7 for additional details. Additional details as to operation of the optimizer are provided in the description of Figs. 6A-8.

At block 520, the vehicle's transmission may be shifted into neutral so that the vehicle begins gliding, or altematively, the vehicle's transmission may be shifted into a forward gear to accelerate the vehicle. The vehicle's transmission may be shifted into neutral by relieving hydraulic pressure on a gear clutch via a gear control solenoid. The vehicle's transmission may be shifted into a forward gear (e.g., 5 th gear) by applying hydraulic fluid pressure to a transmission gear clutch via a gear control solenoid.

At block 522, the vehicle's motive power source output torque may be adjusted. If the motive power source is an engine, engine torque may be increased via adjusting one or more of throttle position, spark timing, fuel injection timing, and cam timing or phase. If the motive power source is an electric machine, the machine torque may be adjusted via varying current supplied to the electric machine.

Thus, the cruise control system of Fig. 5 may provide a torque command to a vehicle motive power source and a gear or neutral command to a transmission to optimize vehicle fuel economy when the vehicle is operating in a cruise control mode. The controller may solve the cruise control problem by applying sequential quadratic programming.

The system of Figs. 1-5 provides for a vehicle system, comprising: a vehicle including a motive torque source; and a controller in the vehicle, the controller including executable instructions stored in non-transitory memory, the instructions including an adaptive nonlinear model predictive cruise control routine. The vehicle system includes where the adaptive nonlinear model predictive cruise control routine includes a vehicle dynamics model and instructions for adapting the vehicle dynamics model. The vehicle system includes where the vehicle dynamics model is adapted via recursive least squares. The vehicle system includes where the adaptive nonlinear model predictive cruise control routine includes a vehicle fuel consumption model and instructions for adapting the vehicle fuel consumption model. The vehicle system includes where the vehicle fuel consumption model is adapted via recursive least squares. The vehicle system includes where the adaptive nonlinear model predictive cruise control routine adapts a vehicle dynamics model and a vehicle fuel consumption model real-time while the vehicle is operating on a road in a cruise control mode. The vehicle system includes where the adaptive nonlinear model predictive cruise control routine outputs a torque demand to the motive torque source.

The system of Figs. 1 -5 also provides for a vehicle system, comprising: a vehicle including a motive torque source; and a controller in the vehicle, the controller including executable instructions stored in non-transitory memory, the instructions including an adaptive nonlinear model predictive cruise control routine with transmission neutral state activation. The vehicle system further comprises a transmission coupled to the motive torque source, and where the adaptive nonlinear model predictive cruise control routine instructions include instructions for evaluating operating the vehicle with the transmission in neutral. The vehicle system includes where adaptive nonlinear model predictive cruise control routine instructions include instructions for evaluating operating the vehicle at road conditions the vehicle is expected to encounter at a future time.

In some examples, the vehicle system includes where the adaptive nonlinear model predictive cruise control routine instructions include instructions for evaluating operating the vehicle at road conditions the vehicle is expected to encounter at the future time responsive to a prediction horizon based on mapped road conditions. The vehicle system includes where the adaptive nonlinear model predictive cruise control routine instructions include instructions to output a command to the motive torque source. The vehicle system also includes where the adaptive nonlinear model predictive cruise control routine instructions include instructions to adjust a torque command supplied to the motive torque source responsive to data derived from a lead vehicle operating on a same road as the vehicle. The vehicle system includes where the adaptive nonlinear model predictive cruise control routine instructions include instructions to determine an optimal vehicle velocity profile and corresponding torque profile based on a predicted road grade ahead of a present position of the vehicle.

Referring now to Figs. 6A and 6B, an example method 600 for adaptive nonlinear model predictive cruise control with fuel optimization is shown. At least portions of method 600 may be included in a system as shown in Figs. 1 -5 as executable instructions stored in non-transitory memory. The instructions may provide a control routine. Further, method 600 may include the methods of Figs. 7 and 8. Additionally, the method of Figs. 6A and 6B may provide the operating sequence shown in Fig. 10. The methods of Figs. 6A-8 may be performed real-time in a vehicle driving on a road.

At 602, method 600 initializes control parameters. Control parameters to be initialized in models and optimization routines may include but are not limited to present vehicle speed, present motive power source output torque, present motive power source speed, present motive power source fuel consumption rate, present road angle the vehicle is traveling on, and selected transmission gear. Method 600 proceeds to 604 after control parameters are initialized.

At 604, method 600 judges if cruise control mode is desired. Cruise control mode may be determined to be desired in response to a driver applying a button, switch, and/or issuing a voice command indicating a desire to enter cruise control mode. During cruise control mode, torque output of a motive power source is adjusted via controller 12 to maintain vehicle speed within a desired speed range bounded by an upper speed threshold (e.g., 100 KPH) and a lower speed threshold (e.g., 90 KPH). Thus, vehicle torque output is adjusted to maintain a desired vehicle speed. It may be judged that cruise control mode is not desired if a driver applies a brake, operates a button, switch, or issues a voice command. If method 600 judges that cruise control mode is desired, the answer is yes and method 600 proceeds to 606. Otherwise, the answer is no and method 600 exits.

At 606, method 600 receives new data from system sensors and memory. Sensor data may include but is not limited to vehicle speed, road grade or slope, motive power source torque output, motive power source fuel consumption or energy consumption, motive power source speed, and presently selected transmission gear. Data from memory may include but is not limited to cruise control constraints, desired vehicle speed, minimum vehicle following distance to lead vehicle, and controller tuning parameters. Method 600 proceeds to 608 after new data is received.

At 608, method 600 revises or updates the β and c coefficients for the vehicle dynamics model and the vehicle fuel consumption model described at blocks 512 and 514 of Fig. 5. The β and c coefficients are adjusted based on the new data received at 606 using recursive least squares, recursive least squares with exponential forgetting, or another suitable method. The revised models are the basis for system state observers that are also updated or revised based on the revised models. Method 600 proceeds to 610 after the model coefficients are revised.

At 610, method 600 applies nonlinear model predictive control to solve for an optimal torque trajectory without neutral engagement. The nonlinear model predictive control is applied to grade entries in the electronic horizon that extend from the vehicle's present position to the forward most position of the electronic horizon. The nonlinear model predictive control outputs optimal torque values based on the constraints in the cost function described at block 708 of Fig. 7 for entries in the electronic horizon. Method 600 proceeds to 612 after the nonlinear model predictive control without neutral is applied.

At 612, method 600 determines the expected fuel economy value E0 for the prediction horizon (e.g., road grade data in the electronic horizon) for conditions when the vehicle is not operated with a transmission in neutral. In one example, method 600 may estimate fuel economy for blocks (e.g., interval between grade values in the electronic horizon) in the electronic horizon by indexing a motive power source fuel or vehicle energy consumption model using the optimal torque value for the block determined at 610 and motive power source speed. The vehicle energy consumption model may store empirically determined fuel or energy consumption rates and outputs the rates. The fuel or energy consumption for the blocks may be stored to memory and method 600 proceeds to 614.

At 614, method determines a maximum time for neutral engagement. The time may be based on a time to achieve the lower vehicle speed threshold. The maximum time may be determined by imputing the vehicle's current operating conditions into the vehicle model described at block 512 of Fig. 5, setting engine brake torque to zero, and solving for a time it takes for the vehicle to coast or glide to the lower vehicle speed threshold. Method 600 proceeds to 616 after the maximum time for neutral engagement is determined.

At step 616, a nonlinear model predictive control may be applied to solve for an optimal torque trajectory with neutral engagement. In one example, the nonlinear model predictive control is applied to only a first grade entry in the electronic horizon ahead of the vehicle's present position to limit computational load. However, in other examples, nonlinear model predictive control may be extended to the length of the electronic horizon by increasing the controller's computational load. The nonlinear model predictive control outputs a transmission state control variable that requests the transmission enter neutral or engage a forward transmission gear based on the constraints in the cost function described at block 506 of Fig. 5 for entries in the electronic horizon. Further, the nonlinear model predictive control outputs an engine idle torque when neutral is determined to be a desired state. For blocks in the electronic horizon where neutral engagement is considered, the nonlinear model predictive controller changes simulation conditions to simulate when the transmission is in neutral and the motive power source is at idle or lower power output conditions. The nonlinear model predictive control with neutral is described in greater detail in the description of Fig. 8. Method 600 proceeds to step 618 after the nonlinear model predictive control with neutral is applied. At step 618, method 600 determines the expected fuel economy value El for the prediction horizon (e.g., road grade data in the electronic horizon) for conditions when the vehicle is operated with a transmission in neutral. In one example, method 600 estimates fuel economy for blocks (e.g., interval between grade values in the electronic horizon) in the electronic horizon by indexing a motive power source fuel or vehicle energy consumption model using the optimal torque values for the blocks determined at 610 and motive power source speed. The vehicle energy consumption model stores empirically determined fuel or energy consumption rates and outputs the rates. The fuel or energy consumption for the blocks in the electronic horizon vector are stored to memory and method 600 proceeds to step 620.

At step 620, method 600 judges if it is desired to operate the vehicle with the vehicle's transmission in neutral. In one example, the answer is yes and method 600 proceeds to step 622 in response to the expected fuel economy value El being greater than the expected fuel economy E0. In other words, if operating the vehicle in neutral provides higher fuel economy while vehicle speed is within the upper and lower speed thresholds, the answer is yes and method 600 proceeds to step 622. If the expected fuel economy value El is greater than the expected fuel economy value E0, or if vehicle speed is expected to be less than the lower threshold vehicle speed when the vehicle's transmission is in neutral, the answer is no and method 600 proceeds to step 630.

At step 622, method 600 selects a trajectory of control where the vehicle's transmission in neutral. The trajectory is the output from step 616 and it includes a vector or array that requests the vehicle's transmission operate in neutral at least in one block of the electronic horizon. The trajectory also includes a torque demand vector or array for operating the vehicle's motive power source operating at idle or another low energy consumption state (e.g., stopping engine operation or motor rotation). Method 600 proceeds to step 632 after selecting the desired control trajectory.

At step 630, method 600 selects a trajectory of control where the vehicle's transmission engaged in a forward gear. The trajectory is the output from step 610 and it includes a torque demand for maintaining vehicle speed within the upper and lower vehicle speed threshold values. The torque demand also provides for minimizing vehicle fuel consumption. Method 600 proceeds to step 632 after selecting the desired control trajectory.

At step 632, method 600 applies control actions to actuators and then waits for a next sample period. The control actions that are taken are for operating the vehicle in the electronic horizon block that corresponds to the present vehicle position. The control actions are based on the trajectory selected at step 622 or step 630. If the control action includes changing the vehicle's transmission operating state from neutral to a forward gear or vice- versa, a state of one or more transmission clutches may change to shift the transmission into neutral or a forward gear. The vehicle's motive power source output may be adjusted in response to a change in requested motive power source torque via changing a state of a torque actuator such as throttle position, cam timing, spark advance, fuel injection timing, or an amount of current supplied to an electric machine. Method 600 may return to step 604 after control actions are applied to the vehicle.

Referring now to Fig. 7, a detailed example of a numerical method for nonlinear model predictive cruise control is shown. The method uses sequential quadratic programming (SQP) to solve the nonlinear optimization problem. A j-th iteration of a SQP solver may be written as:

2

Ax = arg min /(V ) + f(x )Ax

δ '

The new iteration is given by:

x 1 ' 1 = x J + a J · Ax J

where a s is a suitable step length. Selection of a s is important to ensure fast convergence of the algorithm. Generally, a suitable value can be found by applying a line search algorithm. For the systems with relatively benign nonlinearities, the step length may be chosen as a constant, but it should also be chosen such that the cost function is decreasing in all foreseeable scenarios.

At step 704, method 700 receives new data from step 606 of Fig. 6A. Alternatively, method 700 may retrieve data from memory and vehicle sensors as is described at step 606 of Fig. 6A. Method 700 proceeds to step 706 after new data is received.

At step 706, method 700 performs simulations and linearization. The simulations and linearization are performed on the models describe a blocks 512-518. Assuming a nonlinear system is described by:

y(t) = g(x(t),u(t))

where x is the system state, u is the system input, y is the system output, and f and g denote functions. Simulating the system over the prediction or electronic horizon may be accomplished by solving the above ordinary differential equation numerically by a suitable solver, such as a basic forward Euler method. One step of the Euler method at time tk=to+kT s may be written as:

x( + i ) ~ )+ T s - f( x (h u ( ))

The linearization of the above ordinary differential equation at time tk=to+kT s in a point x(t k ),u(t k ) may be written as:

dAx(t k ) _ df(x(t k ),u(t k )) .Av g + fWO ½(

dt dx{t k ) du{t k ) dx{t k ) du{t k )

where

u(t k ) = u(t k ) + Au(t k )

x(t k )~x{t k ) = x{t k )

y(t k ) y(t k ) + y(t k )

The linearized system is discretized to obtain a finite parameterization in the system input and one step prediction:

Ay(t k ) = C k Ax(t k ) = D k Au(t k )

The approximate discretization may be written as:

df(x(t k ),u(t k )) B T )>"('*))

A k =I +

dx(t k ) k s )

g(x(t k )Mt k )) D„ _ s(x(t k )M ))

dx(t k ) " du{t k )

The linearization is evaluated at each sampling period for each block in the electronic or prediction horizon which enables forming a sensitivity matrices H for the predicted trajectory to the system inputs. The linearized prediction of the system output may be written as:

AY = HAU

where

Method 700 proceeds to step 708 after simulation and linearization are performed. At step 708, method 708 builds the quadratic programming (QP) problem. The QP problem is built based on a cost function and constraints. In one example, the cost function may be expressed as:

where J is the cost function variable, N is the prediction horizon based on the vector or array of the electronic horizon, qn is a penalty for tracking desired vehicle speed at the end of the prediction horizon, q m av g is the penalty for average fuel consumption on the predicted horizon, q va v g is the penalty for average vehicle speed tracking, and rr is the torque command activity.

The first term in the cost function represents the terminal penalty (vehicle speed at the end of the prediction horizon N). The second term is average fuel consumption over the prediction horizon. The third term is the average vehicle speed over the prediction horizon. Finally, the fourth term is the torque activity penalty ST(t k ) = T(t k ) - T(t k - 1) , or the change in engine or motive power source torque between k steps. The cost function constraints may be expressed as:

v mn - *i (t k ) < v(t k )≤ + <¾ (t k ), k = l, 2, . . . , N, vlim

T imn < T(t k )≤T max , k = l, 2, . . . , N c

D mn + t pmin v(t k )≤ (f k ) + ε 2 (t k ), k = \, 2, . . . , N D1I1

where N vlim is number of points of vehicle speed limit, N mim is a lead vehicle distance limit in the prediction horizon, and where and s 2 ¾) are auxiliary softening variables. The auxiliary softening variables s^) and s 2 ¾) ensure feasibility of the resulting nonlinear optimization problem, the vehicle speed limits and distance to the lead vehicle limit are handled as soft constraints by introducing auxiliary softening variables ^ ( ) and s 2 ¾) . Note that the minimum distance to the lead vehicle is comprised of two parts. The first part D m is the specified minimum distance and the second part i pmin v(¾) is parameterized by time i pmin which represents specified minimum time to reach D m gap between the host and lead vehicle. The optimization variable J may be the torque trajectory (together with softening variables) over the prediction horizon. A blocking technique may be used to reduce the number of the optimization variables with the goal of decreasing real-time computation and memory allocation. As a result, the control action of adjusting motive power source torque is not computed in each sampling period over the prediction horizon. Instead, several sampling times are blocked (grouped) and the control action within each block is assumed to be fixed (e.g., not changing). This may be expressed as a linear transformation of the optimization variable (torque)

T = B hl T hl

where ¾ is a transformation (blocking) matrix and torque trajectories

= [r( T(t 2 ) ... T{t N ) ,

T b , = [T(t bm ) T(t 2) ) ... T(t n ,

where ¾ is total number of blocks and ¾ is a vector of length specifying a number of samples in each individual block. Vector † bl becomes new optimization variable replacing the original trajectory T . Method 700 proceeds to step 710 after the QP problem is built.

At step 710, method 700 solves the QP problem. The final QP approximation in j-th SQP iteration may be describes as:

where T is the trajectory, j is iteration, is a vector of softening variables for vehicle speed limit where v min < s v (t k ) < v max , gj/ 1" is vector of softening variables for the distance limit to the lead vehicle where D mn ≤ s D (t k ) , the cost function j-th iteration as described above, Jj^ is a cost function associated with the softened vehicle speed limit given by

J Vtm = ^| 1 (i (t ) - s v ( )| , and jrj^ is a cost function associated with the softened distance limit to the lead vehicle given by J Dim = · Method 700

proceeds to step 712 after the QP problem is solved.

At step 712, method 700 updates or revises the solution. According to the SQP solver described above, the trajectory may be revised or updated as: The revised torque trajectory is the starting point for the next j+l)-th SQP iteration. Method 700 proceeds to step 714 after the solution is revised.

At step 714, method 700 judges if the solution has converged to an optimal solution. In some examples, the solution may be compared to the cost function. However, for receding horizon problems the solution may be determined to converge within a predetermined number of iterations (e.g., 1 or 2). If method 700 judges that the solution has converged to the optimal solution, the answer is yes and method 700 proceeds to exit or return to 610 of Fig. 6A.

Thus, the method of Fig. 7 may adjust a torque command supplied to a motive torque source responsive to a distance between the vehicle operating in cruise control mode and a lead vehicle ahead of the vehicle operating in cruise control mode when the vehicle is operating in a forward gear. The method of Fig. 7 also determines an optimal vehicle velocity profile based on constraints.

Referring now to Fig. 8, an example method for nonlinear model predictive cruise control with fuel optimization and with neutral select is shown. Neutral select refers to the controller having the capacity to change the vehicle's transmission operating state from a forward gear to neutral or vice-versa to improve vehicle fuel economy in cruise control mode. By commanding a transmission to neutral, it may be possible to increase or maintain vehicle speed on flat or negative road grades since engine braking and some driveline losses are not resisting a portion gravitational force acting on the vehicle when a transmission is shifted to neutral.

The transmission operating state is a binary variable having a value of 0 for the transmission not being in neutral and a value of 1 for the transmission being in neutral. If the electronic or prediction horizon is comprised of Nd points, the number of possible transmission operating state combinations for operating the transmission in a gear or neutral is ¾ . Therefore, the algorithm of Fig. 8 may be executed 2" ' ¾ to arrive at the minimum cost function. However, to reduce computational load on the controller, it may be desirable to iterate only once for a first block in the electronic or prediction horizon.

At step 804, method 800 receives new data from step 606 of Fig. 6A. Alternatively, method 800 may retrieve data from memory and vehicle sensors as is described at step 606 of Fig. 6A. Method 800 proceeds to step 806 after new data is received.

At step 806, method 800 selects one or more predefined neutral trajectories on the electronic or prediction horizon with suitable combinations of neutral engagement having a fixed duration and start position in the electronic or prediction horizon. All predefined neutral trajectories are evaluated together with corresponding computed torque traj ectories with respect to vehicle fuel economy and constraint violations. A trajectory that has not been evaluated is selected at step 806.

At step 808, the SQP procedure as described at step 706-714 of Fig. 7 is performed to determine a torque trajectory corresponding to the predefined neutral trajectory selected at step 806. Further, a corresponding estimate of fuel economy Ei on the prediction horizon is computed and stored to memory as described at step 612 of Fig. 6A. It should be noted that for evaluating neutral engagements, the motive power source torque is set to a low value such as zero or an engine idle torque when evaluating neutral engagement conditions so that the motive power source energy consumption or fuel consumption is accurate. Method 800 proceeds to step 810 after the SQP procedure is performed.

At step 810, method 800 judges if all combinations of neutral engagement have been evaluated. If so, the answer is yes and method 800 proceeds to step 812. Otherwise, the answer is no and method 800 returns to step 806 and the next neutral trajectory is evaluated.

At step 812, method 800 selects a neutral trajectory and corresponding torque trajectory that provides the best fuel economy from the combinations of neutral trajectories. Method 800 proceeds to exit or return to step 620 of Fig. 6B.

Thus, the method of Fig. 8 evaluates operation of a vehicle with a transmission in neutral while the vehicle is in a cruise control mode without the vehicle actually having to be in neutral. The evaluation may be at least partially based on road conditions the vehicle is expected to encounter at a future time, the road conditions at the future time based on a map of road conditions stored in memory.

The method of Figs. 6A-8 provides for a vehicle cruise control method, comprising: receiving vehicle information from one or more sensors to a controller; providing a torque command responsive to output of an adaptive nonlinear model predictive cruise control routine executed by the controller; and adjusting a torque actuator of a motive torque source responsive to the torque command. The method includes where the adaptive nonlinear model predictive cruise control routine provides for selectively shifting a transmission of a vehicle into neutral while the vehicle is operating in a cruise control mode. The method includes where the torque command is within a first threshold range bounded by a first lower torque threshold and a first upper torque threshold if the adaptive nonlinear model predictive cruise control routine receives data from a convex shaped vehicle fuel consumption model while the vehicle is operating under a first set of conditions. The method includes where the torque command is within a second threshold range bounded by a second lower torque threshold and a second upper torque threshold if the adaptive nonlinear model predictive cruise control routine receives data from a nonconvex shaped vehicle fuel consumption model while the vehicle is operating under the first set of conditions, the second threshold range having a greater torque difference between the second lower torque threshold and the second upper torque threshold than the torque difference between the first lower torque threshold and the first upper torque threshold, the second lower torque threshold less than the first lower torque threshold. The method includes where the motive torque source is an engine, where the torque command is based on a prediction horizon, and where the prediction horizon includes road grade data. The method includes where the torque command is further based on a state of a lead vehicle ahead of a vehicle including the controller.

Referring now to Fig. 9A, a plot of an example convex vehicle fuel consumption model is shown. The vehicle fuel consumption model may also be referred to as a map in some examples. The vertical axis represents fuel flow rate to an engine. The horizontal axis represents engine torque. The axis directed into the paper is engine speed. The vehicle fuel consumption model stores empirically determined values of fuel consumption or use rate corresponding to selected engine speeds and torques. The fuel consumption values form a convex surface when linked together as shown and viewed from a perspective of the horizontal axis. The vehicle fuel consumption model shape may change with fuel type (e.g., gasoline, alcohol and gasoline, alcohol), ambient engine operating conditions, and other conditions. The vehicle fuel consumption model shape (e.g., convex, non-convex, affine) may influence controller output since the optimal torque solution is also optimized for minimum fuel consumption. The vehicle fuel model shape and the expected controller output may be determined from values of coefficients of a polynomial that describes the vehicle fuel consumption model. For example, if the coefficients indicate the vehicle fuel model is convex, the controller described in Figs. 6A-8 may provide a narrow band torque request that varies between an upper torque threshold and a lower torque threshold, the lower torque threshold greater than zero torque. The torque solution output by the controller of Figs. 6A-8 may be referred to as a constant torque solution for a convex vehicle fuel consumption model, although the requested torque does vary to maintain vehicle speed. The narrow band torque request output by the controller for the convex vehicle consumption model includes a lower torque threshold that is a greater torque than a lower torque threshold for a non-convex vehicle fuel consumption model. Further, the narrow band torque request output by the controller for the convex vehicle fuel consumption model includes an upper torque threshold that is a lower torque than an upper torque threshold for the non-convex vehicle fuel consumption model.

Referring now to Fig. 9B, a plot of an example non-convex vehicle fuel consumption model is shown. The vehicle fuel consumption model may also be referred to as a map in some examples. The vertical axis represents fuel flow rate to an engine. The horizontal axis represents engine torque. The axis directed into the paper is engine speed. The vehicle fuel consumption model stores empirically determined values of fuel consumption or use rate corresponding to selected engine speeds and torques. The fuel consumption values form a non-convex surface when linked together as shown and viewed from a perspective of the horizontal axis. The torque solution output from the controller of Figs. 6A-8 may be referred to as a pulse and glide torque solution. The torque request may be pulse shaped swinging from zero torque requested at vehicle wheels to higher torque values than if a same route is driven in the same vehicle when the fuel model is convex. Thus, for a same vehicle driving a same route under same conditions except for the fuel consumption model shape, the controller of Figs. 6A-8 outputs the constant torque solution for a convex vehicle fuel consumption model and a pulse and glide torque solution for a non-convex fuel consumption model. The pulse and glide torque solution demands zero torque at the vehicle wheels at times such that the vehicle glides or coasts. Neutral engagement may be particularly useful for non-convex fuel consumption models as neutral engagement may extend the glide or zero torque duration. The pulse and glide torque solution may request greater torques than the constant torque solution. Thus, the controller torque solution (e.g., constant torque or pulse and glide) may be determined via the vehicle fuel consumption model shape.

Referring now to Fig. 10, an example vehicle cruise control sequence for the system of Figs. 1-5 and the method of Figs. 6A-8 is shown. Vertical markers at times T1-T4 represent times of interest during the sequence. All of the plots occur at a same time and same vehicle operating conditions. In cruise control mode, the vehicle wheel torque command or motive power source torque demand is provided via a controller other than a driver. The controller has objectives in cruise control mode that influence the torque demand output by the controller, and the objectives may be at least partially defined by constraints such as minimize fuel consumption, maintain vehicle speed within upper and lower threshold speeds that define a desired vehicle speed range, neutral use benefit, maximum neutral duration, and maximum wheel torque. The controller may vary the torque demand in cruise control mode to hold vehicle speed within the desired vehicle speed range without driver input to the controller or without the driver requesting torque from a motive power source. Thus, the torque command in cruise control mode may be based on a desired vehicle speed requested by a driver. A controller may adjust torque of a motive torque source to achieve the desired vehicle speed.

The first plot from the top of Fig. 10 is a plot of a calculated maximum neutral duration versus time. The maximum neutral duration corresponds to an amount of time a transmission may be in neutral while contemporaneously holding vehicle speed within a desired vehicle speed range. The maximum neutral duration may be estimate via a model as is described in the method of Figs. 6A-8. The horizontal axis represents time and time increases from the left side of the plot to the right side of the plot. The vertical axis represents the maximum neutral duration and the maximum neutral duration increases in the direction of the vertical axis arrow. Horizontal line 1002 represents a threshold maximum neutral duration that is to be exceeded for the transmission to be commanded into neutral if the transmission is in gear.

The second plot from the top of Fig. 10 is a plot of a calculated neutral use benefit versus time. The use benefit corresponds to vehicle fuel economy while the vehicle's transmission is shifted to neutral. The neutral use benefit may be estimated by determining vehicle fuel economy for when the transmission is in neutral. The horizontal axis represents time and time increases from the left side of the plot to the right side of the plot. The vertical axis represents the neutral use benefit and the benefit increases in the direction of the vertical axis arrow. Horizontal line 1004 represents a threshold neutral use benefit that is to be exceeded for the transmission to be commanded into neutral if the transmission is in gear.

The third plot from the top of Fig. 10 is a plot of transmission state versus time. The transmission state indicates if the transmission is in neutral or a gear. The horizontal axis represents time and time increases from the left side of the plot to the right side of the plot. The vertical axis represents transmission state. The transmission is in neutral when the trace is at a higher level near the vertical axis arrow. The transmission is in a gear when the trace is at a lower level near the horizontal axis.

The fourth plot from the top of Fig. 10 is a plot of vehicle velocity versus time. The horizontal axis represents time and time increases from the left side of the plot to the right side of the plot. The vertical axis represents vehicle velocity and vehicle velocity increases in the direction of the vertical axis arrow. Horizontal line 1006 represents a lower threshold vehicle velocity. The vehicle cruise controller's objective is to maintain vehicle velocity above threshold 1006 while the vehicle is in cruise control mode. At time TO, the vehicle is in cruise control mode. The maximum neutral duration is increasing from a middle level and the vehicle velocity is decreasing from a higher level within the cruise control desired vehicle speed range. Such conditions may be indicative of the vehicle approaching a top of a hill. The neutral use benefit is increasing from a lower level and the transmission is in a forward gear.

Between time TO and time Tl, the vehicle velocity continues to decrease and the maximum neutral duration increases to a value above threshold 1002. The neutral use benefit remains below threshold 1004 and the transmission remains in a forward gear. The transmission state does not change even though the maximum neutral duration exceeds threshold 1002 at times since the neutral use benefit does not exceed threshold 1004.

At time Tl, the transmission changes state from a forward gear to neutral. The transmission is shifted to neutral in response to the maximum neutral duration being greater than threshold 1002 and the neutral use benefit being greater than threshold 1004. The vehicle velocity begins to slowly decrease in response to the transmission being in neutral.

Between time Tl and time T2, the vehicle velocity continues to decrease and the transmission remains in neutral. The maximum neutral duration falls below threshold 1002 and the neutral use benefit falls below threshold 1004. Nevertheless, the transmission remains in neutral to extend the vehicle fuel economy benefit of gliding or coasting in neutral.

At time T2, the vehicle velocity decreases to threshold level 1006 and the transmission is shifted into a forward gear in response to vehicle speed being at or below threshold level 1006. The maximum neutral duration is less than threshold level 1002 and the neutral use benefit is less than threshold level 1004.

Between time T2 and time T3, the transmission remains engaged in a forward gear and the vehicle velocity increases. The maximum neutral duration also exceeds threshold 1002. The neutral use benefit is less than threshold 1004. The transmission does not enter neutral because threshold 1004 is not exceeded.

At time T3, the transmission changes state from a forward gear to neutral. The transmission is shifted to neutral in response to the maximum neutral duration being greater than threshold 1002 and the neutral use benefit being greater than threshold 1004. The vehicle velocity begins to slowly decrease in response to the transmission being in neutral.

Between time T3 and time T4, the vehicle velocity continues to decrease and the transmission remains in neutral. The maximum neutral duration falls below threshold 1002 and the neutral use benefit falls below threshold 1004. The transmission remains in neutral to extend the vehicle fuel economy benefit of gliding or coasting in neutral.

At time T4, the vehicle velocity decreases to threshold level 1006 and the transmission is shifted into a forward gear in response to vehicle speed being at or below threshold level 1006. The maximum neutral duration is less than threshold level 1002 and the neutral use benefit is less than threshold level 1004.

In this way, a transmission may be selectively shifted to and from neutral to extend vehicle fuel economy. The vehicle controller selectively shifts to neutral depending on conditions vehicle operating conditions and road grade or road slope value in the prediction or electronic horizon. The controller may act to shift the transmission to neutral in response to a negative road grade and other vehicle conditions. Further, the controller may act to shift the transmission to neutral in response to a change in road grade from a positive grade to a negative grade or zero grade as determined from the prediction or electronic horizon.

Note that the example control and estimation routines included herein can be used with various engine and/or vehicle system configurations. Further, the methods described herein may be a combination of actions taken by a controller in the physical world and instructions within the controller. 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. The specific routines described herein may represent one or more of any number of processing strategies such as event-driven, interrupt-driven, multi-tasking, multi-threading, and the like. As such, various actions, operations, and/or functions illustrated may be performed in the sequence illustrated, in parallel, or in some cases omitted. Likewise, the order of processing is not necessarily required to achieve the features and advantages of the example embodiments described herein, but is provided for ease of illustration and description. One or more of the illustrated actions, operations and/or functions may be repeatedly performed depending on the particular strategy being used. Further, the described actions, operations and/or functions may graphically represent code to be programmed into non-transitory memory of the computer readable storage medium in the engine control system, where the described actions are carried out by executing the instructions in a system including the various engine hardware components in combination with the electronic controller

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, 13, 14, 15, V6, V8, V10, and V12 engines operating in natural gas, gasoline, diesel, or alternative fuel configurations could use the present description to advantage.

The following claims particularly point out certain combinations and sub- combinations regarded as novel and non-obvious. These claims may refer to "an" element or "a first" element or the equivalent thereof. Such claims should be understood to include incorporation of one or more such elements, neither requiring nor excluding two or more such elements. Other combinations and sub-combinations of the disclosed features, functions, elements, and/or properties may be claimed through amendment of the present claims or through presentation of new claims in this or a related application. Such claims, whether broader, narrower, equal, or different in scope to the original claims, also are regarded as included within the subject matter of the present disclosure.

To recap, a vehicle system may incorporate a vehicle having a motive torque source, one or more sensors sensing one or more parameters related to operation of the vehicle, and a controller in the vehicle and in communication the one or more sensors, the controller having executable instructions stored in non-transitory memory, the instructions having an adaptive nonlinear model predictive cruise control routine. The controller may execute the executable instructions to maintain the vehicle within a user defined parameter based, at least in part, on signals from the one or more sensors.

The adaptive nonlinear model predictive cruise control routine may incorporate a vehicle dynamics model and instructions for adapting the vehicle dynamics model.

The vehicle dynamics model may be adapted via recursive least squares.

The adaptive nonlinear model predictive cruise control routine may incorporate a vehicle fuel consumption model and instructions for adapting the vehicle fuel consumption model.

The vehicle fuel consumption model may be adapted via recursive least squares.

The adaptive nonlinear model predictive cruise control routine may adapt a vehicle dynamics model and a vehicle fuel consumption model real-time while the vehicle is operating on a road in a cruise control mode.

The adaptive nonlinear model predictive cruise control routine may output a torque demand to the motive torque source.

A vehicle system may incorporate a vehicle having a motive torque source, one or more sensors sensing one or more parameters related to operation of the vehicle, a controller in the vehicle and in communication with the one or more sensors, the controller having executable instructions stored in non-transitory memory, the instructions having an adaptive nonlinear model predictive cruise control routine with transmission neutral state activation. The controller may be configured to execute the executable instructions to send a signal that selectively switches the vehicle from a neutral state to a geared state and vice versa to improve fuel efficiency of the vehicle based, at least in part, on signals from the one or more sensors.

The vehicle system may further incorporate a transmission coupled to the motive torque source. The adaptive nonlinear model predictive cruise control routine instructions may have instructions for evaluating operating the vehicle with the transmission in neutral.

The adaptive nonlinear model predictive cruise control routine instructions may incorporate instructions for evaluating operating the vehicle at road conditions the vehicle is expected to encounter at a future time.

The adaptive nonlinear model predictive cruise control routine instructions may incorporate instructions for evaluating operating the vehicle at road conditions the vehicle is expected to encounter at the future time responsive to a prediction horizon based on mapped road conditions.

The adaptive nonlinear model predictive cruise control routine instructions may incorporate instructions to output a command to the motive torque source.

The adaptive nonlinear model predictive cruise control routine instructions may incorporate instructions to adjust a torque command supplied to the motive torque source responsive to data derived from a lead vehicle operating on a same road as the vehicle.

The adaptive nonlinear model predictive cruise control routine instructions may have instructions to determine an optimal vehicle velocity profile and corresponding torque profile based on a predicted road grade ahead of a present position of the vehicle.

A vehicle cruise control approach may incorporate receiving vehicle information from one or more sensors to a controller, providing a torque command responsive to output of an adaptive nonlinear model predictive cruise control routine executed by the controller and based, at least in part, on the received vehicle information, and adjusting a torque actuator of a motive torque source responsive to the torque command.

The adaptive nonlinear model predictive cruise control routine may provide for selectively shifting a transmission of a vehicle into neutral while the vehicle is operating in a cruise control mode.

The torque command may be within a first threshold range bounded by a first lower torque threshold and a first upper torque threshold if the adaptive nonlinear model predictive cruise control routine receives data from a convex shaped vehicle fuel consumption model while the vehicle is operating under a first set of conditions.

The torque command may be within a second threshold range bounded by a second lower torque threshold and a second upper torque threshold if the adaptive nonlinear model predictive cruise control routine receives data from a nonconvex shaped vehicle fuel consumption model while the vehicle is operating under the first set of conditions, the second threshold range greater than the first threshold range, the second lower torque threshold less than the first lower torque threshold.

The motive torque source may be an engine, where the torque command is based on a prediction horizon, and where the prediction horizon has road grade data.

The torque command may be further based on a state of a lead vehicle ahead of a vehicle incorporating the controller.

Any publication or patent document noted herein is hereby incorporated by reference to the same extent as if each publication or patent document was specifically and individually indicated to be incorporated by reference.

In the present specification, some of the matter may be of a hypothetical or prophetic nature although stated in another manner or tense.

Although the present system and/or approach has been described with respect to at least one illustrative example, many variations and modifications will become apparent to those skilled in the art upon reading the specification. It is therefore the intention that the appended claims be interpreted as broadly as possible in view of the related art to include all such variations and modifications.