METHOD AND APPARATUS FOR IMPROVING THE FUEL ECONOMY OF A VARIABLE DISPLACEMENT ENGINE

Abstract
A secondary controller for controlling the performance of a moving automobile is described. The secondary controller can be configured to communicate with one or more vehicle controllers, such as the engine control unit, while the automobile is being driven. The secondary controller can send control commands, such as self-test or diagnostic commands to the vehicle controller to effect the operation of the vehicle's power train. The secondary controller can receive power train related data from the engine control unit and based upon the received power train data determine when to send the control commands. In one embodiment, the secondary controller communicates with the vehicle controller via the vehicle's diagnostic port, such as an OBD-II port. In another embodiment, the secondary controller can be configured to control a variable displacement engine in a vehicle to improve the fuel efficiency of the vehicle while it is driven.
Description
BACKGROUND

1. Field of the Described Embodiments


The described embodiments relate generally to automobile engine control. More particularly, apparatus and method for improving fuel efficiency in an automobile with a variable displacement engine are described.


2. Description of the Related Art


In automobile industry, there is a large aftermarket for devices that affect the factory performance of automobiles. One class of aftermarket devices is geared toward affecting the factory engine performance of an automobile. For instance, an aftermarket engine device can be designed to boost the power of the engine under certain conditions. As another example, an aftermarket automobile device can be configured to cause the engine to burn fuel more efficiently under certain conditions to increase fuel efficiency.


Modern automobile engines include engine control units. The engine control unit determines the amount of fuel, ignition timing and other parameters that affect the performance of an internal combustion engine. Aftermarket devices exist that can be used to overwrite the factory software and/or data in an engine control unit to change the engine performance. For instance, the factory look-up tables and/or control algorithms in the engine control unit that are used to generate the control commands for the engine can be overwritten. The overwrite modification of the engine control unit is performed while the automobile is in a non-operational state, i.e., not being driven, and then, after it is completed, the automobile can be operated, i.e., driven around, using the modified engine control unit.


The factory settings for an engine control unit are selected with the objectives of operating the engine under the conditions that don't needlessly damage the engine and achieving a desired operational lifetime for the engine. The selected factory settings are verified via large amounts of testing. A disadvantage of modifying the factory look-up tables and/or control algorithms in an engine control unit is that it typically voids the warranty the manufacturer provides on the engine. The manufacturer voids the warranty because they don't know whether aftermarket modifications will damage and/or shorten the lifetime of the engine. The possibility of engine damage and reduced engine lifetime are also a concern to a user modifying an engine control unit via an aftermarket device. In view of the above, methods and apparatus are desired that allow the factory engine performance of an automobile to be modified, such as to improve fuel efficiency, that minimize the risks associated with modifying the engine control unit.


SUMMARY OF THE DESCRIBED EMBODIMENTS

A secondary control unit (SCU) for affecting the performance an automobile is described. The SCU can be configured to communicate with one or more vehicle controllers, such as the engine control unit, while the automobile is being driven. Based on data received from the vehicle controllers, the secondary controller can send a control command, such as self-test or diagnostic commands to the vehicle controller to effect the operation of the vehicle, such as the operation of the vehicle's engine. Typically, a mechanic in conjunction with a testing device uses the control commands, such as the self-test or diagnostic commands, to diagnose a problem that is occurring with the vehicle. The mechanic determines which commands to use and when to implement each command. This work is performed while the vehicle is stationary, such as in the shop.


In one embodiment, the SCU can be implemented as an aftermarket device that is installed in a vehicle after it is manufactured. The SCU can be configured to receive power train related data from a vehicle controller, such an engine control unit, and based upon the received power train data determine when to send the control commands, such as the self-test or diagnostic commands. In one implementation, the SCU can send the control commands and receive data via the vehicle's diagnostic port, such as an OBD-II port. Thus, the SCU can include an interface that is compatible with the vehicle's diagnostic port. In a particular embodiment, the SCU is Controller Area Network (CAN) compatible and configured to send commands and receive data on the vehicle's CAN bus.


The SCU can include a processor and memory that are used to execute control algorithms that determine when to issue one or more different control commands, such as the self-test or diagnostic commands. The SCU is used in a vehicle with a variable displacement engine and the SCU includes control algorithms that determine when to issue a control command that effects the displacement of the engine. In a particular embodiment, the control algorithms can be configured to improve the fuel efficiency of the vehicle. The control command generated by the SCU can be sent to the vehicle's engine control unit, which can accept or reject the control command based criteria programmed in the engine control unit when the vehicle was manufactured.


One aspect of the embodiments described herein is related to an electronic device. The electronic device can be generally characterized as including: 1) a housing; 2) a processor and a memory disposed within the housing and 3) an interface that allows the processor and the memory to communicate with a vehicle having an engine control unit. The processor can be configured to a) receive from the engine control unit, power train state data characterizing a current operational state of the vehicle, b) based upon the power train state data, determine whether to send a control command, such as a self-test or a diagnostic command, to the vehicle where the control command effects operation of the vehicle while it is being driven; and c) when the control command is sent, receive a message from the vehicle indicating whether the control command has been implemented or rejected by the vehicle. In a particular embodiment, the vehicle can includes a variable displacement engine where the control command is for changing a displacement mode of the variable displacement engine. The processor can be further configured to repeatedly issue the control command to change the displacement mode of the engine while the vehicle is being driven based upon a current operational state to improve the fuel efficiency of the vehicle.





BRIEF DESCRIPTION OF THE DRAWINGS

The embodiments will be readily understood by the following detailed description in conjunction with the accompanying drawings, wherein like reference numerals designate like structural elements, and in which:



FIG. 1 shows a block diagram of a native ECU in an automobile coupled to a secondary ECU in accordance with the described embodiments.



FIG. 2A shows an example of a secondary control unit (SCU) in accordance with the described embodiments.



FIG. 2B shows an example of an on-board diagnostic interface for an automobile in accordance with the described embodiments.



FIG. 3 shows an example of a secondary control unit (SCU) mounted to the interior of an automobile in accordance with the described embodiments.



FIG. 4 is a flow chart of a method for controlling an vehicle subsystem in accordance with the described embodiments.



FIG. 5 is a flow chart of a method for controlling a variable displacement engine using a secondary CU in accordance with the described embodiments.



FIG. 6 is a flow chart of a method for controlling an engine including a data smoothing algorithm in accordance with the described embodiments.



FIG. 7 is a plot of smoothed and normalized power train data with local extremum determination in accordance with the described embodiments.





DESCRIBED EMBODIMENTS

In the following paper, numerous specific details are set forth to provide a thorough understanding of the concepts underlying the described embodiments. It will be apparent, however, to one skilled in the art that the described embodiments may be practiced without some or all of these specific details. In other instances, well known process steps have not been described in detail in order to avoid unnecessarily obscuring the underlying concepts.


Most modem automobile engines include an engine control unit (ECU). The ECU includes software and data for generating control parameters related to the operation of the engine, such as control of the fuel mixture, control of the ignition timing and control of the idle speed. Typically, a diagnostic and reporting capability is provided that allows data from the ECU to be accessed. The diagnostic and reporting capability can be used to access and fix problems associated with the engine.


Since 1996, the On-board diagnostic (OBD)-II specification has been made mandatory for all cars sold in the United States. Further, a version of OBD-II, EOBD and JOBD, are used in vehicles sold in Europe and Japan, respectively. The OBD-II standard specifies the type of diagnostic connector and its pin-out, the electrical signaling protocols that are available, and the messaging format used for communications. It also provides a candidate list of vehicle parameters to monitor along with how to encode the data for each. In addition, the OBD-II standard provides an extensible list of Diagnostic Trouble Codes (DTC)s. As a result of this standardization, a single device can query the on-board computer(s) in most vehicles.


The OBD-II Diagnostic Trouble Codes are 4-digits, preceded by a letter; P for engine and transmission, B for Body, C for Chassis and U for Network. Individual manufacturers often enhance the OBD-II code set with additional proprietary DTCs. Further, via the OBD-II interface, some manufactures provide access to advanced diagnostic functions. The advanced diagnostic functions that are available vary from manufacturer to manufacturer. The advanced diagnostic functions can include the ability to enter commands for bi-direction tests that allow various subsystem components to be evaluated. After receiving a test request, the ECU can be configured to report 1) whether the test was carried out or not and 2) data associated with the test.


The bi-directional tests can be implemented to confirm the proper or improper functioning of a vehicle component. For instance, a vehicle can be configured with a command that allows solenoids on the vehicle to be activated. A vehicle may have hundreds of such tests available. The bi-directional tests are implemented by a mechanic while the vehicle is at rest. As described in more detail below, apparatus and method are described that allow the bi-directional testing capability of a vehicle to be used to control a vehicle subsystem during operation of the vehicle. In a particular embodiment, a dongle, including a processor and a memory and an interface compatible with an OBD-II port, is configured to affect the operation of a vehicle's variable displacement engine while the vehicle is moving using a bi-directional test provided by the vehicle.


In more detail, with respect to FIG. 1, a block diagram of a secondary control unit coupled to an engine control unit is described. The secondary control unit can be configured to control operation of a vehicle sub-system component, such as the engine, using a bi-directional testing function. As is shown in FIG. 2A, in one embodiment, the secondary control unit can be provided as a dongle configured to interface with an OBD-II diagnostic interface. The OBD-II diagnostic interface is discussed with respect to FIG. 2B. With respect to FIG. 3, the mounting of an apparatus, such as the apparatus shown in FIG. 2A, within the interior of a vehicle is described. In FIG. 4, a method of controlling of a vehicle subsystem using a secondary control unit is described. In a particular embodiment, as described with respect to FIG. 5, the method is applied to controlling the operation of a variable displacement engine to improve fuel efficiency. With respect FIGS. 6 and 7, control algorithms that can be implemented in the secondary control unit are discussed. In one embodiment, the control algorithms can be used to determine a mode of operation for a variable displacement engine.



FIG. 1 shows a block diagram of a factory engine control unit (ECU) 10 in an automobile coupled to a Secondary Control Unit (SCU) 30. First, some details of the factory ECU 10 are described. The details include the configuration of the factory ECU 10 and how it communicates with other vehicle component. Next, details of an SCU 30 that can affect operations of the vehicle via communications with vehicle components, such as the factory ECU 10 are described.


The factory ECU 10 can include a processor 16, control algorithms executed by the process 20 and a memory 18. The memory 18 can store data, such as look-up tables, used by the processor 16 when executing the control algorithms 20. As described above, some aftermarket devices overwrite all or portion of the data in memory 18 and/or the control algorithms 20. In particular embodiments, as described herein, the data in memory 18 and the control algorithms 20 can be preserved so that the factory ECU 10 remains in the operational envelope proscribed by the manufacturer.


The term factory ECU 10 denotes that the engine control unit is operating with software or firmware approved by the manufacturer, such as the software/firmware installed in the ECU at the factory during manufacturer of the vehicle as well as software/firmware upgrades approved by the manufacturer and subsequently installed on the ECU. For the purposes of this description, an ECU where the control algorithms and/or data used in the control algorithms has been modified in an unapproved manner, such as via a third-party aftermarket device, is not considered a factory ECU for the purposes of this description.


The factory ECU 10 can be configured to communicate with and receive data from a number of microprocessors distributed throughout the vehicle. For example, a modem vehicle can include 40-50 such microprocessors associated with various subsystems. Some of these microprocessors can be coupled to sensors. Thus, the factory ECU 10 can be configured to receive sensor data 12 from various sensors distributed throughout the vehicle, such as temperature and pressure sensors associated with the operation of the engine. The factory ECU 10 can be configured to send control commands 14 to various vehicle subsystems. For instance, the factory ECU 10 can send out a command that affects the idle speed of the vehicle or the amount of fuel consumed by the engine.


The factory ECU 10 can communicate with and receive data from various modules, which can include sensors and other microprocessor, via a vehicle communication bus. One type of vehicle communication bus is a CAN (controller area network) bus or the CAN-bus. The bus conductor for the CAN-bus can be generated from different wire configurations. For instance, the CAN-bus can be provided on a single wire, a twisted pair of wires or a fiber optic cable. Thus, SCU 30 can be configured to interface with different types of vehicle communication bus conductors.


Different communication protocols can be implemented on the vehicle communication bus. The communication protocols specify the format of messages transmitted on the vehicle communication bus. One example of a communication protocol that can be utilized is the CAN protocol. It allows automotive components to communicate on a single or dual-wire networked data bus at speeds up to 1 Mbps. The communication speed that is implemented on the CAN-bus can vary from manufacturer to manufacturer. Thus, the SCU 30 can be configured to operate at different communication speeds depending on the communication speed associated with the electronics of a particular vehicle. Other examples of communication protocols can also be utilized on a vehicle communication bus include CAN, SAE J1939, GMLAN, OBD II, SAE J1587 and LIN. The SCU 30 can be configured to communicate using one or more of these protocols. For instance, in one embodiment, the SCU 30 can be configured to communicate using a first communication protocol when connected to a first vehicle and communicate using a second communication protocol when connected to a second vehicle.


Devices connected to the CAN-bus are referred to as nodes. Each node that is attached to the CAN-bus may be capable of sending and receiving signals. The nodes each have their own unique address on the network. Thus, each node can receive the inputs and data it needs to function, while ignoring information intended for other nodes that share the network. When a node transmits information over the network, the information is coded so all the other modules recognize where it came from.


Each node on the CAN-bus can include a host processor, a CAN controller and a transceiver. The host processor decides what received messages mean and which messages it wants to transmit itself. Sensors, actuators and other control devices can be connected to the host processor. The CAN controller includes a synchronous clock used to determine when to send messages. It stores received bits serially until an entire message is available at which time the message can be fetched by the host processor. The host processor can send messages to the CAN controller, which can then transmit the bits associated with the message serially onto the bus. The transceiver, which can be integrated into the CAN controller, can perform signal conditioning such as converting signal levels from the bus to levels that the CAN controller can interpret and converting signal levels from the CAN controller into a format compatible with the CAN-bus. As is described more detail as follows, the SCU 30 may be configured to communicate on the CAN-bus and thus, may include the components that allow it to act as a node on the CAN-bus.


Returning to FIG. 1, in one embodiment, a secondary electronic unit (SCU) 30 can be configured to communicate with the factory ECU 10 via the diagnostic port 22. A standard configuration for a diagnostic port 22 that is compatible with OBD-II is described below with respect to FIG. 2B. In some vehicles, the vehicle communication bus, such as the CAN-bus, can be accessed via the diagnostic port 22, such that a device connected to the diagnostic port 22 may send messages that are routed on the vehicle communication bus. In other vehicles, direct access to the vehicle bus may not be enabled via the diagnostic port 22. One reason to limit direct access to the vehicle communication bus from a device connected via the diagnostic port is that improper communications on the vehicle communication bus can interfere with critical commands needed for operating the vehicle.


In alternate embodiments, the SCU 30 can be coupled directly to the vehicle communication bus, such as a CAN-bus. If the SCU 30 is CAN compliant, it can include a CAN controller and transceiver that allows it to function as a node on the CAN-bus. Further, it can include an interface that allows it to be directly connected to the vehicle communication bus.


When the SCU 30 is configured to communicate on the CAN-bus via the diagnostic port 22 or some other interface to the CAN-bus (e.g., a direct connection), the SCU 30 can include a memory storing information that allows it to address different nodes on the CAN bus. Each node can have a different address and the CAN addresses can vary from manufacturer. Thus, if the SCU 30 is configured to operate with different vehicle types, the memory can include CAN addresses for multiple vehicles types. When installed in a particular vehicle, the SCU 30 can be configured to utilize the CAN addresses that are compatible with the vehicle type in which it is installed.


Via the diagnostic port 22 and/or another interface that provides access to the vehicle bus, the SCU 30 can monitor the status of the vehicle while it is moving, such as when a user is driving the vehicle. For instance, the SCU 30 can obtain current vehicle operating parameters, such as the engine RPM, temperatures and pressures associated with various sensors, an accelerator pedal position, a load on the engine, etc. Obtaining this information may involve bi-directional communications with various vehicle controllers. For instance, the SCU 30 can be configured to communicate with the factory ECU 10 or a transmission control unit (TCU) in a bi-directional manner. In addition, the SCU 30 can be configured to send commands associated with various self-tests and diagnostics available on the vehicle. Each vehicle controller on the vehicle communication bus can be enabled with different self-tests and diagnostics that are implemented when the controller receives the proper command. In response to the commands associated with the self-tests and diagnostics, the SCU 30 can receive information, such as but not limited to, an acknowledgement that the command was carried out, b) an acknowledgement that the command wasn't carried out and possibly a reason why the command wasn't carried out and/or c) the data associated with the implementation of the command.


The self-tests and diagnostics and their associated commands can vary from vehicle to vehicle. In one embodiment, the SCU 30 can be compatible with multiple vehicle types. Thus, the SCU 30 may store commands and control algorithms tailored to the self-tests and diagnostics available on each vehicle. When installed in a particular vehicle, the SCU 30 may determine the type of vehicle in which it is installed and self-configure to be compatible with the vehicle. In another embodiment, the SCU 30 can include an interface that allows the vehicle type to be set on the device, such as via a user input.


A vehicle can include many different types of control units that control various aspects of the vehicle. Each of the control units can be configured to accept different control commands including the self-test and diagnostic commands. In various embodiments, the SCU 30 can be configured to utilize any type of control command recognized by a control unit on a vehicle, such as the ECU.


In some instances, the control commands which are available through a vehicle interface, such as the diagnostic port, can be limited in some manner For instance, the ECU can be configured to block or ignore certain control commands that are available on the vehicle when they are received via the diagnostic port. In some embodiments, the SCU 30 can be configured with logic or a physical interface that bypasses a command block implemented on a vehicle so that a control command generated by the SCU 30 that would normally be blocked is accepted. In other embodiments, the software in the ECU can be modified in some manner to remove the block that prevents a control command issued from the SCU 30 from being utilized.


The SCU 30 can include an interface 32 that allows for communications with various vehicle components, such as a vehicle's ECU or TCU (Transmission Control Unit). In one embodiment, the interface 32 is a connector with a wire lead where the connector is compatible with a vehicle interface, such as the diagnostic port 22. In a particular embodiment, the connector can be compatible with an OBD-II interface port. In another embodiment, the connector can be compatible with an available port that allows for communications on the vehicle communication bus, such as a CAN-bus.


In yet another embodiment, a wireless communication link can be used between the connector to vehicle interface and the body of the SCU 30. Thus, a wire lead may not be required. The vehicle interface may allow power to be transferred from the vehicle to the SCU 30. When a wireless communication interface is used, the SCU 30 may include its own power supply in lieu of receiving power from the vehicle.


In the SCU 30, the interface 32 can be coupled to a communication interface 35. The communication interface 35 can format communications to be compatible with a particular communication protocol. For instance, the communication interface 35 can format voltage level of the communications to be compatible with the diagnostic port 22 or a CAN-bus (not shown). In one embodiment, as described above, the communication interface can include a CAN controller and a CAN compatible transceiver so that the SCU 30 can act as a node on a CAN-bus.


The processor 34 communicates with vehicle components, such as but not limited to the factory ECU 10, via the communication interface 35 and interface 32. The processor 34 can be configured to format the communications to be consistent with one or more different communication protocols, such as but not limited to CAN. The memory 38 can store information used to enable the communications, such as protocol specific data. Further, it can store information that allows specific vehicle components to be addressed, such as CAN addresses on the CAN bus.


As described above, the processor 34 can be configured to issue one or more different control commands that are associated with self-tests and diagnostics available on the vehicle. The control commands can be used to affect one or more different vehicle subsystems, such as the engine or the transmission. As an example, the processor 34 can be configured to issue control commands that affect the engine displacement, the spark timing and/or the torque controller.


The processor 34 can be configured to execute control algorithms 40 that determine when to issue the control commands. The control algorithms can be affected by the vehicle operational state data. The processor 34 can be configured to monitor the vehicle's operational state and receive data associated with the current operational state, such as the latest data from various sensors disposed within the vehicle. As an example, as will be described in more detail below, accelerator pedal position data can affect a control algorithm the determines when to issue a control command requesting a vehicle to change its engine displacement. Further details of the control algorithms are described below with respect to FIGS. 4-7.


In various embodiments, the control algorithms 40 can be configured to determine whether to issue one or more control commands that control 1) a single vehicle component, such as the engine, 2) multiple vehicle components, such as the engine and transmission, 3) a single aspect of each of the controlled vehicle components, such as the displacement of the engine, and 4) multiple aspects of each the controlled vehicle components, such as the engine displacement, spark timing and fuel mixture. For instance, a control algorithm can be configured that affects the engine and the transmission. After issuing a control command that affects the engine performance (e.g., a change in the displacement of the engine, the control algorithm may issue a control command that affects the transmission to improve the drivability of the vehicle. The control algorithms and/or data utilized by the control algorithms can be stored in an encrypted format.


The SCU 30 can include one or more status indicators 36, such as but not limited to a light source. In one embodiment, the status indicator 36 can be activated when the SCU 30 is activated and operating properly. In another embodiment, the processor 34 can be configured to control the status indicator 36 to convey an operational characteristic of the SCU 30. For instance, each time a particular control command is issued by the SCU 30, the processor 34 can be configured to cause the status indicator 36 to change, such as to blink on and off when a light is used for the status indicator. Other types of status indicators besides a light source can be utilized. For instance, an audio mechanism or a vibration mechanism can be used to indicate a status of the SCU 30. In another example, a small display can be coupled to the SCU 30. The processor 34 can be configured to output status information associated with the SCU 30 to the display.


The SCU 30 can include a power source, such as battery. The power source can be used to provide power to the SCU components, such as the processor 34. In another embodiment, the SCU 30 can be configured to draw power from a vehicle to which it is coupled. For instance, there is a pin in an OBD-II connector (see FIG. 2B) that provides power from the vehicle battery. Thus, the SCU 30 may not include its own internal power source.


There are other methods for changing the performance of an engine from the performance dictated by the factory ECU. In older cars, a large set of operational tables is included in the factory ECU that allows the ECU to determine how to operate the various engine components under different conditions. In newer cars, the ECU includes logic that simulates the operation of the engine and determines how to operate the various engine components to achieve a particular operational state, such as an output of some torque amount. The engine simulation utilizes calibration tables. The operational tables or calibration tables are typically stored in a memory on the ECU.


One method of changing the engine performance is to alter the operational tables stored in memory. For instance, the operational tables or calibration tables stored in the memory can be replaced with new tables. As the tables are needed for the vehicle to operate, the replacement is done while the vehicle non-operational.


Another method is to replace the entire ECU. The new ECU can include control algorithms using operational tables or calibration tables that are totally different than what is provided on the factory ECU. The new ECU operates the engine according to its logic and data. Since the ECU is required to operate the engine, this modification is necessarily performed while the vehicle is non-operational.


Another method of changing the engine performance is to intercept and alter data before it reaches the ECU. The ECU can base its operations on data received from various sensors. With older vehicles, such as vehicles employing operational tables, devices can be used that intercept the sensor data and replace it with new sensor data while the vehicle is operating. The engine performance is modified from how it would normally operate because the ECU is receiving false data. In newer cars employing an engine simulation, this approach often doesn't work because the ECU can determine, based upon the engine simulation, that the sensor data is not consistent with how the engine is currently operating. Thus, the modified data can cause the ECU to trigger an error condition.


Each of the three methods described above, replacing operational or calibration tables, replacing the factory ECU or falsifying data can void a vehicle's warranty and possibly lead to engine damage. In embodiments described herein, the operational or calibrations tables don't have to be replaced, the factory ECU doesn't have to be replaced and vehicle data doesn't have to be falsified. Thus, the operational bounds of engine under various conditions proscribed by the factory ECU can be preserved. However, within the operational bounds dictated by the factory ECU, the performance of the engine can still be modified.


Next, some possible SCU device configurations are described. These configurations are described for the purposes of illustration and are not meant to be limiting. For example, FIG. 2A shows one configuration of a SCU 30. The SCU 30 includes a housing 68. The processor 34, memory 38, communication interface 35 and control algorithms 40 can be located within the housing. The housing 68 can be formed from a suitable material, such as a metal or plastic. The shape of the housing may be approximately rectangular. However, the shape of the housing is provided for illustrative purposes and different shaped housing can be utilized.


A mounting interface 70 is coupled to the housing 68. In one embodiment, the mounting interface can be a Velcro™ strip coupled to the housing via an adhesive, such as a double-sided tape. A compatible Velcro™ strip can be mounted to a vehicle surface using an adhesive allowing the SCU 30 to be mounted to a vehicle surface. In another embodiment, a bracket can be provided. The bracket can be attached to a vehicle surface. The housing 68 can be shaped so that when coupled to the bracket a suitable connection is formed between the housing and the bracket.


A translucent cover 72 covering a light source is shown mounted to the housing 68. The light source can be used as a status indicator. The translucent cover 72 and associated light source is shown at one end of the housing but in alternate embodiments, the translucent cover and light source can be located at different locations on the housing. The translucent cover 72 and mounting interface 70 can be arranged such that the status indicator associated with the translucent cover 72 is visible to a user when the SCU device 30 is mounted in a vehicle.


A wire cable 66 extends from the housing 68. A connector 62 is coupled to the wire cable 66. A number of pins 64 extend from the connector. The connector 62 is configured for compatibility with a vehicle interface. In one embodiment, the connector 62 can be shaped to for compatibility with an OBD-II interface. An example of OBD-II interface 50 is shown in FIG. 2B. It includes 16 pins and a particular shape 52. The connector shape 62 and pins 64 may fit the shape 52 and align with the pin-acceptors on the OBD-II plug. As described above, other type connectors can be utilized and this example is provided for the purposes of illustration only.



FIG. 3 shows an example of a SCU 30 mounted to the interior of an automobile in accordance with the described embodiments. In one embodiment, the SCU 30 can be mounted to a surface on the vehicle's interior 80. Typically, the OBD-II diagnostic port is located within 2 feet of the steering column Thus, in some embodiments, the SCU 30 can be mounted on a surface near the steering column after it is coupled to the OBD-II diagnostic port. If the OBD-II diagnostic port is located at some other location in the vehicle interior 80, then the SCU 30 can be located near this location.


If another type of interface is used to couple the SCU 30 to the vehicle, such as an interface compatible with a vehicle's CAN-bus. The SCU 30 can be mounted in a different location. In other embodiments, the SCU 30 can be mounted underneath the hood of the vehicle in the engine compartment or can be mounted in a trunk of the vehicle.


The SCU 30 is shown mounted to a panel 90 that extends beneath the steering wheel. The SCU 30 is mounted to a bottom surface of the panel 90 such that the SCU is in a proximately horizontal position and the translucent cover 72 of the status indicator is visible to the user. In other embodiments, the SCU 30 can be mounted to a surface, such as a surface of panel 90, which is more vertically orientated. For example, it can be mounted to portion of the panel above the location shown in FIG. 3. Thus, the mounting location shown in FIG. 3 is provided for the purpose of illustration and is not meant to be limiting.



FIG. 4 is a flow chart of a method 100 for controlling a vehicle subsystem via an SCU. In 102, while the vehicle is moving, the SCU can determine a current state of the vehicle. The current of state of the vehicle can be characterized by different vehicle operational parameters. The vehicle operational parameters can be associated with a vehicle subsystem such as the engine or the transmission. For example, the vehicle operational parameter can be displacement mode in which the engine is currently operating, such as 4 cylinder or 8 cylinders. In another example, the vehicle operational parameter can be related to a current state of the transmission, such as sport driving mode or a normal driving mode or a gear in which the transmission is operating. In yet another example, the current state of the vehicle can be characterized from sensor data associated with various vehicle components, such as but not limited to an 1) RPM of the engine, 2) a temperature of the engine at a particular location, 3) a pressure of the engine at a particular location or 4) a position of the accelerator pedal.


In 104, SCU can receive information from the vehicle that characterizes the current state of the vehicle, such as engine speed, a temperature of various components, the gear in which the transmission is operating, an accelerator pedal position, etc. The SCU can be continuously monitoring these parameters. Thus, the SCU can store a time history of the various parameters in its memory. In 106, based upon the received vehicle information, the SCU can determine whether the vehicle can be placed in a desired state. As an example, the desired state can be related to a particular engine operational mode or a transmission operational mode. One example of a particular engine operational mode is a displacement mode for the engine. Details of determining whether a vehicle can be placed in a desired engine displacement mode are described with respect to FIGS. 6 and 7.


In 108, the SCU can determine whether the desired state is different from the current state of the vehicle. When the SCU determines the vehicle is operating as desired, then the method can return to 102. When the SCU determines the vehicle is not operating as desired, then 110, i.e., the desired state is different from the current state, the SCU can send one or more control commands to a controller in the vehicle, such as the ECU. The one or more control commands can be configured to direct the vehicle to the desired operational state. In a particular embodiment, the one or more control commands can be associated with self-tests and diagnostics that are available on the vehicle. Thus, a diagnostic associated command can be sent from the SCU to the vehicle. As described above, the diagnostic command may be sent via the diagnostic port on the vehicle, such as an OBD-II port.


In 112, the SCU can receive an acknowledgement from the vehicle, such as from the ECU, indicating whether the one or more control commands have been implemented. If the one or more control commands have not been implemented, then the acknowledgement can include information indicating why the one or more control commands were not implemented. For example, in the ECU on the vehicle can reject a received control command related to the engine if it places the engine in an unallowable operational state. Thus, the vehicle can be configured to evaluate its current operational state and determine whether the control command is allowable based upon its current operational state before implementing a control command from the SCU. Thus, the ECU can include data and control algorithms that allow the operational state of the vehicle to be assessed in regards to implementing a particular control command


In one embodiment, both the SCU and ECU can be configured to each issue the same one or more control commands that direct the vehicle towards a desired operational state. For instance, both the SCU and ECU can be configured to issue a control command that causes the engine to operate in a particular mode, such as a particular variable displacement mode. Both the SCU and ECU can include control algorithms that determine whether or not to issue a control command shared in common The control algorithms including the data used to determine whether to issue the shared control command can be different in the SCU and the vehicle controller, such as the ECU. In addition, to prevent damage to the vehicle, the vehicle controller, can be configured to decide whether or not to implement the control command received from the SCU. Thus, the control command from the SCU to the vehicle controller can be referred to as an advisory command since the vehicle controller is not required to implement the control command received from the ECU.



FIG. 5 is a flow chart of a method 200 for controlling a variable displacement engine using a SCU. The variable displacement engine can include two or more displacement modes. For instance, an 8 cylinder engine can be configured to operate using 8, 6 and 4 cylinders. In another example, an 8 cylinder engine can be configured to operate using 8 or 4 cylinders. The method can be configured to when to operate the vehicle in each of its two or more displacement modes. In one embodiment, the method can be designed to favor engine modes that increase the fuel efficiency of the vehicle. An example of vehicles that include an eight cylinder engine that is configured to operate in a 8 cylinder mode or a 4 cylinder mode are 2007 and later model years of the Chevy Tahoe™, Yukon™ and Escalade™ by General Motors (Detroit, Mich.).


In 202, the SCU can be configured to determine the vehicle's current displacement. The SCU can be configured to communicate with a vehicle subsystem that maintains this data, such as the ECU. In one embodiment, a vehicle can include an active fuel management system that determines which cylinders on the engine are enabled at a particular time while the vehicle is moving. The SCU can receive data from the active fuel management system indicating the current number of cylinders enabled on the engine.


In 204, the SCU can monitor and receive data associated with a number of drive train state variables. As described above, in one embodiment, this information can be obtained via communications through the vehicle's diagnostic port. The vehicle's diagnostic port can be an OBD-II compatible port. Examples of data that the SCU can receive include one or more of the vehicle speed, manifold pressure, engine RPM, accelerator pedal position, engine coolant temperature, transmission gear, the calculated engine load or combinations. The SCU can be configured to store one or more these variables as a function of time for some period of time. After some time, a portion of the stored time based data can be deleted or overwritten.


In 206, based upon the drive train related data, the SCU can be configured to determine the desired displacement mode to achieve a particular engine performance. An example of method that is geared to maximizing fuel efficiency of the engine is described below with the respect to FIGS. 6 and 7. However, the displacement mode can be selected for other engine performance parameters and the example of fuel efficiency is provided for the purposes of illustration only.


In 208, it can be determined whether the desired displacement mode is different from the current displacement mode. If the desired displacement mode and the current displacement mode are the same, then the method can return to 202 and the method can be updated with the latest drive train state data. If the desired displacement mode and the current displacement mode are different, then in 210, the SCU can send a request to a vehicle controller, such as the ECU or the vehicle's fuel management system, to change the vehicle's displacement mode.


In one embodiment, the request can be in the form of a self-test or diagnostic command that is available on the vehicle. For example, in the shop, while the vehicle is stationary, a mechanic might use a self-test or a diagnostic command for a particular displacement mode to determine whether the engine can operate in each of the displacement modes. When the appropriate vehicle controller, such as the ECU, receives the test command, in some embodiments, the vehicle controller can be configured to accept or reject the self-test or diagnostic command according to some criteria utilized by the vehicle controller.


If the vehicle controller accepts the control command, an acknowledgement can be sent from controller to the SCU indicating the control command has been accepted. If the vehicle controller rejects the control command, the vehicle controller can send a message indicating the control command has been rejected to the SCU. In some embodiment, the message indicating the control command has been rejected can include information, such as error codes, that specify why the control command is rejected.


The SCU can be configured store and track information related to the error conditions. An error condition can be generated because the vehicle is in the wrong gear or the engine RPM is not within some required range, as determined by the vehicle controller, when the SCU sent the control command to change the displacement mode to the vehicle controller. The SCU can be configured to keep a counter that is updated each time an error condition occurs or a control command is rejected. For example, one or more counters can be updated each time a wrong gear or an engine RPM out of range error condition is detected. Further, it can be configured to store other data associated with the error condition, such as the gear the vehicle was in when the error condition occurred and other data associated with the state of the drive train. In one embodiment, the SCU can be configured to allow the error condition data to be downloaded from the SCU to another device for additional analysis. The error data can be used to refine the control algorithms to reduce the occurrence of the error conditions.


In 212, the SCU can receive and analyze the reply from the ECU. Then, the method can return to 202. In one embodiment, when the control command is rejected, the SCU can be configured add some delay period before it again attempts to issue a control command to change the displacement mode. For instance, after the vehicle controller rejects the displacement mode requested by SCU, in 206, the desired displacement mode can be set to the current displacement mode for some time period without performing the determination, such as the determination described with respect to FIGS. 6 and 7. After the time period elapses, the determination can again be performed.


Next, a method for determining a displacement mode for a vehicle is described. For illustrative purposes, a method is described for determining when to place a vehicle in one of two different modes, such between 4 and 8 cylinders in an engine with eight cylinders. As described above, multiple engine modes and engine types with different cylinder configurations are possible. The method involves data smoothing and calculating time based derivatives of the smoothed data where the data is received from a vehicle controller, such as the ECU. The smoothed data and derivative calculations are used to determine whether to issue a control command to place the vehicle in a particular displacement mode. These techniques are applicable to other control algorithms used to affect engine performance and are not limited to only control algorithms associated with determining a displacement mode of engine for the purposes of improving fuel efficiency.



FIG. 6 is a flow chart of a method 300 for controlling an engine including a data smoothing algorithm. In 302, while the vehicle is moving, the SCU can receive power train data from the vehicle's electronic control system. Some examples of power train variables that the SCU can receive include but are not limited to vehicle speed, manifold pressure, engine RPM, accelerator pedal position, engine coolant temperature, transmission gear and calculated load. The SCU can store an acceptable range for one or of these power train variables.


In 316, the SCU can compare the current value of one or more power train variables to their acceptable range. If one or more of the power train variables is out of range, the method can be configured to return to 302 to receive the values for the power train variables for the next state. If the one or more power train variables that are checked are in range, in 318, it can be determined whether a change mode command is currently pending, i.e., the SCU has sent a request to the ECU to change the displacement mode of the engine but has not received a reply yet. If a mode change is pending, the method can return to 302. If a mode change is not pending, then in 320, it can be determined whether a change mode command has been recently rejected by a vehicle controller, such as the ECU. If there hasn't been a recent rejection, then the method can proceed to 304.


In 320, if it is determined there has been a recent rejection, then in 322, the time elapsed since the last rejection can be checked. If the elapsed time exceeds a threshold value then the method can advance to step 304. If the elapsed time doesn't exceed the threshold value, then the method can return to step 302.


In one embodiment, there are four conditions under which a control command is issued to change the displacement mode, such as from 8 cylinders to 4 cylinders. A first condition is a drop of some magnitude in the accelerator pedal position. A second condition is a drop of some magnitude in the calculated load. The third condition is if the vehicle is an observed cruising state. A fourth condition is that the calculated load is below a certain value. In various embodiments, one or more of these conditions can be used in the algorithm.


To determine the drop in the accelerator position and whether the vehicle was in a cruising state, it was found beneficial to normalize and smooth the data, such as the calculated load and the accelerator pedal position received from the vehicle controller prior to using the data. The data received from the ECU can include a lot of noise which can be somewhat eliminated by smoothing. In 302 and 304, the data received from vehicle controller can be normalized to some reference value and then smoothed as a function of time. A comparison of the raw normalized data and the smoothed data is shown in FIG. 7.


One example of a smoothing algorithm that can be applied is the exponential smoothing algorithm,





S1=X0






S
t
=α X
t−1+(1−α)St−1, t>1 and 0<α<1


Other smoothing algorithms are possible and above equations are provided for the purposes of illustration only. The smoothing is applied to reduce noise in the values received from the vehicle.


A driver can cause changes in the vehicle data by changing the accelerator pedal position or braking. Under similar driving conditions, different drivers can apply the accelerator pedal and brakes differently. In one embodiment, the SCU can be configured to analyze the driving behavior of a particular driver and adjust the algorithm to account for a particular driver's behavior. For example, a cruise state can be determined by examining the position of the accelerator pedal over time. If the position accelerator pedal is not changing much over time, it can be assumed that the vehicle is in a cruise state. Different drivers can generate greater or smaller ranges of pedal position to maintain the cruise state. For a driver that tends to generate a greater range of pedal positions, the threshold value for determining whether the vehicle is in a cruise state can be increased to account for the driver's behavior.


In one embodiment, the SCU can include an interface that allows a user to select different settings. The different settings can include different threshold ranges for determining when to attempt to issue a control command, such as a command to switch to a particular displacement mode. For instance, the SCU could include two switch positions aggressive and normal. In the aggressive mode, the SCU would more frequently attempt to switch to a particular displacement mode than in the normal node. The more frequent attempts in the aggressive mode can result for adjusting the thresholds at which a control command is issued or by including more conditions for when to trigger the control command. For instance, in the normal mode, 3 of the 4 conditions for triggering a change in the displacement mode might be utilized while in the aggressive modes all the conditions might be utilized.


This feature may be useful if the user knows what type of driving conditions will be occurring on a trip. For instance, if the user is taking a long trip that includes a large percentage of cruising, then the user may wish to change the tolerances for detecting a cruise condition in such a way that the amount of time the engine runs in a displacement mode less than using all of the cylinder is maximized If the user is going to be driving in traffic or locally with a lot of speed changes, then the user may not wish to use this setting.


Next, in 308, time-based derivatives of the smoothed data are determined. In one embodiment, only first derivatives are calculated. In other embodiments, higher order derivates, such as the second derivative can be calculated and utilized. In 310, the time based derivatives at multiple times are examined. The first derivative with respect to time of the normalized and smoothed data can be used to determine if a local maximum. In one embodiment, a recent local maximum is determined to occur when the last three values of the first derivative are greater than or equal to zero. Each time this condition is met, the SCU can be configured to update the past value of the local maximum with the current value.


For the purposes of determining whether cruising is occurring, a present value of the accelerator pedal position is compared to the most recent local maximum. If the present value of the accelerator pedal position is within some defined percentage of the most recent local maximum, then the vehicle can be determined to be cruising. In response to this determination, the SCU can request that the vehicle operate at a particular displacement mode, such as less than the maximum amount of cylinders to improve fuel efficiency. Thus, when it is determined the vehicle is in a cruise mode, the SCU can send a control command to the ECU to operate with a particular amount of cylinders.


In 311, the signs of one or more of the first derivatives can be checked at one or more different times can be checked. In one embodiment, when the first derivatives at three or more times is greater than zero, then in 312, the local maximum can be set to the current value of the smoothed and/or formatted data. Thus, in 313, the change amount form the local maximum will be zero. In 311, when the three or derivatives are each not greater than or equal to zero, then the local maximum is not changed and a change amount from the local maximum can be determined in 313.


In 313 and 314, the SCU can be configured to determine if there has been a drop in the engine load or the accelerator pedal position of a sufficient amount to trigger a control command to change the displacement of the engine, such as to less than the maximum available cylinders. The SCU can store threshold values that result in a control command being triggered. When the threshold is exceeded. The SCU can send a control command to a vehicle controller to change the displacement of the engine.


With respect to FIGS. 5 and 6, a method was described that can be implemented on a SCU. This method is not limited to implementation on the SCU. In one embodiment, the method can be implemented directly on the vehicle's ECU. In this instance, it wouldn't be necessary to employ the SCU to implement the method.


Next, with respect to FIG. 7, the implementation of the smoothing algorithm and determination of local extremum, such as a local maximum is described. FIG. 7 is a plot of smoothed and normalized power train data. The data 400 has been smoothed and normalized by a reference value such that it ranges from 0 to 1. The data 400 is plotted as a function of time. Raw normalized is shown as a series of points 410. The smoothed data is represented as a curve 412. However, a curve fit of the data is not required and the smoothed data can consist of a series of points stored in memory.


As the local maximum 406 is approached from the left, the three most recent first derivatives 404 at any time are likely to be greater or equal to zero. Thus, the value of local maximum stored by the SCU will increase as the last value of the local maximum is replaced with the current value of the local maximum each time three positive or zero first derivatives are detected. When the data begins to decrease near the local maximum, at some point, the three most recent local derivatives will no longer be positive and the last value of the local maximum will be retained while the data decreases in value. A different criterion, such as the four or two most recent derivatives greater than zero, can be used to determine a local maximum and use of three is presented for the purposes of illustration only.


At each time, a change from local maximum can be calculated. The change will increase until the data begins to increase again and three local derivatives again become positive at this time the local maximum is reset and the change from the local maximum at the next time step will be small. For the curve shown in FIG. 7, the largest change from the local maximum is represented approximately by change 408. The value of change 408 can be compared to a threshold value to determine if a sufficient drop in the pedal position or the calculated load has occurred (separate curves can be generated for each variable). If the threshold value is exceeded than a control command to change the displacement mode can be sent from the SCU to the vehicle.


The various aspects, embodiments, implementations or features of the described embodiments can be used separately or in any combination. Various aspects of the described embodiments can be implemented by software, hardware or a combination of hardware and software. The computer readable medium is any data storage device that can store data which can thereafter be read by a computer system. Examples of the computer readable medium include read-only memory, random-access memory, CD-ROMs, DVDs, magnetic tape and optical data storage devices. The computer readable medium can also be distributed over network-coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.


The foregoing description, for purposes of explanation, used specific nomenclature to provide a thorough understanding of the invention. However, it will be apparent to one skilled in the art that the specific details are not required in order to practice the invention. Thus, the foregoing descriptions of specific embodiments of the present invention are presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention to the precise forms disclosed. It will be apparent to one of ordinary skill in the art that many modifications and variations are possible in view of the above teachings.


The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, to thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated. It is intended that the scope of the invention be defined by the following claims and their equivalents.


While the embodiments have been described in terms of several particular embodiments, there are alterations, permutations, and equivalents, which fall within the scope of these general concepts. It should also be noted that there are many alternative ways of implementing the methods and apparatuses of the present embodiments. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations, and equivalents as fall within the true spirit and scope of the described embodiments.

Claims
  • 1. An electronic device comprising: a housing;a processor and a memory disposed within the housing;an interface that allows the processor and the memory to communicate with a vehicle having an engine control unit;wherein the processor is configured to 1) receive from the engine control unit, power train state data characterizing a current operational state of the vehicle, 2) based upon the power train state data, determine whether to send a control command recognized by the vehicle wherein the control command effects operation of the vehicle while it is being driven; and 3) when the control command is sent, receive a message from the vehicle indicating whether the control command has been implemented or rejected by the vehicle.
  • 2. The electronic device of claim 1, further comprising: a connector that allows the electronic device to be coupled to a diagnostic port associated with the vehicle.
  • 3. The electronic device of claim 2, wherein the diagnostic port is OBD-II compliant.
  • 4. The electronic device of claim 2, wherein the diagnostic port is JOBD or EOBD compliant.
  • 5. The electronic device of claim 2, wherein the connector is configured to receive power from the diagnostic port.
  • 6. The electronic device of claim 1, further comprising: a power source disposed within the housing for delivering power to operate the processor.
  • 7. The electronic device of claim 1, further comprising: a CAN-controller and a CAN transceiver for sending and receiving messages on a CAN compliant vehicle communication bus.
  • 8. The electronic device of claim 7, wherein the processor is further configured to communicate using a CAN communication protocol.
  • 9. The electronic device of claim 1, wherein the power train data is one or more of a vehicle speed, a manifold pressure, an engine RPM, an accelerator pedal position, an engine a coolant temperature, a transmission gear or a calculated load.
  • 10. The electronic device of claim 1, further comprising: a status indicator for indicating an operational state of the electronic device.
  • 11. The electronic device of claim 10, wherein the status indicator is one of a light, an audio device, a vibration device or a display.
  • 12. The electronic device of claim 1, further comprising: a mounting interface for mounting the electronic device to a surface of the vehicle.
  • 13. The electronic device of claim 1, wherein the vehicle includes a variable displacement engine and wherein the control command is for changing a displacement mode of the variable displacement engine.
  • 14. The electronic device of claim 13, wherein processor is further configured to repeatedly issue the control command to change the displacement mode of the engine while the vehicle is being driven based upon a current operational state to improve the fuel efficiency of the vehicle.
  • 15. The electronic device of claim 13, wherein the control command is sent to a vehicle controller wherein the vehicle controller is configured to issue a command to change the displacement mode of the engine based upon a determination that is independent of determination made by the electronic device.
  • 16. The electronic device of claim 13, wherein the processor is further configured to 1) determine one or more of whether the vehicle is in a cruise state, 2) an accelerator pedal position has changed over a first time period more than a first threshold amount, 3) a calculated engine load has changed more than over a second time period more than a second threshold amount, 4) the calculated engine load is below a third threshold amount or 5) combinations thereof and in response the determination, determine whether to issue the command for changing the displacement mode of engine.
  • 17. The electronic device of claim 1 wherein the control command is self-test or diagnostic command.
  • 18. A method in a controller for controlling an automobile including an a variable displacement engine comprising: receiving from power train state data including a calculated engine load data and an accelerator pedal position data;applying a data smoothing algorithm to at least the calculated engine load and the accelerator pedal position and storing the smoothed data;based upon the smoothed calculated engine load data and the smoothed accelerator pedal position data, determining one or more of 1) whether the vehicle is in a cruise state, 2) an accelerator pedal position has decreased more than a first threshold amount over a first time period, 3) a calculated engine load has decreased more than a second threshold amount over a second time period, 4) the calculated engine load is below a third threshold value or combinations thereof.based upon the determination, determining a determining a desired displacement mode of the variable displacement mode engine; andwhen the desired displacement mode is different from a current displacement mode, sending one or more control commands configured to cause the variable displacement mode engine to operate in the desired displacement mode.
  • 19. The method of claim 18, further comprising: normalizing the calculated engine load data and the accelerator pedal position data.
  • 20. The method of claim 18, wherein the variable displacement engine includes two or more displacement modes.
  • 21. The method of claim 18, wherein the one or more control commands are self-test or diagnostic commands.
  • 22. The method of claim 18, wherein the controller is an engine control unit.
  • 23. The method of claim 18, further comprising: determining a plurality of first derivatives with respect to time using the smoothed accelerator pedal position data, based upon the plurality of first derivatives determining a local maximum for the accelerator pedal position wherein the change in the accelerator pedal position over the first time period is determined based upon an amount of change from the local maximum.
  • 24. The method of claim 18, further comprising: determining a plurality of first derivatives with respect to time using the smoothed calculated load data, based upon the plurality of first derivatives determining a local maximum for the calculated load wherein the change in the calculated load over the second time period is determined based upon an amount of change from the local maximum.
  • 25. The method of claim 18 wherein the data smoothing algorithm is an exponential smoothing algorithm.
  • 26. A computer readable medium including computer code for controlling an automobile including an a variable displacement engine comprising: computer code for receiving from power train state data including a calculated engine load data and an accelerator pedal position data;computer code for applying a data smoothing algorithm to at least the calculated engine load and the accelerator pedal position and storing the smoothed data;computer code for, based upon the smoothed calculated engine load data and the smoothed accelerator pedal position data, determining one or more of 1) whether the vehicle is in a cruise state, 2) an accelerator pedal position has decreased more than a first threshold amount over a first time period, 3) a calculated engine load has decreased more than a second threshold amount over a second time period, 4) the calculated engine load is below a third threshold value or combinations thereof.computer code for, based upon the determination, determining a determining a desired displacement mode of the variable displacement mode engine; andcomputer code for, when the desired displacement mode is different from a current displacement mode, sending one or more control commands to cause the variable displacement mode engine to operate in the desired displacement mode.