System, method, and computer program product for optimizing cruise altitudes for groups of aircraft

Information

  • Patent Application
  • 20080059052
  • Publication Number
    20080059052
  • Date Filed
    August 31, 2006
    18 years ago
  • Date Published
    March 06, 2008
    16 years ago
Abstract
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. According to exemplary embodiments, 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.
Description

BRIEF DESCRIPTION OF THE DRAWINGS

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.



FIG. 1 is a functional block diagram of exemplary functions performed for optimizing cruise altitudes for multiple aircraft;



FIG. 2 is a probable altitude density distribution curve;



FIG. 3 is a flow chart of an exemplary method for executing the functions shown in FIG. 1;



FIGS. 4, 5, and 6 are flow charts that show details of portions of the method shown in FIG. 2; and



FIG. 7 is a block diagram of an exemplary host environment for a system for hosting the functions shown in FIG. 1.





DETAILED DESCRIPTION

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 FIG. 1, exemplary functions 10, including processing functions 12, data input functions 14, and network communications 16, work together to optimize cruise altitudes for multiple aircraft. The processing function 12 develops a set of optimum initial cruise altitudes for multiple aircraft. The data input function 14 provides data to the processing function 12 to enable the processing function 12 to refine the cruise altitudes. The network communications function 16 can provide feedback to enable to processing function 12 to re-plan the cruise altitudes.


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 FIG. 2, in an exemplary embodiment the optimum initial cruise altitude function 18 suitably assigns each flight in a set of scheduled flights to its own flight level based upon a probable altitude density distribution curve 20. The probable altitude density distribution curve 20 plots altitude versus the probability that an aircraft is expected to be at the altitude. The probable altitude density distribution curve 20 is based on observed data and approximates a normal distribution curve. It has been observed that certain altitudes are preferred along certain routes due to strength of the winds at the cruise altitudes. For example, it is desirable for flights heading westbound from Europe to the United States (that is, against the prevailing winds) to minimize exposure to excessive prevailing headwinds. Weather forecasts are available to all aircraft operators, and therefore the forecast winds are known. Those forecasts yield several preferred routes and cruise altitudes. The preferred altitudes will sustain a disproportionate share of traffic and other flight levels could be almost vacant.


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 FIG. 3, an exemplary method 50 starts at a block 52.


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 FIG. 4, details of exemplary processing at the block 54 will be explained. Processing at the block 54 starts at a block 56. At a block 58, each flight in a set of scheduled flights may be assigned to its own flight level based upon the probable altitude density distribution curve 20. The probable altitude density distribution curve 20 is based upon a database of weather data (including winds and temperatures aloft) and a database of three-dimensional (3-D) flight distributions that correspond to the database of weather data. This curve corresponds to expected flight density distributions. Based upon expected winds aloft, certain flight altitudes can be preferred. These preferred altitudes can see a disproportionate share of traffic, whereas other flight levels could be almost vacant. Altitude assignments are based upon density distributions occurring in a traffic sample database. This results in aircraft altitudes being distributed in a curve which is appropriate to the operators' preferences.


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 FIGS. 1 and 3, the method 50 proceeds from the block 54 to a block 74. At the block 74, weather conditions at the first set of optimum initial cruise altitudes are accounted for to establish the second set of optimum initial cruise altitudes. Processing at the block 74 implements the weather function 22.


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 FIG. 5, in an exemplary embodiment accounting for the direction of flight at the block 76 starts at a block 78. At a decision block 80 a determination is made whether the assigned altitude from the second set of optimum initial cruise altitudes (from the block 74) is the same as the ceiling altitude. If the assigned altitude is the same as the ceiling altitude, then at a decision block 82 a determination is made whether the assigned altitude is correct for the direction of the flight or for any special Air Traffic Control considerations. If the altitude for direction of flight is correct, then no further action is needed and processing at the block 76 stops at a block 84. If the assigned altitude is not the same as the ceiling altitude, then at a block 86 the higher of the assigned altitude or the ceiling altitude is assigned and processing continues to the decision block 82.


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 FIG. 6, processing at the block 90 starts at a block 92. Any conflicts are detected at a block 94. A conflict exists when two or more aircraft flying at the same altitude are scheduled to arrive at a same waypoint at less than the required spacing. In other words, if the separation time or separation distance between the aircraft is less than the distance/time separation requirement at that waypoint, a conflict exists and must be resolved.


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 FIGS. 1 and 3, processing of the method 50 turns to implementing the network communications function 16. To that end, at a block 114 data is distributed to stakeholders via network-enabled applications. The data that is distributed at the block 114 will be either data regarding the third set of optimum initial cruise altitudes from the block 76 or, if any conflicts have been resolved, the fourth set of optimum initial cruise altitudes from the block 90.


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 FIGS. 1, 3, and 7, an exemplary system environment 200 suitably may host the exemplary functionality described above for optimizing cruise altitudes for multiple aircraft. Reference numbers used in reference to components of the system environment 200 are similar to reference numbers used in reference to corresponding functionality shown in FIG. 1.


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 FIG. 7 illustrates the processing functions 12 being centralized within one processor, processing within the system environment 200 may be distributed among as many processors as desired. Thus, hosting the processing functions 12 is not to be construed as being limited to the exemplary, non-limiting embodiment of the system environment 200 shown in FIG. 7


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 FIG. 7, the processing component 212 can access the data input 14 directly 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 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 FIG. 7.


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.

Claims
  • 1. A computer-executable method for optimizing cruise altitudes for a plurality of aircraft, the method comprising: establishing a first set of optimum initial cruise altitudes for a plurality of aircraft;accounting for weather conditions at the first set of optimum initial cruise altitudes to establish a second set of optimum initial cruise altitudes;accounting for direction of flight at the second set of optimum initial cruise altitudes to establish a third set of optimum initial cruise altitudes;determining whether a conflict exists between aircraft at the third set of optimum initial cruise altitudes; andwhen a conflict is detected, resolving the conflict to establish a fourth set of optimum initial cruise altitudes.
  • 2. The method of claim 1, further comprising distributing to at least one user data regarding altitudes chosen from the third set of optimum initial cruise altitudes and the fourth set of optimum initial cruise altitudes.
  • 3. The method of claim 2, further comprising: receiving from at least one user preference data regarding at least one user preference chosen from route assignment and altitude assignment; andaccounting for the received user preference data to establish a fifth set of optimum initial cruise altitudes.
  • 4. The method of claim 1, wherein establishing the first set of optimum initial cruise altitudes includes assigning each flight in a set of scheduled flights to its own flight level based upon a probable altitude density distribution curve.
  • 5. The method of claim 4, wherein establishing the first set of optimum initial cruise altitudes further includes reassigning the flight level that is based upon a probable altitude density distribution curve to account for reduced vertical separation minimums between aircraft.
  • 6. The method of claim 5, wherein accounting for weather conditions adjusts the probable altitude density distribution curve based upon the weather conditions.
  • 7. The method of claim 1, wherein the weather conditions include at least one weather condition chosen from wind conditions at cruise altitude, temperatures at cruise altitude, thunderstorm activity, and turbulence.
  • 8. The method of claim 1, wherein the weather conditions include at least one set of weather conditions chosen from forecast weather conditions and observed weather conditions.
  • 9. The method of claim 1, wherein accounting for direction of flight of aircraft includes: assigning to an aircraft a higher altitude chosen from an altitude assigned to a flight from the second set of optimum initial cruise altitudes and a performance ceiling of the aircraft; andassigning an adjusted altitude to the flight when the assigned altitude is not a standard altitude for the direction of flight.
  • 10. The method of claim 9, wherein assigning the adjusted altitude includes assigning an altitude to a flight having a heading between 000 and 179 that is a predetermined difference lower than an altitude assigned to another flight having a heading between 180 and 359.
  • 11. The method of claim 10, wherein the predetermined difference is around 1,000 feet.
  • 12. The method of claim 1, wherein determining whether a conflict exists determines whether at least two aircraft at a same altitude are scheduled to arrive at a same waypoint at less than a predetermined difference in at least one parameter chosen from time and distance.
  • 13. The method of claim 12, wherein determining whether a conflict exists checks for conflicts in a pair of altitude levels at a time.
  • 14. The method of claim 13, wherein resolving the conflict includes re-assigning altitudes to a least number of flights to resolve the conflict.
  • 15. The method of claim 14, wherein the flights are re-assigned to one altitude level lower than the altitude causing the conflict.
  • 16. A system for optimizing cruise altitudes for a plurality of aircraft, the system comprising: a first processing component configured to establish a first set of optimum initial cruise altitudes for a plurality of aircraft;a second processing component configured to account for weather conditions at the first set of optimum initial cruise altitudes to establish a second set of optimum initial cruise altitudes;a third processing component configured to account for direction of flight at the second set of optimum initial cruise altitudes to establish a third set of optimum initial cruise altitudes;a fourth processing component configured to determine whether a conflict exists between aircraft at the third set of optimum initial cruise altitudes; anda fifth processing component configured to, when a conflict is detected, resolve the conflict to establish a fourth set of optimum initial cruise altitudes.
  • 17. The system of claim 16, further comprising a network communications component configured to distribute to at least one user data regarding altitudes chosen from the third set of optimum initial cruise altitudes and the fourth set of optimum initial cruise altitudes.
  • 18. The system of claim 17, further comprising a sixth processing component configured to accounting for received user preference data to establish a fifth set of optimum initial cruise altitudes.
  • 19. The system of claim 16, wherein the first processing component is further configured to assign each flight in a set of scheduled flights to its own flight level based upon a probable altitude density distribution curve.
  • 20. The system of claim 19, wherein the first processing component is further configured to reassign the flight level that is based upon a probable altitude density distribution curve to account for reduced vertical separation minimums between aircraft.
  • 21. The system of claim 20, wherein the second processing component is further configured to adjust the probable altitude density distribution curve based upon the weather conditions.
  • 22. The system of claim 16, wherein the weather conditions include at least one weather condition chosen from wind conditions at cruise altitude, temperatures at cruise altitude, thunderstorm activity, and turbulence.
  • 23. The system of claim 16, wherein the weather conditions include at least one set of weather conditions chosen from forecast weather conditions and observed weather conditions.
  • 24. The system of claim 16, wherein the third processing component includes: a seventh processing component configured to assign to an aircraft a higher altitude chosen from an altitude assigned to a flight from the second set of optimum initial cruise altitudes and a performance ceiling of the aircraft; andan eighth processing component configured to assign an adjusted altitude to the flight when the assigned altitude is not a standard altitude for the direction of flight.
  • 25. The system of claim 24, wherein the eighth processing component is further configured to assign an altitude to a flight having a heading between 000 and 179 that is a predetermined difference lower than an altitude assigned to another flight having a heading between 180 and 359.
  • 26. The system of claim 25, wherein the predetermined difference is around 1,000 feet.
  • 27. The system of claim 16, wherein the fourth processing component is further configured to determine whether at least two aircraft at a same altitude are scheduled to arrive at a same waypoint at less than a predetermined difference in at least one parameter chosen from time and distance.
  • 28. The system of claim 27, wherein the fourth processing component is further configured to check for conflicts in a pair of altitude levels at a time.
  • 29. The system of claim 28, wherein the fifth processing component is further configured to re-assign altitudes to a least number of aircraft to resolve the conflict.
  • 30. The system of claim 29, wherein the flights are re-assigned to one altitude level lower than the altitude causing the conflict.
  • 31. A computer software program product for optimizing cruise altitudes for a plurality of aircraft, the computer software program product comprising: first computer program code means for establishing a first set of optimum initial cruise altitudes for a plurality of aircraft;second computer program code means for accounting for weather conditions at the first set of optimum initial cruise altitudes to establish a second set of optimum initial cruise altitudes;third computer program code means for accounting for direction of flight at the second set of optimum initial cruise altitudes to establish a third set of optimum initial cruise altitudes;fourth computer program code means for determining whether a conflict exists between aircraft at the third set of optimum initial cruise altitudes; andfifth computer program code means for, when a conflict is detected, resolving the conflict to establish a fourth set of optimum initial cruise altitudes.
  • 32. The computer software program product of claim 31, further comprising sixth computer program code means for distributing to at least one user data regarding altitudes chosen from the third set of optimum initial cruise altitudes and the fourth set of optimum initial cruise altitudes.
  • 33. The computer software program product of claim 32, further comprising seventh computer program code means for accounting for received user preference data to establish a fifth set of optimum initial cruise altitudes.
  • 34. The computer software program product of claim 31, wherein the first computer program code means assigns each flight in a set of scheduled flights to its own flight level based upon a probable altitude density distribution curve.
  • 35. The computer software program product of claim 34, wherein the first computer program code means further reassigns the flight level that is based upon a probable altitude density distribution curve to account for reduced vertical separation minimums between aircraft.
  • 36. The computer software program product of claim 35, wherein the second computer program code means adjusts the probable altitude density distribution curve based upon the weather conditions.
  • 37. The computer software program product of claim 31, wherein the weather conditions include at least one weather condition chosen from wind conditions at cruise altitude, temperatures at cruise altitude, thunderstorm activity, and turbulence.
  • 38. The computer software program product of claim 31, wherein the weather conditions include at least one set of weather conditions chosen from forecast weather conditions and observed weather conditions.
  • 39. The computer software program product of claim 31, wherein the third computer program code means includes: seventh computer program code means for assigning to an aircraft a higher altitude chosen from an altitude assigned to a flight from the second set of optimum initial cruise altitudes and a performance ceiling of the aircraft; andeighth computer program code means for assigning an adjusted altitude to the flight when the assigned altitude is not a standard altitude for the direction of flight.
  • 40. The computer software program product of claim 39, wherein the eighth computer program code means further assigns an altitude to a flight having a heading between 000 and 179 that is a predetermined difference lower than an altitude assigned to another flight having a heading between 180 and 359.
  • 41. The computer software program product of claim 40, wherein the predetermined difference is around 1,000 feet.
  • 42. The computer software program product of claim 31, wherein the fourth computer program code means determines whether at least two aircraft at a same altitude are scheduled to arrive at a same waypoint at less than a predetermined difference in at least one parameter chosen from time and distance.
  • 43. The computer software program product of claim 42, wherein the fourth computer program code means checks for conflicts in a pair of altitude levels at a time.
  • 44. The computer software program product of claim 43, wherein the fifth computer program code means re-assigns altitudes to a least number of flights to resolve the conflict.
  • 45. The computer software program product of claim 44, wherein the flights are re-assigned to one altitude level lower than the altitude causing the conflict.