Exemplary embodiments are illustrated in referenced figures of the drawings. It is intended that the embodiments and figures disclosed herein are to be considered illustrative rather than restrictive.
By way of overview, embodiments provide systems, methods, and computer program products for optimizing cruise altitudes for multiple aircraft. The embodiments may be used for optimizing cruise altitudes of multiple aircraft on multiple flight paths and/or system capacity by an operator and/or an air navigation service provider. Still by way of overview, a first set of optimum initial cruise altitudes are established for a plurality of aircraft. Weather conditions at the first set of optimum initial cruise altitudes are accounted for to establish a second set of optimum initial cruise altitudes. Direction of flight at the second set of optimum initial cruise altitudes is accounted for to establish a third set of optimum initial cruise altitudes. Any conflicts between aircraft at the third set of optimum initial cruise altitudes are detected. When a conflict is detected, the conflict is resolved to establish a fourth set of optimum initial cruise altitudes. Details will be set forth below.
An overview will first be set forth regarding exemplary functions that work together to optimize cruise altitudes for multiple aircraft. Next, details of processing blocks will be explained in the context of an exemplary method that can execute the functions. Lastly, an exemplary host environment for a system that can host the functions will be explained.
Functional Overview
Referring now to
An optimum initial cruise altitude function 18 establishes a first set of optimum initial cruise altitudes for multiple aircraft. Four-dimensional (4-D) flight path information is based upon a flight data source 19 that includes filed flight plans, active flight plans, operator requests, or other flight data sources. The 4-D flight path information is also compared against a reference aircraft performance database 21. Referring additionally to
In an exemplary embodiment, the optimum initial cruise altitude function 18 reads a flight's cruise altitude from the flight data source 19 and verifies the flight's cruise altitude according to reduced vertical separation minimums (RVSM) flight rules, subject to an aircraft's ceiling constraint. Under RVSM, opposite direction aircraft traveling between flight levels FL290 and FL410 are separated by 1000 vertical feet, based upon direction of flight. RVSM rules were implemented in U.S. domestic airspace in January 2005. Prior to 2005, the traffic was separated in U.S. domestic airspace by 2000 vertical feet, although RVSM was already used in several regions of the world, including Canada and the North Atlantic oceanic airspace.
A weather function 22 uses weather data 24 to adjust the probable altitude density distribution curve 20 to establish the second set of optimum initial cruise altitudes. The weather data 24 may include any one or more of wind conditions (such as direction and speed) and temperatures at cruise altitude, thunderstorm activity, turbulence, and the like. The weather data 24 may include forecast weather conditions and/or observed weather conditions. The weather data 24 may be provided by weather services, agencies such as the National Oceanic and Atmospheric Administration (NOAA), aircraft flying at cruise altitude, and the like.
A direction of flight function 26 uses direction of flight data 28 to account for direction of flight to establish the third set of optimum initial cruise altitudes. Information regarding preferred direction of flight is developed from flight rules/regulations and the ground track between the departure and arrival airports, adjusted as desired for air traffic control system special procedures. The direction of flight function 26 uses as a starting point the second set of optimum initial cruise altitudes generated by the weather function 22. Accounting for direction of flight serves two purposes. First, if used for day-of-flight analysis, the operators' requested preferred altitude for one flight in its schedule or the aircraft best performance cruise altitude instead of ceiling is used for a flight. Second, if the algorithm is used in a simulation study and an operator preference is not available, the algorithm uses a reference source of aircraft preferences (from the aircraft performance database 21 or like source) and adjusts the altitudes for weather and direction of flight, thus helping to assign an aircraft to an appropriate flight altitude more accurately.
A conflict detection and resolution function 30 uses airspace constraint data 32 to replicate effects of the first-come, first-served policy used by air traffic controllers. The conflict detection and resolution function 30 identifies any conflicts and determines any adjustments that should be made to cruise altitudes in order to resolve the detected conflict. Adjustments made to cruise altitudes in order to resolve any detected conflict establish a fourth set of optimum initial cruise altitudes.
In general, the conflict detection and resolution function 30 analyzes a set of predicted crossing times where conflicts are likely to occur by analyzing all waypoints along all flight paths that may have conflicts. A search analysis is conducted to determine what combination of altitudes will put the least number of aircraft at lower altitudes to resolve the conflicts.
In an exemplary embodiment, a conflict may be detected by determining whether at least two aircraft are scheduled to arrive at a same waypoint at less than a predetermined difference in time. That is, a conflict occurs if two or more flights are scheduled to come to a waypoint at the same time or if the time or distance separation between the aircraft at the waypoint is less than the distance or time constraint entailed in safe separation. As will be discussed in detail below, conflicts may be checked for in a pair of altitude levels at a time. When a conflict is detected, the conflict may be resolved by several standard methods (including lateral passing, climbing, slowing, speeding up, descending). As an example, re-assigning an aircraft to a lower flight altitude than another aircraft may resolve the conflict. In such a case, the lower altitude may be one altitude level lower than the altitude of the flight causing the conflict.
A data distribution function 34 distributes to users 36 data from the processing functions 12. When no conflicts have been detected, data regarding the third set of optimum initial cruise altitudes may be distributed to the users 36. When a conflict has been detected and resolved by the conflict detection and resolution function 30, data regarding the fourth set of optimum initial cruise altitudes may be distributed to the users 36.
The users 36 suitably are stakeholders in the air traffic control system who have subscribed to the data. As such, the users 36 may include air traffic control and air navigation control services (such as FAA and the like). The users 36 may also include operators, such as airlines, corporate aviation departments, business jet fractional ownership companies, and the like. The users 36 may review the data to which they have subscribed and formulate any desired trajectory requests, changes to route assignments, changes to altitude assignments, or the like. For example, an operator may desire, for one reason or another, to have longer flights flown at higher altitudes than shorter flights.
When desired, the users 36 may invoke a user feedback function 38 to provide feedback to route and altitude assignments. In the example mentioned above in which an operator may desire to have some flights flown at higher altitudes than other flights, the operator may submit revised trajectory requests via the user feedback function.
The user feedback function 38 invokes a replanning function 40 that accommodates the user feedback. The replanning function invokes a feedback loop that inputs the user feedback and includes the weather function 22, the direction of flight function 26, and the conflict detection and resolution function 30. Requested flight altitude changes are verified against RVSM rules. As a result of including user feedback, a collaborative decision-making process can include all stakeholders—that is, air traffic service providers and all operators.
Exemplary Method
Now that an overview has been given in functional terms, an exemplary method will be explained. Referring additionally now to
At a block 54, optimum initial cruise altitudes are established. Processing at the block 54 implements the optimum initial cruise altitude function 18 and establishes a first set of optimum initial cruise altitudes for multiple aircraft. Referring now to
At a block 60, the flight level that is based upon the probable altitude density distribution curve 20 is verified against RVSM rules. At a block 62, a flight's cruise altitude is read and aircraft are re-assigned to an optimum RVSM flight level. The assignments are based on maintaining approximately the same shape of the probable altitude density distribution curve 20 while filling the new RVSM flight levels. The probable altitude density distribution curve 20 sets RVSM flight level quotas.
At a decision block 64 a determination is made whether the re-assigned RVSM level is above the aircraft's ceiling. If the re-assigned RVSM level is above the aircraft's ceiling, then at a block 66 the aircraft's flight level is re-assigned to the aircraft's ceiling.
If not, then at a decision block 68 a determination is made whether all RVSM flight level quotas are filled. If all RVSM flight level quotas are filled, then processing at the block 54 stops at a block 70.
If not, then at a decision block 72 a determination is made if there are any more aircraft eligible for a flight altitude change. If there are no more eligible aircraft, then processing at the block 54 stops at the block 70. If there are more eligible aircraft, then processing at the block 54 returns to the block 62.
Returning now to
At the block 74, the weather data 24 is used to adjust the probable altitude density distribution curve 20 to establish the second set of optimum initial cruise altitudes. Differences between the baseline weather data (including winds and temperatures aloft) from the current weather data are analyzed and the probable flight density curve 20 is adjusted based upon best performance altitudes for the current/expected weather conditions. After the probable flight density curve 20 is adjusted, as part of processing of the block 74 the RVSM altitude assigner (that is, processing described for the block 60) is re-run.
At a block 76, the direction of flight data 28 is used to account for direction of flight to establish the third set of optimum initial cruise altitudes. Direction of flight is based upon the ground track between the departure and arrival airports, adjusted as desired for route segments. The block 76 uses as a starting point the second set of optimum initial cruise altitudes generated at the block 74.
Referring now to
If the altitude for the direction of flight is not correct, then at a processing block 88 the altitude from block 74 is adjusted. For example, if the heading of the flight is in a group of headings (such as, for example, 180-359), then at the block 88 an altitude is re-assigned that is a predetermined difference (such as around 1,000 feet lower) from the altitude re-assigned to a flight having a heading in another group of headings (such as, for example, 180-359). Processing then stops at the block 84.
At a block 90, any conflicts are detected and resolved. Processing at the block 90 uses the airspace constraint data 32 to replicate effects of the first-come, first-served policy used by air traffic controllers. As such, processing at the block 90 implements the conflict detection and resolution function 30. To that end, the objectives of processing at the block 90 are to (1) analyze a set of predicted crossing times where conflicts are likely to occur by analyzing all waypoints along all flight paths that may have conflicts; and (2) conduct a search analysis to determine what combination of altitudes will put the least number of aircraft at lower altitudes to resolve the conflicts.
Referring now to
At a decision block 96 a determination is made whether there are any conflicts at a highest altitude pair (such as flight levels 430/420) available in a timetable. The altitudes are set in pairs to account for opposite direction traffic. Because the altitudes do not conflict with each other, computational speed is improved by reducing by a factor of two the number of computations to be run.
Processing at the block 94 works downward until it reaches flight level 200 or another altitude band defined as the lowest altitude in the area of study. To that end, when no conflicts are detected at the highest altitude pair, processing at the block 94 proceeds to a decision block 98. At the decision block 98, a determination is made whether any conflicts are detected at a next lower altitude pair.
If no conflicts are detected at the decision block 98, then a determination is made at a decision block 100 whether the lowest altitude pair in the study has been reached. If so, then processing at the block 90 stops at a block 102. If not, then processing works downward and returns to the decision block 98, at which a determination is made whether any conflicts are detected at a next lower altitude pair.
If conflicts are detected at the decision block 96 or at the decision block 98, then at a decision block 104 a determination is made whether the lowest altitude pair in the study has been reached. If so, then processing at the block 90 stops at the block 102.
If the lowest altitude pair in the study has not been reached, then at a block 106 the detected conflicts are resolved. At a block 107, all flights that are involved in conflict at a flight level, e.g. 430, are examined, and a determination is made of the least number of flights that need to be changed to solve all conflicts at that level. At a block 108, the least combination of flights to resolve conflicts at this level will be moved down one level. Given by way of non-limiting example, a flight having an original altitude of flight level 430 would be moved down one level to an altitude of flight level 410.
At a block 110, a new flight schedule is built with updated flights from the block 108. That is, the fourth set of optimum initial cruise altitudes is established.
Processing at the block 90 returns from the block 106 (that is, conflict resolution) to the block 94 (that is, conflict detection). Specifically, processing returns from the block 110 to the decision block 98, at which a determination is made whether there are any conflicts at the next lower altitude pair level from the block 110. If so, then processing continues at the decision block 104. If not, then continues to the decision block 100. Thus, a final timetable (that is, the fourth set of optimum initial cruise altitudes) will be without any conflicts, or the lowest altitude pair (such as without limitation flight levels 210/200) will have been reached, or any remaining conflicts will be resolved by different means such as a route change or ground delay.
Returning now to
Data may be distributed at the block 114 in any suitable manner as desired. Given by way of non-limiting example, data may be distributed over a network to users who have subscribed to the data. As another non-limiting example, data may be distributed as set forth in U.S. patent application publication no. 2006/0069497 entitled “Tracking, Relay, and Control Information Flow Analysis Process for Information-Based Systems” and assigned to The Boeing Company, the entire contents of which are hereby incorporated by reference.
The stakeholders may provide feedback regarding the distributed data. The stakeholders may review the data to which they have subscribed and formulate any desired trajectory requests, changes to route assignments, changes to altitude assignments, or the like. For example, an operator may desire, for one reason or another, to have longer flights flown at higher altitudes than shorter flights. To that end, at a decision block 116 a determination is made whether any operator preferences for route and altitude assignments have been received, thereby implementing the user feedback function 38.
If any operator preferences for route and altitude assignments have been received, then at a block 118 operator preferences for route and altitude assignments are incorporated. The block 118 implements the replanning function 40 by returning processing of the method 50 back to the block 74. If no operator preferences for route and altitude assignments are received, then processing of the method 50 stops at a block 120.
Exemplary Host Environment
Referring now to
The processing functions 12 are executed by a processing component 212. The processing component 212 suitably is any computer processor, such as a desktop computer, a workstation, a laptop computer, a palmtop computer, or the like. While the processing component 212 as shown in
A weather data repository 224, a direction of flight repository 228, and an airspace constraint data repository 232 store their respective data as described above. As shown in
The processing component 212 is coupled in data communications with a network 250, such as a local area network (LAN), a wide area network (WAN), an intranet, the Internet, or the like. In another embodiment (not shown), the processing component 212 can also access the data input 14 via the network 250. That is, the processing component 212 can access via the network 250 the data input 14 from the weather data repository 224, the direction of flight repository 228, and the airspace constraint data repository 232, as desired. The processing component 212 can also distribute data regarding the third or fourth sets of optimum initial cruise altitudes, as discussed above, via the network 250.
User applications 236 can subscribe to the data as described above. The user applications 236 can receive the distributed data via the network 250. The user applications 236 also can access weather data from the weather data repository 224 via the network 250 and the processing component 212. The user applications also can provide feedback via the network 250. The user applications 236 can be executed on any processing platform as desired, such as without limitation a desktop computer 236A, a laptop computer 236B, a palmtop computer 236C, or the like.
In various embodiments, portions of the system and method include a computer program product. The computer program product includes a computer-readable storage medium, such as the non-volatile storage medium, and computer-readable program code portions, such as a series of computer instructions, embodied in the computer-readable storage medium. Typically, the computer program is stored and executed by a processing unit or a related memory device, such as the processing component 212 depicted in
In this regard, FIGS. 1 and 3-7 are block diagrams and flowcharts of methods, systems and program products according various embodiments. It will be understood that each block of the block diagrams and flowcharts and combinations of blocks in the block diagrams and flowcharts can be implemented by computer program instructions. These computer program instructions may be loaded onto a computer or other programmable apparatus to produce a machine, such that the instructions which execute on the computer or other programmable apparatus create means for implementing the functions specified in the block diagrams or flowchart blocks. These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function specified in the block diagrams or flowchart blocks. The computer program instructions may also be loaded onto a computer or other programmable apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions specified in the block diagrams or flowchart blocks.
Accordingly, blocks of the block diagrams or flowcharts support combinations of means for performing the specified functions, combinations of steps for performing the specified functions and program instruction means for performing the specified functions. It will also be understood that each block of the block diagrams or flowcharts, and combinations of blocks in the block diagrams or flowcharts, can be implemented by special purpose hardware-based computer systems which perform the specified functions or steps, or combinations of special purpose hardware and computer instructions.
While a number of exemplary embodiments and aspects have been illustrated and discussed above, those of skill in the art will recognize certain modifications, permutations, additions, and sub-combinations thereof. It is therefore intended that the following appended claims and claims hereafter introduced are interpreted to include all such modifications, permutations, additions, and sub-combinations as are within their true spirit and scope.