Each of the ground-based ATC 10 and the ground-based aircrafts operations center 12 can include one or more computing circuits, such as microprocessors or microcontrollers, that can be configured with firmware or other configuration data, programmed with software, or hardwired to perform certain functions and tasks related to the flying, monitoring, and maintenance of the aircraft 14.
The aircraft 14 includes one or more electronic subsystems 16, such as a flight management computer (FMC, hereinafter called a flight management system (FMS)), central maintenance computer (CMC), and an aircraft condition monitor (ACM), a communication management unit (CMU) 18, and one or more data busses 20, for example, an Aeronautical Radio INC. (ARINC) 429 bus, over which the CMU and the other one or more subsystems are configured to communicate with one another (other examples of the one or more busses 20 include an avionics full-duplex switched Ethernet (AFDX), a back-plane bus, and Ethernet). Each of the electronic subsystems 16 and the CMU 18 can include one or more respective computing circuits, such as a microprocessor or microcontroller, and respective other circuits, such as peripheral circuits and sensors. The computing circuits and other circuits can be configured with firmware or other configuration data, programmed with software, or hardwired to perform certain functions and tasks related to the flying, monitoring, flight-application processing, and maintenance of the aircraft 14. For example, each of one or more of the computing circuits can execute one or more software applications to implement the functions of the corresponding subsystem.
Although not shown in
The CMU 18 includes an Aircraft Communications Addressing and Reporting System (ACARS) router 22 for sending and receiving datalink messages between the aircraft and the ground.
During operation, each of the electronic subsystems 16 broadcasts certain information (hereinafter “data”) to the CMU 18 via the ARINC 429 bus (one of the one or more busses 20), and, as described above, the CMU is configured to route at least some of this data to the ATC 10 or to the aircraft operations center 12 via the ACARS router 22. Examples of a subsystem 16 so broadcasting such data to the CMU 18 via the ARINC 429 bus 20 include an FMS broadcasting the current altitude and the current airspeed of the aircraft 14 periodically (e.g, every one second), and broadcasting, upon the aircraft arriving at a waypoint along the aircraft's flight path, the current time, the elapsed time and the distance the aircraft traveled since the aircraft was at the immediately previous waypoint, and the current airspeed of the aircraft.
Furthermore, the ground-based aircraft operation center 12 is configured to request and to receive, from each of at least one of the electronic subsystems 16, other data that the electronic subsystem does not periodically broadcast over the ARINC 429 bus 20. Examples of such non-broadcast data include but not limited, the current flight plan stored in the FMS for the aircraft 14.
In more detail, to request non-broadcast data from a target one of the electronic subsystems 16, the ground-based aircraft operations center 12 generates a data-request message that identifies the target electronic subsystem and that has an ACARS-compatible format, and sends the data-request message to the ACARS router 22. For example, the data-request message includes an identifier (e.g., an address) of the target electronic subsystem 16, and includes an address, or other description, of the requested data.
In response to the data-request message from the ground-based aircraft operations center 12, the CMU 32 generates, and sends to the service provider for the ground-based aircraft operations center, an acknowledgement of having received the data-request message. The service provider may, or may not, pass the acknowledgement to the ground-based aircraft operations center 12.
The ACARS router 22 routes the data-request message from the ground-based aircraft operations center 12 to the identified target electronic subsystem 16 via the ARINC 429 bus 20. Alternatively, the ACARS router 22 drives the data-request message onto the ARINC 429 bus 20, and the target electronic subsystem 16 intercepts the data-request message in response to an identifier (e.g., an address of the target electronic system) contained within the data-request message.
The target electronic subsystem 16 responds to the received data-request message by processing, generating, or retrieving the requested data, by generating an ACARS-compatible data-response message that includes a payload with the requested data and that includes the requested destination, and by sending the data-response message to the ACARS router 22 via the ARINC 429 bus 20.
The ACARS router 22 routes the data-response message to the ground-based aircraft operations center 12 via the ground service provider (not shown), and the ground-based aircraft operation center extracts the data from the data-response message and consumes the data in any suitable manner.
Assume, for purpose of example, that an FMS of the subsystems 16 is configured to publish, on the ARINC 429 bus 20, the altitude of the aircraft 10 at two-second intervals, but is not configured to publish, on the ARINC 429 bus, flight-plan data that represents the flight plan that is stored in, implemented (while the aircraft 30 is on autopilot) by, and updated by, the FMS.
Therefore, if the flight plan is changed in midflight (e.g., the pilot requests permission to fly above or around turbulence, and ATC 10 grants the request), then the CMU AOC 18 cannot be configured, and, therefore, is unable, to inform, automatically, the ground-based aircraft operations center 12 of the change in the flight plan in a timely manner because the FMS 16 does not publish all of the flight-plan data on the ARINC 429 bus 20, and, therefore, because the CMU does not have full access to the flight-plan data.
Because the ground-based aircraft operations center 12 does not “know” of the change in the flight plan, the ground-based aircraft operations center cannot, and does not, update the flight-plan information. For example, if the change in the flight plan is likely to result in the aircraft 14 arriving early at the destination airport, consequences of the ground-based aircraft operations center 12 not updating the flight-arrival information include the destination airport not having a gate prepared to receive the aircraft when the aircraft lands, and pre-scheduled transportation for a passenger of the aircraft not arriving at the airport in time to pick up the passenger upon his/her arrival at the destination airport. And if the change in the flight plan is likely to result in the aircraft arriving late at the destination airport, consequences of the ground-based aircraft operations center 12 not updating the flight-arrival information include tying up an airport gate for longer than necessary.
A potential solution to the problem of the CMU 18 being unable to provide the ground-based aircraft operations center 12 with particular information from an electronic subsystem 16 onboard the aircraft 14 is to modify the subsystem to broadcast the particular information on the ARINC 429 bus 20 at periodic intervals, or upon the occurrence of an event (e.g., the aircraft 14 reaching a particular altitude, reaching a particular distance from the airport of arrival, or reaching a particular waypoint along the aircraft's flight path).
But unfortunately, this potential solution may be relatively expensive and time consuming, and may nullify any competitive advantage that it might otherwise render to an airline. A modification to an electronic subsystem 16, such as an FMS, often requires the agreement of the aircraft manufacturer and of government bodies overseeing air travel (e.g., the Federal Aviation Administration (FAA) in the United States), and obtaining such agreement can be lengthy and expensive. Furthermore, a so-modified electronic subsystem 16 is subject to a lengthy, expensive, and rigorous re-certification process before it can be placed into service onboard aircraft. Moreover, even assuming that such a modification developed, and provided to an airline, by an avionics manufacturer, is approved and implemented, the modified electronic subsystem 16 might provide no competitive advantage to the airline because other airlines would be able to obtain the modified subsystem from the developing avionics manufacturer or from another subsystem manufacturer.
Another potential solution to the problem of the CMU 18 being unable to provide the ground-based aircraft operations center 12 with particular information from an electronic subsystem 16 onboard the aircraft 14 is to configure a computer circuit of the ground-based aircraft operations center to request (e.g., periodically or upon occurrence of an event) the unpublished data (e.g., the flight-plan data) from the electronic subsystem 16 (e.g., the FMS) by sending a data-request message to the target electronic subsystem via the ACARS router 22.
But unfortunately, this potential solution may be relatively expensive because it may consume a significant amount of the bandwidth of the air-to/from-ground communication links and may consume a significant amount of the processing throughput of the ground-based aircraft-operations-center's computer(s). Typically, an airline pays a fee for each ACARS message (or for each ACARS message over a threshold number per billing period) that the ground-based aircraft operations center 12 sends to, or receives from, the aircraft 14. Therefore, configuring the ground-based aircraft operations center 12 to request, periodically, unpublished data from a target electronic subsystem 16 onboard the aircraft 14 can cause the airline to incur significant messaging fees, plus the air/ground subnetwork may not support all the extra data communications traffic. Furthermore, configuring the ground-based aircraft operations center 12 to request, periodically, unpublished data from one or more target electronic subsystems 16 onboard one or more aircraft 14 can increase, significantly, the messaging load, and thus the overall processing load, of the computer circuit(s) of the ground-based aircraft operations center.
Furthermore, a similar lack-of-data problem may plague systems and subsystems other than the aircraft operations center 12.
For example, a pilot of the aircraft 30 may wish to inform the aircraft operations center 12 when the aircraft reaches the altitude peak of its ascent (or the pilot may wish to inform ATC 10 when the aircraft reaches the altitude peak of its ascent if the ATC does not otherwise have access to this information). But if the data needed to determine when the aircraft 14 reaches the peak of its ascent is not published on the one or more busses 20 (including, e.g., an ARINC 429 bus), and, therefore, is unavailable to the CMU 18, then the pilot cannot so inform the aircraft operations center 12 (or ATC 10). And unlike the aircraft operations center 12, which may be able to request data not published on the one or more busses 20, there is no way for the pilot or CMU 18 to request, from the other electronic subsystems 16, data that the electronic subsystems do not publish on the one or more busses 20.
Other examples of situations in which lack of published data may prevent the occurrence of a desired operation include the lack of published data preventing the CMU 18, or other onboard system or subsystem, from predicting, in real time, the fuel burn and the fuel reserve for the aircraft 14 at various points along the flight path, and from notifying the pilot of the occurrence of an event such as when the aircraft 14 reaches a certain distance (e.g., twenty miles) from the airport of arrival.
Therefore, a need has arisen for a technique for obtaining unpublished data from an electronic subsystem 16 onboard a vehicle, such as the aircraft 14, without the time, cost, loss of competitive advantage, and other complexities associated with modifying the electronic subsystem, and without significantly increasing the processing load of the computer circuit(s) of a communications center such as the ground-based aircraft operations center 12 and without significant air/ground bandwidth utilizing.
An embodiment of a communication management unit (CMU) that can meet this need includes an emulator circuit and a data-mining circuit. The emulator circuit is configured to generate a data request having a same format as a data request from a vehicle operations center or other communications center, to send the data request to a subsystem disposed on a vehicle, and to receive data sent by the subsystem in response to the data request. And the data-mining circuit is configured to provide at least some of the received data to a determining circuit configured to determine information in response to the provided data.
For example, such a CMU can request flight-plan data from a flight management system (FMS) by sending, to the FMS, an emulated data-request message having the same or similar format as a data-request message that the ground-based aircraft operations center 12 is configured to send to the FMS. That is, the CMU is configured to “fool” the FMS into “thinking” that the data-request message originated from the ground-based aircraft operations center 12.
Because the emulated data-request message has the same, or a similar, format as a data-request message from the ground-based aircraft operations center 12 would have, the FMS responds to the emulated data-request message with a data-response message just as the FMS would have responded to a data-request message from the ground-based aircraft operations center.
The CMU intercepts and mines data from the data-response message, and provides the mined data to a determiner circuit, which determines one or more pieces of information (e.g., estimated flight arrival time) from the mined data. “Intercept” means that the CMU receives and acknowledges receipt of the data-response message if required, and that the ACARS router 22 does not transmit the data-response message to the ground-based aircraft operations center 12. Furthermore, “mining” data means that the CMU may extract and send to the determiner circuit only the portion of the data in the data-response message used by the determiner circuit to determine a particular piece of information. For example, if the data-response message from the FMS 16 includes all of the flight-plan data, then the CMU 18 may extract, from the data-response message, only the portion of the flight-plan data that the determiner circuit uses to estimate the arrival time of the aircraft 14 at the destination airport. Furthermore, the determiner circuit can be part of the CMU 18, can be separate from the CMU but still be onboard the aircraft 14, or can be separate from the CMU and remote from the aircraft (e.g., can be part of the ground-based aircraft operations center 12).
Because one can modify a CMU to operate as described above by modifying software or firmware, and not hardware, modifying the CMU is often less time consuming, less costly, and has less-stringent certification requirements, than modifying the hardware of an electronic subsystem 16 or of the ARINC 429 bus 20.
Furthermore, a CMU so modified and configured does not increase the messaging load, or overall processing load, of the ground-based aircraft operations center 12.
Moreover, because an airline typically “owns” the CMU configuration, the above-described modifications that an airline makes to the CMU can be proprietary to the airline. That is, to modify the CMU, the airline does not need the permission of the aircraft manufacturer or of a subsystem manufacturer, and, therefore, does not need to make the modification available to competing airlines.
Unless otherwise noted, a value, quantity, or attribute herein preceded by “substantially,” “approximately,” “about,” a form or derivative thereof, or a similar term, encompasses a range that includes the value, quantity, or attribute ±20% of the value, quantity, or attribute, and a range of values preceded by such a term includes the range extended by ±20% of the difference between the range endpoints. For example, an “approximate” range of b to c is a range of b−20%·(c−b) to c+20%·(c−b). Furthermore, the terms “a,” “an,” and “the” can indicate one or more than one of the objects that they modify.
In addition to the electronic subsystems 16 and the CMU 32, the aircraft 30 includes one or more electronic devices 34, such as electronic-flight-bag (EFB) devices, cabin terminal, or maintenance terminal or personal electronic device, at least some of which are, or can be, configured for communication with the CMU 32. For example, a device 34 can be a laptop or tablet computer or personal electronic device (PED) configured to display a flight path of the aircraft 30, to receive flight-plan data from a flight management system (FMS) 16 via the CMU 32, and to update the flight-path display in response to the flight-plan data. Although shown coupled to the CMU 32 via a bus 35, one or more of the electronic devices 34 can be coupled to the CMU 32 by the ARINC 429 bus 20 or by other coupling means such as an airplane interface device (AID), examples of which include Ethernet, ARINC 429, ARINC 629, RS 232, and a wireless channel).
And in addition to the ACARS router 22, the CMU 32 includes an ACARS emulator-and-data-mining circuit 36 and one or more software applications 38.
The ACARS emulator-and-data-mining circuit 36 is configured to generate an emulated data-request message that has the same, or a similar, format as a data-request message generated by the ground-based aircraft operations center 12, such that a target one of the electronic subsystems 16 is configured to respond to the emulated data-request message just as the target subsystem would respond to a data-request message from the ground-based aircraft operations center.
The ACARS emulator-and-data-mining circuit 36 is further configured to send the emulated data-request message to a target electronic subsystem 16 via the ARINC 429 bus 20 or another channel (not shown in
The ACARS emulator-and-data-mining circuit 36 is still further configured to mine data from the downlink response message received from the target electronic subsystem 16, and to provide the mined data to one or more of the devices 34, the applications 38, and the ground-based aircraft operations center 12, for determining information (e.g., predicted fuel consumption, predicted flight arrival time) from the provided data.
Still referring to
The CMU 32 causes the ACARS emulator-and-data-mining circuit 36 to request, periodically (e.g., every ten seconds to five minutes, for which the period can be configured through an aircraft database such as the data base 50 of
For each request, the ACARS circuit 36 generates an emulated data-request message that includes an address, or other identity, of the FMS 16, that specifies the data requested (e.g., all flight-plan data, partial flight-plan data), and that has a format sufficiently similar to the format that a comparable data-request message from the ground-based aircraft operations center 12 would have so that the FMS will respond to the emulated data-request message as it would to an actual data-request message from the ground-based aircraft operations center.
Next, the ACARS circuit 36 sends the emulated data-request message to the FMS 16 via the ARINC 429 bus 20, or via any other suitable communication channel (e.g., a WiFi® channel, a BlueTooth® channel).
The FMS 16 receives the emulated data-request message, generates, in response to the emulated data-request message, a downlink data-response message having a payload that includes the requested flight-plan data, and sends the data-response message to the ACARS emulator-and-data-mining circuit 36 via the ARINC 429 bus 20 or any other suitable communication channel. If the requested data is not yet available, then the FMS 16 generates the data, or waits until the requested data otherwise is generated. Furthermore, the data-response message may include an identifier, such as the address or other destination code, of the message destination, which, in this example, is the ACARS circuit 36. Alternatively, the CMU 32 parses the data-response message from the FMS 16 to determine whether the data-response message is destined for the CMU (i.e., is the response to a corresponding previously emulated data request) or for the ground-based aircraft operations center 12.
The ACARS emulator-and-data-mining circuit 36 receives the data-response message, and optionally mines the payload for the portion of the data to be used by the ground-based aircraft operations center 12 computer system. For example, if the emulated data-request message requests all flight-plan data, but the ground-based aircraft operations center 12 computer system needs only the airspeed and heading of the aircraft 30, then the ACARS circuit mines, or extracts, only the airspeed and heading from the flight-plan data. Alternatively, the ACARS circuit 36 can provide all of the data in the data-response message to the ground-based aircraft operations center 12, which has the option of using only some of the provided data.
If the data-response message is the first such message generated for the ground-based aircraft operations center 12 on the current flight of the aircraft 30, then the ACARS circuit 36 provides the selected portion of the flight-plan data to the ground-based aircraft operations center, where, as stated above, the selected portion can be some or all of the flight-plan data.
If, however, the data-acknowledge message is the second or subsequent such message generated for the ground-based aircraft operations center 12 on the current flight of the aircraft 30, then one of the software applications 38 determines, in a conventional manner, whether the latest version of the selected portion of the data differs from the previous version of the same data. For example, the one of the software applications 38 compares the current version of the data to the immediately previous version of the data to determine if the current version is the same as, or is different than, the immediately previous version.
If the one of the applications 38 determines that there is no difference between the latest and previous versions of the data, then the CMU 32 does not send the selected data portion to the ground-based aircraft operations center 12, and waits until the ACARS circuit 36 sends a subsequent data-request message to the FMS 16. By not sending redundant data, the CMU 32 saves bandwidth over the ACARS communication channel and the cost of sending an ACARS message, and relieves the ground-based aircraft operations center 12 of the burden of needlessly processing redundant data.
But if there is a difference between the latest and previous versions of the data, then the ACARS circuit 36 provides the latest version of the selected portion of the flight-plan data to the ground-based aircraft operations center 12.
Next, a computing circuit of the ground-based aircraft operations center 12 determines, in response to the latest version of the selected portion of the flight-plan data, a new estimated arrival time of the aircraft 30 at the destination airport, and updates the arrival time that a monitor at the destination airport displays.
In another example, each of one or more of the processing devices (e.g., computing circuit of the ground-based aircraft operations center 12, devices 34, computing circuit(s) running the applications 38) uses a respective portion of the flight-plan data from the data-response message from the FMS 16.
In such an embodiment, the ACARS circuit 36 mines different portions of the flight-plan data for the different processing devices, and sends, to each processing device, only the portion of the flight-plan data that the processing device will consume.
For example, assume that one of applications 38 predicts fuel consumption of the aircraft 30, a tablet computer device 34 predicts and displays a flight path of the aircraft, and a computing circuit of the ground-based aircraft operations center 12 predicts the arrival time of the aircraft at a destination airport.
The ACARS circuit 36 generates, and sends to the FMS 18 via the ARINC 429 bus 20, a data-request message that requests all of the flight-plan data.
The ACARS circuit 36 then mines respective portions of the flight-plan data from the payload of the data-response message, and provides the selected data portions to the respective processing devices. For example, the ACARS circuit 36 mines, from the payload of the data-response message, the portion of the flight-plan data that the application 38 uses to predict the fuel consumption of the aircraft 30, and provides only this portion of the data to the application. Similarly, the ACARS circuit 36 mines, from the payload of the data-response message, the portion of the flight-plan data that the tablet computer device 34 uses to predict the flight path of the aircraft 30, and provides only this portion of the data to the tablet. And, the ACARS circuit 36 mines, from the payload of the data-response message, the portion of the flight-plan data that a computing circuit of the ground-based aircraft operations center 12 uses to predict the arrival time of the aircraft 30, and provides only this portion of the data to the ground-based aircraft operations center 12.
Still referring to
In addition to a flight management system (FMS) 44, the electronic subsystems 16 include one or more Line Replaceable Units (LRUs) 46, which may include the electronic devices 34 (e.g., a tablet computer and other electronic-flight-bag devices) of
In addition to the ACARS router 22, the ACARS router-emulator-and-mining circuit 36, and the one or more software applications 38, the CMU 32 includes an aircraft-operations-communications (AOC) data engine 48, which is configured to control, and possibly to include, the ACARS circuit, the ACARS router, and one or more of the applications 38, and otherwise to cause the CMU to request unpublished data from one or more of the electronic subsystems 16, to mine the received unpublished data, and to provide the unpublished data to the ground-based aircraft operations center 12 (or possibly to one or more other devices), as described above in conjunction with
The memory 40 stores an aircraft-operations-center (AOC) database 50, which defines the functions performable by the AOC data engine 48, and which a computing circuit uses to build the data engine 48 during a boot routine. Alternatively, other ways to build, actually or effectively, the data engine 48 include using modified non-certifiable software run by the CMU 32 to build the data engine, or by updating an aircraft program module (APM, not shown in
The communications link 42 is configured to transfer messages between the ACARS router 22 and the ground-based aircraft operations center 12, and between the ACARS router and the ATC 10 (not shown in
Still referring to
After the computing circuit builds and instantiates the AOC data engine 48 and the other portions of the CMU 32, the CMU operates as described above in conjunction with
Still referring to
The software applications 38 instantiated on a computing circuit that forms the CMU 32 include a decision application 60, a monitoring application 62, a tracking application 64, and one or more other applications 66. The applications 38 can be executed by separate computing circuits, or two or more of the applications can be executed by a same computing circuit. Furthermore, each of the applications 38 are configured to operate not only on unpublished and mined data provided by the ACARS circuit 36, but are also configured to operate on data provided by another one or more of the applications. Moreover, one or more of the software applications 38 can be omitted from the AOC data engine 48, and the AOC data engine 48 can be configured to perform respective functions of each of the one or more omitted software applications.
The decision application 60 is configured to make decisions in response to unpublished data that the ACARS circuit 36 requests and receives from one or more of the electronic subsystems 16 and provides to the decision application. For example, the decision application 60 is configured to notify a pilot to request a change in course based on a comparison of current fuel level provided by a fuel sensor (not shown in
The monitoring application 62 is configured to monitor flight- and aircraft-related parameters (e.g. to monitor the flight plan for changes, fuel level, altitude, airspeed to detect a stall) in response to data that the ACARS circuit 36 requests and receives from one or more of the electronic subsystems 16 and provides to the monitoring application.
The tracking application 64 is configured to track the actual flight path already traversed by the aircraft 30 (
And examples of other applications 66 include an application that is configured to determine a best course adjustment in response to a request from a pilot to alter the course of the aircraft 30 (
The ACARS circuit 36 includes an ACARS router emulator 72 and a data-mining circuit 74. The router emulator 72 is configured to generate emulated data-request messages, and to receive datalink response messages that the electronic subsystems 16 send in response to the emulated data-request messages, as described above in conjunction with
In addition to the ACARS router 22, the ACARS router-emulator-and-data-mining circuit 36, and the one or more applications 38, the CMU 32 includes one or more application interfaces 70.
Each of the one or more application interfaces 70 is configured to generate messages that include mined data from the data-mining circuit 74, or otherwise to package the mined data, so that the mined data is in form that is compatible with those of the applications 38 and the ground-based aircraft operations center 12 that are configured to receive the mined data. And each of the one or more application interfaces 70 also can be configured to generate messages that include data published on the ARINC 429 bus 20 by one or more electronic subsystems 16. Alternatively, if one or more of the applications 38 are omitted and the AOC data engine 48 performs the functions of the one or more omitted applications, then a corresponding one or more of the application interfaces 70 may be omitted.
A cruise-altitude application interface 76 is configured to format altitude data received from the FMS 44 (
Similarly, a flight plan interface 78 is configured to format flight-plan data received from the FMS 44 (
Alternatively, the flight plan interface 78 is configured to format flight-plan data received from the FMS 44 (
Each of one or more other application interfaces 800-80n are configured to format respective data from or more of the electronic subsystems 16 for consumption by a corresponding application 38, the ground-based aircraft operations center 12, or another application or device not shown in
And the memory 40 is configured to store the AOC database 50, a data-engine builder 82, and an AOC-emulator builder 84. As described below, a computing circuit executes the builder 82 to build the data engine 48, and executes the builder 84 to build the ACARS router-emulator-data-mining circuit 36. Alternatively, the data-engine builder 82 can include the AOC-emulator builder 84 such that a computing circuit executes the builder 82 to build both the ACARS router-emulator-and-data-mining circuit 36 and the data engine 48.
Still referring to
A computing circuit, such as one or more microprocessors or microcontrollers, executes the AOC-emulator builder 84 and the engine builder 82 to instantiate, in a memory (the memory 40 or another memory not shown in
Next, the instantiated CMU 32 causes the ACARS router emulator 72 to generate an emulated data-request message having the same format as a data-request message from the ground-based aircraft operations center 12 would have, and to send the emulated data-request message to the FMS 44 (
Then, the FMS 44 (
Next, in response to the received emulated data-request message, the FMS 44 generates a data-response message that includes the requested data. For example, the FMS 44 generates the requested data, or retrieves the requested data from a memory or from another source. If the FMS 44 can provide only some of the requested data, can provide none of the requested data, or can provide only more data than the CMU 32 requested, then the FMS can be configured to provide an error code as part of the data-response message, where the error code identifies the portion of the requested data included in the data-response message, the portion of the data not provided in the data-response message, or a map of the data within the payload of the data-response message. Alternatively, the data-mining circuit 74 may “know,” a priori, the data map, which indicates which flight-plan data (e.g., heading, air-speed) is located in which portion of the payload of the data-response message. In this latter case, the FMS 44 need not provide an error code or a data map as part of the data-response message.
Then, the ACARS router emulator 72 intercepts the data-response message from the FMS 44, provides the data in the payload of the data-response message to the data-mining circuit 74, and acknowledges receipt of the data-response message to the FMS 44.
Next, the data-mining circuit 74 identifies and extracts, from the payload of the data-response message from the FMS 44, the portion(s) of the flight-plan data to send to the ground-based aircraft operations center 12, and extracts the portion(s) of the flight-plan data to send to the tracking application 64 (the portion to send to the ground-based aircraft operations center 12 can be the same as, or different from, the portion to send to the tracking application 64).
Then, the data-mining circuit 74 sends the extracted portions of the flight-plan data to the flight-plan application interface 78.
Next, the flight-plan application interface 78 formats, and otherwise conditions, the extracted data portions to be compatible with the tracking application 64 and with the corresponding application being run by the ground-based aircraft operations center 12 computer system, respectively.
Then, the flight-plan application interface 78 sends the formatted, and otherwise conditioned, extracted AOC data portion to the ground-based aircraft operations center 12 via a bus 90 (or other interface) and the ACARS router 22, and sends the formatted, and otherwise conditioned, tracking-application data portion to the tracking application 64 via the bus 90 (or other interface).
Next, the computing circuit of the ground-based aircraft operations center 12 determines information, such as a predicted arrival time or fuel consumption of the aircraft 30 (
Similarly, a computing circuit executing the tracking application 64 determines a predicted flight path of the aircraft 30 (
For subsequent emulated data-request messages to the FMS 44 (
Still referring to
Referring to
For example, a pilot of the aircraft 30 may want the CMU 32 to determine the aircraft's fuel-burn rate, to predict the aircraft's fuel reserves at locations along the flight path, and to update the predicted burn rate and fuel reserves periodically during the flight. To enable performance of this determination and prediction, the router-emulator-and-data-mining circuit 36 is configured to request periodically from the FMS 16 via an emulated aircraft-operations-center request, and to mine, data such as windspeed, airspeed, distance to the destination airport, and actual fuel consumption. The circuit 36 periodically provides the mined data to one or more applications 66 configured to calculate the actual fuel burn and to predict fuel reserves at identified locations along the current flight path. The circuit 36, or another circuit of the CMU 32, periodically receives the calculated fuel burn and predicted fuel reserves from the one or more applications, and periodically provides this information, for example, to the pilot via the bus 20 and a cockpit computer display (not shown in
In another example, personnel at the aircraft operations center 12 may want the CMU 32 to predict, periodically and automatically, the time when the aircraft 30 will be a particular distance (e.g., 50 miles) from the destination airport, and to notify, automatically, the pilot and the aircraft operations center when the predicted time is ten minutes away. To enable performance of this notification, the router-emulator-and-data-mining circuit 36 is configured to request periodically from the FMS 16 via an emulated aircraft-operations-center request, and to mine, data including current position, airspeed, flight path, and distance along the flight path to the destination airport. The circuit 36 periodically provides the mined data to one or more applications 66 configured to predict the time to the particular distance from the destination airport and to determine when that predicted time is within ten minutes from the current time. The circuit 36, or another circuit of the CMU 32, periodically receives, from the one or more applications 66, an indication as to whether the predicted time to the particular location is within ten minutes of the current time. In response to an indication that the predicted time is ten or few minutes away, the CMU 32 notifies the pilot via the bus 20 and a cockpit computer display (not shown in
From the foregoing, it will be appreciated that, although specific embodiments have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the disclosure. Furthermore, where an alternative is disclosed for a particular embodiment, this alternative may also apply to other embodiments even if not specifically stated. Moreover, the circuit components described above may be disposed on a single or multiple integrated-circuit (IC), a digital signal processor (DSP), a filter and detect (FAD) circuit, integrated-photonic (IP) dies, or radio-frequency-over-glass (RFOG) dies to form one or more ICs/IPs/RFOGs/DSP/FAD, where these one or more ICs/IPs/RFOGs/DSP/FAD may be coupled to one or more other ICs/IPs/RFOGs/DSP/FAD. Furthermore, one or more components of a described apparatus or system may have been omitted from the description for clarity or another reason. Moreover, one or more components of a described apparatus or system that have been included in the description may be omitted from the apparatus or system.
What is Exampled is:
Example 1 includes a communication management unit, comprising: an emulator circuit configured to generate a data request having a same format as a data request from a vehicle communications center, to send the data request to a subsystem disposed on a vehicle, and to receive data sent by the subsystem in response to the data request; and a data-mining circuit configured to provide at least some of the received data to a determining circuit configured to determine information in response to the provided data.
Example 2 includes the communication management unit of Example 1 wherein the emulator circuit and the data-mining circuit are disposed on the vehicle.
Example 3 includes the communication management unit of any of Examples 1-2 wherein the determining circuit is disposed on the vehicle.
Example 4 includes the communication management unit of any of Examples 1-3, further comprising the determining circuit.
Example 5 includes the communication management unit of any of Examples 1-4, further comprising a computing circuit that includes the emulator circuit and the data-mining circuit.
Example 6 includes the communication management unit of any of Examples 1-5, further comprising a computing circuit that includes the emulator circuit, the data-mining circuit, and the determining circuit.
Example 7 includes the communication management unit of any of Examples 1-6, wherein the emulator circuit is configured to generate the data request having a format compatible with an aircraft communications addressing and reporting system.
Example 8 includes the communication management unit of any of Examples 1-7, wherein the data-mining circuit is configured to provide to the determining circuit only the portion of the received data in response to which the determining circuit is configured to determine the information.
Example 9 includes a method, comprising: emulating, with a computing circuit onboard a vehicle, a data request from a vehicle communications center that is remote from the vehicle; sending, with the computing circuit, the emulated data request to a subsystem onboard the vehicle via a message route that excludes a vehicle communications center that is remote from the vehicle; receiving, with the computing circuit and via a message route that excludes a vehicle communications center that is remote from the vehicle, data sent by the subsystem in response to the emulated data request; mining the data received from the subsystem; and determining information in response to the mined data.
Example 10 includes the method of Example 9, wherein the emulated data request has a format that is compatible with a format of a data request from a vehicle communications center that is remote from the vehicle.
Example 11 includes the method of any of Examples 9-10, wherein the vehicle includes an aircraft.
Example 12 includes the method of any of Examples 9-11, wherein the one or more vehicle communications centers include one or more ground-based aircraft operations centers.
Example 13 includes the method of any of Examples 9-12, wherein the subsystem includes a flight-management subsystem.
Example 14 includes the method of any of Examples 9-13, wherein determining the information includes determining information related to a path along which the vehicle is traveling.
Example 15 includes the method of any of Examples 9-14, wherein determining the information includes determining information related to the vehicle.
Example 16 includes the method of any of Examples 9-15, wherein the vehicle communications centers each include one or more computer systems.
Example 17 includes the method of any of Examples 9-16, wherein the computing circuit includes a communication-management-unit subsystem.
Example 18 includes a non-transitory computer-readable medium storing instructions that, when executed by one or more computing circuits onboard a vehicle, cause the one or more computing circuits, or one or more other circuits onboard the vehicle and under control of the one or more computing circuits: to emulate a data request from a vehicle communications center that is remote from the vehicle; to send the emulated data request to a subsystem onboard the vehicle via a message route that excludes a vehicle communications center that is remote from the vehicle; to receive, via a message route that excludes a vehicle communications center that is remote from the vehicle, data sent by the subsystem in response to the emulated data request; and to provide at least some of the received data to a determining circuit configured to determine information in response to the provided data.
Example 19 includes the non-transitory computer-readable medium of Example 18, wherein the determining circuit is part of the one or more computing circuits or the one or more other circuits.
Example 20 includes the non-transitory computer-readable medium of Example 19, wherein the determining circuit is separate from the one or more computing circuits and the one or more other circuits.
Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement, which is calculated to achieve the same purpose, may be substituted for the specific embodiments shown. Therefore, it is manifestly intended that this invention be limited only by the claims and the equivalents thereof.