The present disclosure relates generally to operation of a locomotive and, more particularly, to systems and methods for distributed control of a locomotive.
Traditional locomotives and locomotives within a consist arrangement are known to use a centralized on-board computer-based control system. Typically, such conventional control systems for a locomotive may include a central processing unit on the locomotive, a user interface for the locomotive operator, and interfaces or backplanes connected to the central processing unit on the locomotive for communications with sensor input and actuator output. As such, conventional control systems provide a consolidated interface for the locomotive operator. For example, U.S. Pat. No. 7,131,614 (the '614 patent) describes a conventional locomotive control system with such elements. The '614 patent describes locomotive control hardware including a central computer processor.
However, the complexity of new systems desired to be on-board a locomotive as part of a control system may introduce problems to systems such as that described in the '614 patent. In other words, some of the problems currently encountered with conventional control systems include the complexity of disparate components within the control system that need to effectively communicate with each other. Additionally, some conventional control systems may suffer from a lack of robust, mission critical, extensible and scalable components, which results in an undesirably higher cost, a less standardized and flexible architecture, and undesirably complex and complicated control systems.
The presently disclosed distributed control system is directed to overcoming one or more of the problems set forth above and/or other problems in the art.
In accordance with one aspect, the present disclosure is directed to a distributed control system for a locomotive. The system may include a network and a plurality of electronic modules distributed within a locomotive. The plurality of electronic modules are communicatively coupled to the network in a standardized scalable architecture and implement distributed control of the locomotive. A first electronic module of the plurality of electronic modules may include a first configurable controller and a memory that stores a configuration file received via the network. The first configurable controller may be reconfigurable based on the configuration file stored in the memory.
According to another aspect, the present disclosure is directed to a method for controlling a locomotive. The method may include receiving a configuration file via a network. The plurality of electronic modules may be distributed within the locomotive and communicatively coupled to the network in a standardized scalable architecture. The electronic module may include a first configurable controller that is reconfigurable to implement distributed control of the locomotive. The method may also include storing the configuration file in a memory in the electronic module. The method may further include configuring the first configurable controller by using the configuration file.
In accordance with yet another aspect, the present disclosure is directed to a consist. The consist may include a plurality of locomotives. Each locomotive may include a network and a plurality of electronic modules distributed within a locomotive. The plurality of electronic modules are communicatively coupled to the network in a standardized scalable architecture and implement distributed control of the locomotive. A first electronic module of the plurality of electronic modules may include a first configurable controller and a memory that stores a configuration file received via the network. The first configurable controller may be reconfigurable based on the configuration file stored in the memory.
While not shown in
As part of implementing control functions used to control the locomotive, the embodiment illustrated in
Electronic modules 202-210 may be spatially disposed within locomotive 120. As shown in
Electronic modules 202-210 may be programmed and configured to communicatively connect to one or more control elements disposed within the locomotive. As shown in
Another example of a control element is a communication/navigation device 230, which is generally a device that provides communication within or outside the locomotive or receives/transmits navigational information within or outside the locomotive. An example of communication/navigation device 230 may include, but is not limited to, an analog radio, a digital communication receiver/transmitter, a GPS unit, and a tracking transponder.
Sensors 240 and 242 and actuators 250 and 252 are additional examples of control elements operatively connected to one or more electronic modules 206, 208, and 210. Generally, a sensor may be any type of device that records or senses a condition or characteristic relative to the locomotive, such as speed, temperature, atmospheric conditions, shock, vibration, frequency, engine conditions, etc. Various voltages (e.g., DC link voltage) and amperages (e.g., blower motor or traction motor amperage) may be used to represent the sensed conditions or characteristics. Similarly, an actuator may generally be any type of device that changes a condition or characteristic relative to the locomotive, such as a throttle, brake, heater, fuel flow regulator, generator, damper, pump, switch, relay, solenoid, etc. In one embodiment, an actuator may involve control of a mechanical or electrical device.
In an embodiment, a single electronic module may be connected to one or more control elements. For example, in
While
Power supply circuitry 325 generally provides appropriate power signals to different circuit elements within electronic module 202. Various other known circuits may be associated with electronic module 202, including gate driver circuitry, buffering circuitry, and other appropriate circuitry.
Network interface 300 may be configured to couple electronic module 202 to network 200. Network interface 300 may be coupled to both of programmable controller 305 and configurable controller 310. In one example, network interface 300 may be an Ethernet switch. However, other types of network or communication interfaces may suffice to operatively couple electronic module 202 to network 200. Additionally, in embodiments where network 200 includes different communication paths or subnetworks, network interface 300 may be implemented with one or more interface circuits to accommodate the different format or different physical paths of network 200. For example, the interface circuits of network interface 300 may accommodate transmission of Ethernet TCP/IP based data, RS 232 data, RS422 data, CAN bus data via network 200. Although not shown in
Configurable controller 310 contains internal circuitry that is configurable to implement distributed control of locomotive 120. In other words, the internal circuitry of configurable controller 310 may be altered (e.g., internally reconnectable) in different configurations to implement one or more control functions associated with the distributed control of locomotive 120. In one embodiment, configurable controller 310 may be implemented by a field programmable gate array (FPGA) including programmable logic gates that may be reconfigured in how each of the programmable logic gates are interconnected when providing analog or digital control of one or more control elements. Configurable controller 310 may be configured to include a soft core processor such as a Nios processor in Altera® FPGAs. In some embodiments, a control application that is running on configurable controller 310 may require more sophistication and complexity. In this case, control application may be implemented by both configurable controller 310 and programmable controller 305, which has a higher processing capacity than configurable controller 310. Configurable controller 310 may be connected to memory 330b. Memory 330b may be configured to store configuration files used by configurable controller 310 to reconfigure the internal circuitry to perform certain functions related to the disclosed embodiments. In some embodiments, memory 330b may also store executable programs to be executed by the soft core processor in configurable controller 310. Memory 330b may include a volatile or non-volatile, magnetic, semiconductor, tape, optical, removable, nonremovable, or other type of storage device or computer-readable medium. In some embodiments, configurable controller 310 may be configured to include a memory to store, for example, the configuration files used by configurable controller 310.
Programmable controller 305 may be in communication with configurable controller 310 and network 200. Programmable controller 305 is programmatically adapted to provide computational support for a control function associated with electronic module 202. Exemplary communication between configurable controller 310 and programmable controller 305 may be accomplished with a peripheral component interconnect express (PCIe) bus or other high speed data bus that facilitates quick and efficient communication between the devices when implementing the control function. Alternatively, the communication between configurable controller 310 and programmable controller 305 may be accomplished through network 200. The control function, such as throttle control of the engine, may be at least one of a plurality of control functions associated with the distributed control of the locomotive. Computational support generally involves an offloaded task that may be accomplished with a processing unit, such as programmable controller 305, not in direct connection with the control element, such as a throttle actuator or speed sensor.
Programmable controller 305 may be removably connected to main board 202a. The software of programmable controller 305 may be programmed to provide computational support to electronic module 202, thus allowing for a more complex implementation of application than configurable controller 310. Programmable controller 305 may have a higher processing capacity than configurable controller 310 in terms of execution rate of instructions. Programmable controller 305 may be a microcontroller, a microprocessor, a Computer-On-Module (COM), or a System-On-Module (SOM). A SOM may have a processing capacity of 3 billion instructions per second. In one example, programmable controller 305 may be programmatically tasked with monitoring network 200 for messages. Programmable controller 305 may communicate with memory 330a formed on main board 202a of electronic module 202. Memory 330a may be used to store programs to be executed by programmable controller 305. Similar to memory 330b, memory 330a may include a volatile or non-volatile, magnetic, semiconductor, tape, optical, removable, nonremovable, or other type of storage device or computer-readable medium. Alternatively, programmable controller 305 may communicate with other local peripheral devices not formed on main board 202a (e.g., control elements 230, 240, 242, 250 and 252) via a local data interface 315. Local data interface 315 may be implemented, for example, using a USB or SATA format.
In some embodiments, configurable controller 310 of electronic module 202 may communicate with daughter boards 202b and 202c via the one or more communication ports 320a and 320b. Then, via input and output (I/O) ports formed on daughter boards 202b and 202c, configurable controller 310 of electronic module 202 may communicate with one or more control elements or the daughter boards of other electronic modules 204-210 within the distributed control system. Each one of daughter boards 202b and 202c may be electrically connected to configurable controller 310 in main board 202a via communication port 320a or 320b and a cable. The cable may contain several physical signaling lines. In one example, the cable may be formed as a flexible flat cable with fifty physical signaling lines, including power and ground lines.
Daughter board 202b may include a communication port 340, an interface controller 350, and I/O ports 360a, 360b, and 360c. Communication port 340 may be connected to communication port 320a in main board 202a via the cable. Interface controller 350 may be implemented by a complex programmable logic device (CPLD) or a FPGA, which may be configured to control data transmission (e.g., serial data transmission) via I/O ports 360a, 360b, and 360c. Alternatively, interface controller 350 may be implemented by a microcontroller that may be programmable to control data transmission via I/O ports 360a, 360b, and 360c. Interface controller 350 may also control one or more control elements connected to daughter board 202b. In some embodiments, one or more of I/O ports 360a, 360b, and 360c may be a RS232 data port, a RS422 data port, a LonTalk data port, or a GPS receiver. I/O ports 360a, 360b, and 360c enable communication between electronic module 202 and some control elements that require special data format, such as RS232 data, RS422 data, and/or LonTalk data. For example, a remote speed indicator which monitors and displays the speed of locomotive 120 may be communicated only via the RS 422 data port.
Daughter board 202c may include a communication port 370 and I/O ports 380a, 380b, and 380c. Communication port 370 may be connected to communication port 320b in main board 202a via another cable. In some embodiments, one or more of I/O ports 380a, 380b, and 380c may be a CAN port that enables communication between electronic module 202 and other control elements that require CAN bus data. For example, an Electro Motive Diesel Engine Controller (EMDEC) which controls the locomotive engine may be communicated only via the CAN port. Since CAN data transmission has a relatively stringent timing requirement, there is no need for an interface controller to control data transmission. In this case, configurable controller 310 in main board 202a may be configured to include a CAN controller for controlling data transmission between main board 202a and daughter board 202c having CAN ports.
Programmable controller 305 and configurable controller 310 may overlap in terms of their functions. That is, each one of programmable controller 305 and configurable controller 310 may independently interface with network 200 via network interface 300 to receive, process, initiate, and transmit messages. In addition, each one of programmable controller 305 and configurable controller 310 may have a processing capacity to host one or more control applications. However, programmable controller 305 may have a substantially large processing capacity, while configurable controller 310 may have relatively limited processing capacity.
In some embodiments, a control application of electronic module 202 may determine its need for processing capacity. The application may determine whether it can be implemented by only configurable controller 310, or whether it requires additional processing capacity from programmable controller 305. Applications that require relatively low processing capacity may be implemented by a certain electronic module that does not have a programmable controller, which will be discussed in greater detail below.
In one embodiment, the distributed control system for a locomotive may use electronic modules that use both a programmable controller 305 and a configurable controller 310 (e.g., electronic module 202 illustrated in
Additionally, the method may receive a monitored locomotive signal from the one or more control elements. In one embodiment, a monitored locomotive signal is provided by a sensor, such as sensor 240, to configurable controller 310 via daughter board 202b or 202c, as part of monitoring the speed of the locomotive or as part of monitoring the temperature of locomotive engine 140. In response, the method may process the monitored locomotive signal within the first of the electronic modules and alter the generated control signal applied to the one or more control elements disposed within the locomotive. In the example mentioned above, the monitored locomotive signal may be processed by the configurable controller 310 or, if desired and equipped, by the programmable controller 305 within the electronic module.
In another embodiment, the method may reconfigure the configurable controller to cause the configurable controller to implement an alternative one of the control functions. In some exemplary embodiments, reconfiguring the configurable controller may alter interconnections of a plurality of programmable logic gates to implement the alternative one of the control functions. For example, an FPGA device may be used to implement the configurable controller and may be remotely reconfigured to implement an alternative control function. In this manner, those skilled in the art will appreciate the advantageous dynamic tasking of electronic modules and the ability to re-use electronic modules in differing configurations.
In comparison to electronic module 202 illustrated in
Configurable controller may be configured by various controllers in electronic module 208. In some embodiments, the configuration of configurable controller 510a may be implemented by configurable controller 510a itself For example, configurable controller 510a may first receive a configuration file transmitted via network 200, and store the configuration file in memory 530b. When configuration controller 510a receives a reconfiguration instruction from, for example, network 200, it will trigger its own reconfiguration based on the configuration file in memory 530b. In other embodiments, configurable controller 510a may be configured by configurable controller 510b based on the configuration file stored in memory 530b. In such case, configurable controller 510b may be configured to receive a configuration file and store the configuration file in memory 530b. Still alternatively, configurable controller 510a may be configured by programmable controller 505.
In some embodiments, the configuration file may be transmitted from another electronic module in the distributed control system in locomotive 120. Alternatively, the configuration file may be transmitted from a server (not shown) located outside of locomotive 120.
The method may also include storing the configuration file in a memory (Step 820). For example, the configuration file may be stored in memory 530b. The method may further include configuring a configuration controller by using the configuration file (Step 830). For example, configurable controller 510a may be configured by using the configuration file stored in memory 530. In certain embodiments, Step 830 may be performed responsive to a determination that a reconfiguration event has occurred. A reconfiguration event may be any event that triggers reconfiguration of reconfigurable controller 510a. For example, a reconfiguration event may occur when it is determined that electronic module 208 is not functioning properly. Alternatively, a reconfiguration event may occur upon receiving a reconfiguration file that includes critical software update or patch. The above-recited steps 810, 820, and 830 may be implemented by either one of configurable controller 510a, configurable controller 510b, and programmable controller 505.
The disclosed distributed control system and methods provide a robust and improved solution for controlling a locomotive with a standardized and scalable architecture of distributed electronic modules. The disclosed systems and methods are able to handle robust, mission critical, and demanding control functions associated with control of the locomotive using distributed standardized electronic modules.
In particular, the presently disclosed distributed control system may have several advantages. Specifically, the presently disclosed distributed control system avoids undesirably high costs by providing spatially distributed electronic control modules using standardized components. The standardized components, such as an electronic peripheral control interface and, in some instances, a programmable controller, allow for a flexible, extensible, and scalable architecture while helping to avoid high maintenance costs and system downtime.
Additionally, the disclosed systems are able to use components, such as a configurable controller, which contain internal circuitry that is reconfigurable. This is especially beneficial when there is the need for quick and flexible replacement of components in the system, dynamic tasking of electronic modules within the system to handle differing control needs within the locomotive, and the ability to re-use electronic modules in differing configurations. Moreover, the configurable controller included in the disclosed systems can be reconfigurable using configuration files received from a source separate from locomotive 120, e.g., when locomotive 120 is in the field. This enables the electronic modules of locomotive 120 to be reconfigured, updated, and/or repaired without ceasing operation of locomotive 120, or otherwise creating the need for locomotive 120 to be serviced. Thus, locomotive 120 may function more efficiently.
It will be apparent to those skilled in the art that various modifications and variations can be made to the disclosed distributed control system for a locomotive and associated methods for operating the same. Other embodiments will be apparent to those skilled in the art from consideration of the specification and practice of disclosed distributed control system for a locomotive. It is intended that the specification and examples be considered as exemplary only, with a true scope being indicated by the following claims and their equivalents.