This disclosure relates to systems and methods for consuming, aggregating, and generating flight operation data to assist pilot decision making. More particularly, this disclosure relates to systems and methods that provide pilots with timely information to allow for better decision making and improved safety during the piloting of a flight.
General aviation (“GA”) is civil aviation operations other than scheduled air services and non-scheduled air transport operations for compensation or hire. Although commercial aviation has been touted as one of the safest ways to travel, general aviation flight does not enjoy a similar safety record. In addition, single-pilot general aviation operations are higher risk than dual-pilot general aviation operations. For example, the accident rate for turbine aircraft certified for single-pilot operations is 3.4 times higher than the rate for aircraft requiring two pilots and the fatal accident rate for single-pilot operations is 13 times higher than dual-pilot operations (Robert E. Breiling and Associates' 2010 Report).
In a typical dual-pilot operation, the copilot who is not flying the aircraft can handle other tasks involved in flight such as looking up pertinent information, prompting actions for the pilot flying at the appropriate time, and cross checking the performance of the pilot flying among other tasks. A single-pilot flight does not have a copilot who can perform other tasks during flight. This is one of the factors that increases the risk of single-pilot operations compared to dual-pilot operations.
Applicants have discovered a framework (i.e., a Digital Copilot) that can help improve general aviation safety by reducing single-pilot workload and/or providing timely information to the pilot. In some embodiments, the systems and methods disclosed herein can bring some of the benefits of Crew Resource Management (CRM) to the single-pilot cockpit. For example, the Digital Copilot can offload some pilot workload related to searching for and/or retrieving information by automatically presenting relevant information to the pilot based on context. In some embodiments, the Digital Copilot can deliver relevant information to the pilot based on context by predicting phase of flight and/or the pilot's intentions. For example, the digital copilot can determine what phase of flight the aircraft is currently in, and when applicable, also the traffic pattern leg the aircraft is on.
Some embodiments include a method comprising determining a phase of flight for the aircraft and in response to determining the phase of flight for the aircraft, providing the aircraft with at least one notification based on the phase of flight for the aircraft. In any embodiment, the method can include receiving a destination airport for an aircraft and determining whether visibility at the destination airport is below a threshold visibility. In any embodiment, in response to determining that the visibility at the destination airport is below a threshold visibility, notifying the aircraft of the visibility at the destination airport. In any embodiment, the method can include determining whether ceiling at the destination airport is below a threshold ceiling. In any embodiment, in response to a determination that the ceiling at the destination airport is below the threshold ceiling, providing the aircraft with at least one notification in accordance with the phase of flight for the aircraft. In any embodiment, the phase of flight for the aircraft can include takeoff or landing. In any embodiment, the method can include determining remaining distance to runway end. In any embodiment, based on the determined phase of flight of the aircraft, providing at least one notification to the aircraft comprising the remaining distance to runway end. In any embodiment, the phase of flight for the aircraft can include arrival. In any embodiment, the method can include determining whether the aircraft distance to destination airport is less than a threshold distance, and in response to determining whether the aircraft distance to destination airport is less than a threshold distance, providing the aircraft with a notification containing the appropriate radio frequency for weather information (for example, an Automated Terminal Information Service (ATIS) frequency that can be a continuous broadcast of recorded noncontrol aeronautical information in busier airport areas.). In any embodiment, the method can include determining whether the aircraft distance to destination airport is less than a threshold distance; determining whether the tower at the destination airport is open or closed; in response to determining that the aircraft distance to destination airport is less than a threshold distance and that the tower at the destination airport is open, providing the aircraft with a tower frequency notification; and in response to determining that the aircraft distance to destination airport is less than a threshold distance and that the tower at the destination airport is closed, providing the aircraft with a Common Traffic Advisory Frequency (CTAF) frequency notification. The common traffic advisory frequency, or CTAF, is the name given to the radio frequency used for air-to-air communication at US, CA, and AU non-towered airports. Alternatively, if the airport has a control tower, then the frequency of the control tower itself can be provided rather than the CTAF frequency. In any embodiment, the method can include determining an approach airport for the aircraft; determining if the approach airport is the same as the destination airport; and in response to a determination that the approach airport is not the same as the destination airport for the aircraft, providing the aircraft with a wrong airport notification. In any embodiment, the method can include determining an approach runway for the aircraft, determining closed runways from Notice to Airmen (NOTAM) data, determining if the approach runway is closed, and in response to determining that the approach runway is closed, providing the aircraft with a closed runway notification. A notice to airmen, or NOTAM, is a notice filed with an aviation authority to alert pilots of potential hazards along a flight route or at a location that could affect the safety of the flight. In any embodiment, the phase of flight can include downwind. In any embodiment, the phase of flight can include short final. In any embodiment, at least one notification based on the phase of flight for the aircraft is a “before landing” checklist notification. In any embodiment, the visibility notification, the ceiling notification, and/or any other notification can be an aural, tactile, and/or visual notification. In any embodiment, the method can be at an electronic device. In any embodiment, the electronic device can include a touch-sensitive display. In any embodiment, the method can be incorporated into panel-mount system.
Some embodiments include an electronic device comprising one or more processors; memory; and one or more programs, wherein the one or more programs are stored in the memory and configured to be executed by the one or more processors, the one or more programs including instructions for any of the methods described in the above paragraph. Some embodiments include a nontransitory computer readable storage medium storing one or more programs, the one or more programs comprising instructions, which when executed by an electronic device, cause the device to perform any of the methods described in the above paragraph.
As used herein, the singular forms “a,” “an,” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It is also to be understood that the term “and/or” as used herein refers to and encompasses any and all possible combinations of one or more of the associated listed items. It is further to be understood that the terms “includes, “including,” “comprises,” and/or “comprising,” when used herein, specify the presence of stated features, integers, steps, operations, elements, components, and/or units but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, units, and/or groups thereof.
Additional advantages will be readily apparent to those skilled in the art from the following detailed description. The examples and descriptions herein are to be regarded as illustrative in nature and not restrictive.
Exemplary embodiments are described with reference to the accompanying figures, in which:
Applicants have discovered a framework (i.e., a Digital Copilot) that can help improve general aviation safety by reducing single-pilot workload and/or providing timely information to the pilot. Specifically, the digital copilot can support the single pilot by performing some of the actions that a second pilot would typically perform. These actions can include, for example: simplifying information retrieval, offloading pilot information retrieval workload, providing contextually relevant information to the pilot, and/or cross checking pilot compliance with procedures and clearances. In some embodiments, the digital copilot can be an application for a computer.
The digital copilot herein seeks to provide pilots with timely information to allow for better decision making and improved safety during the piloting of a flight. Piloting an aircraft often requires a pilot or a flight crew to comprehend and reconcile disparate information quickly, and many times without much notice. This task can prove to be quite difficult and must be done in unison with the task of flying the aircraft. The digital copilot can employ a collection of algorithms that take the disparate information, process it, and synthesize it into meaningful information for the pilot, flight crew, other flight systems and/or other algorithms to consume. The system can maintain awareness of current and previous aircraft performance and can infer future aircraft performance states. The system can also infer pilot intent. With this information the system can adjust the inputs to algorithms, and the processing and synthesizing performed by the algorithms.
In some embodiments, the digital copilot can use flight context, thereby enabling the digital copilot to determine the pilot's intent and deliver relevant information to the pilot at the right time. The relevant information can be information elements that pilots need to access throughout the course of a typical flight. The digital copilot can automatically deliver the relevant information to the pilot through visual, tactile, and/or aural information as well as allowing the pilot to request or customize information delivered. In addition, the digital copilot can provide the pilot contextually relevant notifications. For example, the digital copilot can prompt the pilot to complete a checklist at the appropriate time, advise the pilot of deteriorating weather, or notify the pilot if they are on approach to a closed runway. These capabilities, and many others like them, can be made possible by algorithms that infer the current phase of flight, the current traffic pattern leg, and/or the destination airport (among others).
Besides single-pilot operations, many other operations may benefit from a digital copilot that never sleeps, does not get fatigued, and does not get distracted. For example, in the Asiana Airlines Flight 214 accident that occurred on Jul. 6, 2013, in San Francisco, California, the aircraft was trending low with low power and low airspeed. However, by the time the human pilots detected this trend, it was too late to recover. A digital copilot that had knowledge of the pilot's intent (i.e., to land at San Francisco) could have extrapolated the trend and potentially alerted the pilots to the impending situation with enough time to recover. Further, many Transport-Category aircraft have configuration alerts that will trigger if the pilot applies takeoff power and the aircraft is not configured for takeoff (e.g., flaps not set). A digital copilot could understand that a pilot taxiing from a gate toward a runway probably intends to takeoff and could then provide an earlier warning that the aircraft is not configured for takeoff.
In the following description of the disclosure and embodiments, reference is made to the accompanying drawings, in which are shown, by way of illustration, specific embodiments that can be practiced. It is to be understood that other embodiments and examples can be practiced, and changes can be made without departing from the scope of the disclosure.
Some portions of the detailed description that follows are presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of steps (instructions) leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical, magnetic, or optical signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It is convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. Furthermore, it is also convenient at times to refer to certain arrangements of steps requiring physical manipulations of physical quantities as modules or code devices, without loss of generality.
However, all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussion, it is appreciated that, throughout the description, discussions utilizing terms such as “processing,” “computing,” “calculating,” “determining,” “displaying,” “obtaining,” or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system memories or registers or other such information storage, transmission, or display devices.
Certain aspects of the digital copilot include process steps and instructions described herein in the form of an algorithm. It should be noted that the process steps and instructions of the digital copilot could be embodied in software, firmware, or hardware and, when embodied in software, could be downloaded to reside on and be operated from different platforms used by a variety of operating systems.
The digital copilot also relates to a device for performing the operations herein. This device may be specially constructed for the required purposes, or it may comprise a general-purpose computer selectively activated or reconfigured by a computer program stored in the computer. Such a computer program may be stored in a non-transitory, computer-readable storage medium, such as, but not limited to, any type of disk, including floppy disks, optical disks, CD-ROMs, magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, application specific integrated circuits (ASICs), or any type of media suitable for storing electronic instructions, and each coupled to a computer system bus. Furthermore, the computers referred to in the specification may include a single processor or may be architectures employing multiple processor designs for increased computing capability.
The methods, devices, and systems described herein are not inherently related to any particular computer or other apparatus. Various general-purpose systems may also be used with programs in accordance with the teachings herein, or it may prove convenient to construct a more specialized apparatus to perform the required method steps. The required structure for a variety of these systems will appear from the description below. In addition, the digital copilot is not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement the teachings of the digital copilot as described herein.
The digital copilot's methods and systems can be illustrated by flowcharts. The flowcharts can include a plurality of boxes. These boxes can correspond to various steps in a method or system. For example, some boxes may correspond to a processing step and other boxes may correspond to a decision step.
The algorithms run by the digital copilot can be run by an algorithm manager. The algorithm manager can be responsible for managing the various algorithms.
In some embodiments, the digital copilot can include a controller. The controller can register algorithms (e.g., one or more of the below algorithms) and can determine whether a notification should be presented to the pilot based on an algorithm result and stored data. Essentially, the controller can act as the brain of the digital copilot. For example, if the controller is unregistered for an algorithm or if the controller unregisters for an algorithm, the application or device for running the algorithm can be shut down to prevent unnecessary processing (presuming the algorithm is not in use elsewhere in the software). Similarly, registering for an algorithm may include activating an application or a device for running the algorithm, according to some embodiments. For example, the controller can register with the runway remaining algorithm during takeoff and landing so that it may deliver runway remaining notifications to the pilot based on those results. However, when airborne, the runway remaining algorithm may not be needed and, therefore, can be stopped. Besides the controller automatically registering and unregistering for an algorithm, a user can customize which information/notifications it wants to receive. Therefore, the controller can register and unregister for algorithms corresponding to the information/notifications.
In some embodiments, the controller registers or unregisters for application or device running the algorithm based on customizations or instructions input by the user. For example, the user can input a customization that specifies which algorithms are to be registered during certain phases of flight. In some embodiments, the controller can include speech recognition functionality to receive the user's instructions or customizations via speech commands. For example, the user can say “I don't want to know about weather conditions,” which the controller can interpret via the speech recognition functionality. In response, the controller may deregister one or more algorithms related to monitoring and reporting weather conditions.
In response to receiving the phase of flight information, the controller can take various actions. If the current phase of flight is taxi, the controller can clean up various notifications. For example, the controller can remove previous notifications that have been presented to the user. In some embodiments, the controller can keep only the notifications that are relevant at the current moment. In some embodiments, the controller can remove notifications that are no longer needed unless their context is still valid. For example, the controller can remove notifications regarding distance to destination from a user interface since the user is at its destination during taxi.
If the current phase of flight is takeoff, the controller can determine if the runway remaining algorithm is registered. If it is not registered, the controller can register for the algorithm. If the controller is registered for the runway remaining algorithm or if the controller is already registered for the runway remaining algorithm 202, the runway remaining algorithm can output the distance until the end of the runway. Once the distance to end of runway is received, the controller can determine whether to notify the user of the distance to end of runway. In some embodiments, once the distance to end of runway is received, the controller can determine if the distance is divisible by a given number (e.g., 100, 250, 500 (as shown in
Similar to takeoff phase of flight, if the current phase of flight is landing, the controller can determine if the runway remaining algorithm is registered. If it is not registered, the controller can register for the algorithm. If the controller is registered for the runway remaining algorithm or if the controller is already registered for the runway remaining algorithm 202, the runway remaining algorithm can output the distance until the end of the runway. In some embodiments, the distance until end of runway can be received from another source such as user input. Once the distance to end of runway is received, the controller can determine whether to notify the user of the distance to end of runway. In some embodiments, once the distance to end of runway is received, the controller can determine if the distance is divisible by a given number (e.g., 100, 250, 500 (as shown in
If the current phase of flight is arrival, the controller can determine if the distance to destination algorithm is registered. If it is not registered, the controller can register for the algorithm. If the controller is registered for the destination distance algorithm or if the controller is already registered for the destination distance algorithm 203, the destination distance algorithm can continually monitor the aircraft distance to the destination airport, outputting the distance for consumption at a regular interval. In some embodiments, the distance to destination can be received from another source such as user input. In some embodiments, once the distance to destination is received, the controller can determine whether to notify the user with the appropriate radio frequency for weather information (an ATIS frequency notice). For example, once the distance to destination is received, the controller can determine: (1) if the distance is less than or equal to a given distance (e.g., 5, 10, 20 (as shown in FIG. 2), 50, 100 miles); (2) if the ATIS is not issued; and/or (3) if the ATIS is available. As discussed above, The automatic terminal information service, or ATIS, can be a continuous broadcast of recorded noncontrol aeronautical information in busier airport areas. In some embodiments, if at least one of these three conditions is met, the controller can notify the user of the ATIS. Such a notification can be an aural, tactile, and/or visual notification to the user of the ATIS. In some embodiments, if all three conditions are met, the controller can notify the user of the ATIS. Accordingly, the controller can continuously provide ATIS frequency notices to the user based on the current phase of flight (e.g., arrival) and the destination distance algorithm.
In some embodiments, after at least one of these three conditions (or if all three of these conditions) is met, the controller can determine: (1) if the distance is less than or equal to a second given distance (e.g., 5, 10, 13 (as shown in
Irrespective of the current phase of flight, the controller can run a NOTAM parser 205. As discussed above, a notice to airmen, or NOTAM, is a notice filed with an aviation authority to alert pilots of potential hazards along a flight route or at a location that could affect the safety of the flight. The NOTAM parser can be an algorithm that ingests NOTAM data, parses it looking for specific NOTAM types, and then monitors the flight to determine if NOTAM data should be presented (e.g., closed runway notification if the approach runway is closed, localizer or other navigation equipment is out of service, etc.). For example, NOTAM parser can gather NOTAMs for the destination airport and parse through the raw text looking for instances of closed runways. If the closed runway from the NOTAM parser is the approach runway, the controller can provide the user with a closed runway notice. Such a notification can be an aural, tactile, and/or visual notification to the user that the runway to which they are currently on approach has been NOTAM′d closed. In some embodiments, the approach runway can be from the phase of flight information. Accordingly, the controller can provide closed runway notices to the user based on the current phase of flight (e.g., arrival) and the NOTAM parser.
If the current phase of flight is arrival, the controller can determine if the approach airport is the same as the intended destination airport. In some embodiments, the approach airport can be inferred from the phase of flight information. In some embodiments, the destination airport can be entered by the user. If the approach airport is not equal to the destination airport, the controller can provide the user with a wrong airport notice. Such a notification can be an aural, tactile, and/or visual notification to the user that the airport to which they are currently on approach is not the destination airport. Accordingly, the controller can provide wrong airport notices to the user based on the current phase of flight (e.g., arrival). In some embodiments, the current phases for landing include downwind (leg), base (leg), and short final (leg). These three phases correspond to three sides of a rectangular pattern that the user follows to land the plane on the approach runway. In general during visual flight operations, to land on the approach runway, the flight path starts on the downwind leg where the plane is flying parallel to the approach runway with a distance (e.g., 0.75 or 1 mile) from the approach runway.
If the current phase of flight is downwind (i.e., the traffic pattern leg is downwind), the controller can determine if the traffic pattern conformance algorithm is registered, according to some embodiments. If it is not registered, the controller can register for the traffic pattern conformance algorithm 206. Once the controller is registered for the traffic pattern conformance algorithm or if the controller is already registered for the traffic pattern conformance algorithm 206, the traffic pattern conformance algorithm can monitor the pilot's tracking of the downwind leg (i.e., the flight track parallel to runway). In other words, the traffic pattern conformance algorithm can determine whether the pilot is flying the downwind leg as expected. In some embodiments, if the algorithm detects that the pilot is drifting toward or away from the runway (rather than tracking parallel to the runway), the traffic pattern conformance algorithm can notify the user of this. Such a notification can be an aural, tactile, and/or visual notification to the user that the aircraft is drifting towards or away from the runway. In addition, the traffic pattern conformance algorithm can also determine if (at the current ground speed) it will be possible for the pilot to make the turn to base and final without overshooting the final approach course. In some embodiments, if the algorithm detects that the pilot cannot make the turn from base to final (using normal control inputs) without overshooting the final approach course, the traffic pattern conformance algorithm can provide aural, tactile, and/or visual notices to the user that the aircraft is too close to the runway to make the turn to final.
If the current phase of flight is base (i.e., the traffic pattern leg is base), the controller can determine if the overshoot algorithm is registered, according to some embodiments. If it is not registered, the controller can register for the overshoot algorithm 208. Once the controller is registered for the overshoot algorithm 208 or if the controller is already registered for overshoot algorithm 208, the overshoot algorithm can monitor the pilot's tracking of the base leg (i.e., the flight track perpendicular to runway). In some embodiments, the monitoring performed by the controller (running the overshoot algorithm) can include retrieving approach runway information for the approach airport, receiving Global Positioning System (GPS) location of the plane, receiving a speed of airplane, a wind speed, or a combination thereof. For example, approach runway information may include location of the approach runway, altitude of the approach runway, preferred approach runway based on current winds, and traffic pattern direction. In some embodiments, based on the monitored information, the overshoot algorithm computes the geometric flight path needed to be followed to turn the plane to enter the short final phase. In some embodiments, if the algorithm detects that the geometric path requires that the plane turn at an angle greater than a threshold angle, then the algorithm can notify the user of possible overshoot in transitioning to the short final phase. In some embodiments, the algorithm adjusts the threshold angle based on approach runway information for the approach airport, receiving GPS location of the plane, receiving a speed of airplane, a wind speed, stored aircraft performance parameters, or a combination thereof. Such a notification can be an aural, tactile, and/or visual notification to the user that the aircraft is likely to overshoot the final approach course. Accordingly, the user may heed the overshoot notification, abandon the current landing attempt, and return to the air to prevent a possible accident. The next instance that the plane enters the base phase, the user can control the plane to turn earlier to prevent possible overshoot.
If the current phase of flight is short final, the controller can determine if a “GUMPS” notification has already been issued for approach. GUMPS (i.e., Gas, Undercarriage, Mixture, Propeller, Seat belts and Switches) is a widely used acronym for a mental checklist to ensure nothing critical has been forgotten before landing. If a GUMPS notification has not been issued, the controller can issue a GUMPS notice. Such a notification can be an aural, tactile, and/or visual notification to the user that the GUMPS check should be completed. For example,
In some embodiments, prior to the landing phase of flight, the controller can register for a pattern entry guidance algorithm if not already registered. In some embodiments, the pattern entry guidance algorithm retrieves approach runway information from a database based on the approach airport and accesses current wind and traffic information to determine preferred approach runway. The approach runway information may include the dimensions of the runway, turn directions, and a suggested rectangle pattern (or path) to follow, or other information included in the Federal Aviation Regulations Aeronautical Information Manual (FAR/AIM) for the approach airport. In some embodiments, the controller can plot the suggested rectangle pattern on a user interface such as the map GUI as described with respect to
In any phase of flight, the controller can determine if a checklist notification has been issued for an applicable checklist, and if it has not been issued, the controller can issue the checklist notice. Examples of applicable checklists include, for example, a before takeoff checklist, a before landing checklist, an emergency checklist, and the like.
In some embodiments, the controller can register the weather monitor 207. In some embodiments, the controller can register for the weather monitor upon startup by the controller. In some embodiments, the weather monitor can periodically (e.g., every 5, 10, 15, minutes etc.) receive weather information (e.g., visibility and ceiling values as shown in
In some embodiments, the weather monitor can store the received weather information in a database associated with the controller. The controller may periodically (e.g., every 5, 10, or 15 minutes etc.) analyze the weather information stored by the weather monitor to determine what notification to transmit to the user. Such a notification can be an aural, tactile, and/or visual notification to the user of the visibility. For example, upon receiving the visibility and ceilings from the weather monitor, the controller can determine whether to send a visibility and ceiling notice to the user. In some embodiments, if the visibility is less than a certain distance (e.g., 1, 2, 3 (as shown in
In some embodiments, the controller can analyze the stored weather information to determine whether a change in visibility and/or ceiling meet predefined criteria. In some embodiments, the visibility and/or ceiling include values from a first weather station corresponding to the destination airport, a second weather station corresponding to the closest airport, or a plurality of weather stations (which may include the first or second weather stations) on the flight route. Based on the change in received weather information, the controller can provide a weather notice. For example, if the visibility for a weather station closest to the plane decreases by a threshold amount (i.e., the change in visibility exceeds the threshold amount), then the controller may generate a weather notice that alerts the user of decreasing weather conditions. In some embodiments, the weather notice can be provided by the controller aurally, tactilely, or visually. For example, the controller can plot visual notifications on a user interface (e.g., a map graphical user interface as described with respect to
In some embodiments, based on the generated notices (e.g., visibility notice, ceilings notice, or weather notice), the controller can propose alternate flight routes to the user. For example, the controller can plot a proposed flight route on the user interface discussed above.
In some embodiments, the controller can register unperceived roll monitor 209. In some embodiments, the controller can register for unperceived roll monitor 209 upon startup by the controller. In some embodiments, the controller can register unperceived roll monitor 209 once the phase of flight algorithm described with respect to
In some embodiments, unperceived roll monitor 209 can periodically (e.g., every 1, 1.5, or 2 seconds) monitor a heading across a period of time (e.g., 20 seconds, 30 seconds, etc.). In some embodiments, unperceived roll monitor 209 receives the heading from a heading indicator or a GPS that incorporates the heading indicator. In some embodiments, the controller can track a rate of change of the heading based on the heading information received from unperceived roll monitor 209. Then, based on a trend of the rate of change of the heading over a set period of time (e.g., 20, 25, 30, 35, or 40 seconds) on a rolling basis \, the controller can issue an unperceived roll notice. In some embodiments, the controller compares the trend being tracked with an expected trend line for the unperceived roll such that if the tracked trend fits the expected trend line, the controller generates an unperceived roll notice to provide to the user. In some embodiments, the controller can determine a fit between the tracked trend and the expected trend line if the Root Mean Square Error between the trend line is less than a predefined value. In some embodiments, the expected trend line can be dynamically updated by the controller based on a rate of change of the heading, a length of the set period of time used in tracking the trend, or a combination thereof. In some embodiments, the unperceived roll notice can be provided by the controller aurally, tactilely, and/or visually. Generally, when a user is consciously turning, the heading would change at a constant rate (e.g., 2 or 3 degrees a second). Accordingly, an increasing rate of change less than a threshold amount may indicate that the rate of change of the heading had been increasing within the period of time without the user noticing. This trend in the rate of change of the heading would be tracked within the set period of time, as discussed above.
Besides the notifications described above, the controller can notify the user of a wide variety of notifications including custom notifications. In some embodiments, the controller can register for an altitude monitoring algorithm. The altitude monitoring algorithm can monitor altitude conformance and alert the user if he deviates from a set altitude. In some embodiments, the altitude monitoring algorithm can be registered by the controller during the arrival phase. In some embodiments, the controller can retrieve instrument approach (or instrument approach procedure (IAP)) information to determine an altitude threshold or range appropriate for a segment (or phase) of the instrument approach. In some embodiments, the controller determines the current segment based on the GPS and orientation information of the plane. For example, during a specific segment, the instrument approach may require the pilot pass that specific segment at or above 3000 feet. In this example, the controller can alert the user of non-compliance if the altitude falls below the 3,000 feet altitude threshold. Such a notification can be an aural, tactile, and/or visual notification to the user.
In some embodiments, the controller can register for a hold monitoring algorithm. The hold monitoring algorithm can monitor for the hold join and provide countdown timers or distance remaining notifications throughout the hold. Such a notification can be an aural, tactile, and/or visual notification to the user. In some embodiments, the controller can register for a taxi conformance algorithm. The taxi conformance algorithm can ingest a taxi clearance and monitor conformance with the assigned taxi route. The controller can then provide the user with turn-by-turn taxi route guidance notifications and can provide notification if a deviation from the planned taxi route is detected. These notifications can be provided aurally, tactilely, and/or visually to the user.
In some embodiments, the controller can register for a flight stability algorithm. The flight stability algorithm can identify deviations from “ideal” flight path (e.g., monitoring stability during pattern operations and practice maneuvers). The user can then receive notifications if the flight stability deviates from the ideal flight path. These notifications can be provided aurally, tactilely, and/or visually to the user.
In some embodiments, the controller can register for an airspace incursion/excursion algorithm. The airspace incursion/excursion algorithm can monitor and provide the pilot with notifications if the flight path and/or current trajectory is trending toward penetrating or exiting a particular airspace. These notifications can be provided aurally, tactilely, and/or visually to the user.
In some embodiments, the controller can register for a hazards algorithm. The hazards algorithm can identify if the flight is moving towards hazards like terrain, obstacles, traffic, or weather. The user can then be provided with notifications at an early enough point for the user to make decisions and take corrective actions to remain clear of any hazards. In some embodiments, the controller can register for a 4D Flight Plan Conformance algorithm. The 4D flight plan conformance algorithm can monitor the ability of pilots to conform with multi-waypoint flight plans with target altitudes (and possibly time-of-arrival). The pilot can be notified of any deviations during flight progress. In some embodiments, the controller can register for a communication frequency monitoring algorithm. The communication frequency monitoring algorithm can use speech recognition to listen to ATC clearances and/or instructions and capture those relevant to the flight. Once captured, these ATC clearances can be implemented automatically (subsequently monitored for conformance) and verify correct readback. For example, if an ATC clearance amended the altitude for a charted crossing restriction, this new information could be incorporated into the conformance monitoring algorithm for that crossing. In some embodiments, the controller can register for an instrument flight support algorithm. The instrument flight support algorithm can monitor key approach information with a “just-in-time” model. The user can then be reminded of these key approach items (e.g., decision height, initial missed approach steps, etc.). In some embodiments, the controller can register for a cognitive assistance algorithm. The cognitive assistance algorithm can implement machine learning algorithms to track pilot behavior over time and provide tailored information to pilots (e.g., less information about familiar airports, more information about unfamiliar airports). As such, the digital copilot could better infer a pilot's intent through machine learning across both individual pilots as well as by aggregating across all pilots using the digital copilot over time. In some embodiments, the controller can register for an active runway algorithm as discussed below. The active runway algorithm can determine where the aircraft currently is within a runway boundary and, if so, whether aligned with the runway. The user can receive notifications if the aircraft is not aligned with the active runway.
Although the digital copilot controller can detect if the algorithms are registered based on a given phase of flight, if the phase of flight changes, the controller can also unregister for an algorithm that is no longer being used, given the change of flight phase. In addition, with any notification, the user can request to receive certain notifications based upon user set parameters. For example, the pilot can ask to receive notifications if the ceilings get below 3000 feet at the destination airport even if the initial set up of the controller would not start sending ceiling notifications until the ceiling was below 1000 feet.
In some embodiments, the phase of flight algorithm can operate in two stages: categorization (e.g., as shown in
The phase of flight algorithm can then determine if it actually has an ownship location. If there is no location of the aircraft, then the algorithm can mark the phase of flight as unknown. If the algorithm does have a location, the algorithm can look for the closest airport to the aircraft. If there is not a closest airport, then the algorithm can set the phase of flight as unknown. In some embodiments, the closest airport can be the closest airport within a given distance (e.g., 10, 25, 50 miles). If the algorithm does have a closest airport, then a phase of flight test 401 can be run at three different airports. These three airports can be: (1) the closest airport; (2) the inferred airport; and (3) the declared destination airport. In some embodiments, the inferred airport can be obtained from the inferred destination airport algorithm discussed below. As will be described below with respect to
The phase of flight test can start with receiving the ownship location, an airport (i.e., one of three airports referenced above), and the last phase of flight test. The last phase of flight test can be replaced each time a phase is calculated. However, the last phase of flight test can start as null.
The phase of flight test can get derived location data. From the derived location data, the test can determine if the calculated acceleration is greater than 0. If the calculated acceleration is greater than 0, the test can set the groundspeedincreasing value to true. If the calculated acceleration is not greater than 0, the test can set the groundspeeddecreasing value to true. From the derived location data, the test can also determine if the aircraft is climbing, roughly level, or descending (i.e., intentionally climbing at a reasonable rate, intentionally descending at a reasonable rate, or basically staying level). For example, from the derived location data, the test can determine if the calculated vertical speed (cvs) is not equal to 0. If the calculated vertical speed is equal to 0, the test can set the verticalspeedlow value to true. If the cvs is not equal to 0, the test can determine if the cvs is greater than a set value (e.g., 250 fpm). If the cvs is greater than the set value, the test can set the verticalSpeedPositive value to true and can determine if the absolute value of cvs is less than the set value. If the absolute value of cvs is less than the set value, the test can set the verticalSpeedLow value to true. If the cvs is less than the set value, the test can determine if the cvs is less than −set value (e.g., −250 fpm). If the cvs is less than −set value, the test can set the verticalSpeedNegative value to true.
The phase of flight test can also get all the runways for the given airport. The test can see if the aircraft is on the runway and intending to go down the runway (i.e., on and aligned with the runway). For example, the test can then see if the location of the aircraft is within the runway bounds with a buffer (e.g., 50 ft as shown in
The phase of flight test can also obtain the difference between the ownship altitude and airport altitude (i.e., altitude above ground level). With the differences between the ownship altitude and airport altitude, the test can determine whether the aircraft is on the ground at an airport, near an airport in altitude, or flying over the top of an airport at an altitude sufficient to suggest the pilot has no intent to land at the airport. If the difference is less than a given value (e.g., 150 feet), the test can set the altitudenearairport value to true and the altitudelessthantwothousand value to true. If the difference is not less than the set value, the test can determine if the difference is less than a second set value (e.g., 2000 ft). If the difference is less than a second set value, the test can set the altitudelessthantwothousand value to true.
The phase of flight test can also determine if the ground speed is greater than a given value (e.g., 35). If the ground speed is greater than a given value, the test can set the groundspeedtoflight value to true. If the ground speed is not greater than a given value, the test can set the groundspeedtoground to true.
The phase of flight test can also obtain the distance from the aircraft to the airport. The phase of flight test can then determine if the distance to the airport is less than a certain number of values (e.g., 2, 3.5, 5, 10, and 20 miles). For example, if the distance is less than 2 miles, the test can set the positionwithintwomilesofairport value, positionwithinthreemilesofairport value, positionwithinfivemilesofairport value, positionwithinttenmilesofairport value, and the positionwithintwentymilesofairport value to true. If the distance is less than 3.5 miles, the test can set the positionwithinthreemilesofairport value, positionwithinfivemilesofairport value, positionwithinttenmilesofairport value, and the positionwithintwentymilesofairport value to true. If the distance is less than 5 miles, the test can set the positionwithinfivemilesofairport value, positionwithinttenmilesofairport value, and the positionwithintwentymilesofairport value to true. If the distance is less than 10 miles, the test can set the positionwithinttenmilesofairport value and the positionwithintwentymilesofairport value to true. If the distance is less than 20 miles, the test can set the positionwithintwentymilesofairport value to true. In addition, the phase of flight test can also determine if the distance from the aircraft to the airport is less than this distance the last time this test was ran. If the new distance is less than the last time the test was ran, the test can set the distancetoairportdecreasing value to true.
The phase of flight test can also calculate the time to the airport (
The phase of flight test can also calculate the bearing to the airport. For example, if the difference between the ownship course and the bearing to the airport is within a certain degree range (for example, +/−10), the test can set the pointedtowardsairport value to true.
As stated above and returning back to
From the closest airport phase of flight test as shown in
In some embodiments, as described with respect to
In evaluating the taxi phase, the current phase of flight can be identified as taxi if the aircraft has a “low” ground speed, be a “short” distance from the airport, and has an altitude that is “close” to the airport's altitude, where the criteria for “low,” “short,” and “close” are set according to aircraft type. If not, the phase of flight may proceed with evaluating a next potential phase of flight.
In evaluating the takeoff phase, the current phase of flight can be identified as takeoff if the aircraft has a “high.” “increasing” speed, an altitude that is “low” as measured relative airport elevation, on or over a runway, and is aligned with that runway. If not, the phase of flight may proceed with evaluating a next potential phase of flight.
In evaluating the departure phase, the current phase of flight can be identified as departure if the aircraft is within 10 miles of the airport, within 2000′ feet above the airport, exceeding a specified rate of climb, and the traffic pattern leg algorithm returns departure.
In evaluating the approach phase, the current phase of flight can be identified as approach if the traffic pattern leg algorithm determines the aircraft is on the overhead, join, downwind, base, or short final leg.
In evaluating the arrival phase, the current phase of flight can be identified as arrival if the aircraft is between 5 and 20 miles (values may vary by aircraft type) of the destination airport set by the pilot, and the set destination agrees with the destination as determined by the inferred destination algorithm.
In evaluating the en route phase, the current phase of flight can be identified as en route if the aircraft is level (allowing for modest rates of climb or descent), and either more than 10 miles from the specified airport or at an altitude greater than 2000′ above that same airport.
In evaluating the maneuver phase, the current phase of flight can be identified as maneuver if the aircraft is climbing or descending at a rate higher than a specified threshold, or if the turn rate exceeds 1 degree per second.
If the current phase of flight is not identified as any of the above potential phases of flight, the phase of flight can be set to unknown.
If the phase of flight algorithm cannot determine whether the phase of flight is landing, takeoff, or taxi, the phase of flight algorithm can obtain the pattern leg. In some embodiments, the pattern leg is obtained from the traffic pattern leg algorithm discussed below. In some embodiments, the pattern leg obtained can be the pattern leg of the closest airport (“closest leg”). Based off of the pattern leg, the phase of flight algorithm can obtain the runway and runway end. The phase of flight algorithm can then use information from the closest airport phase of flight test (e.g., CAT.14 and CAT.17) and the set airport phase of flight test (e.g., SAT.9) to determine if the pattern leg is a departure or crosswind pattern leg. The phase of flight can then be the departure or crosswind pattern leg.
The phase of flight algorithm can also use information from the closest airport phase of flight test (e.g., CAT.14 and CAT.17) and the set airport phase of flight test (e.g., SAT.9) to determine if the airport has been set by the user. If the airport was not set by the user, the phase of flight algorithm can take into account the inferred airport as shown in
If the airport is not set by the user, the information from the set airport phase of flight test (e.g., SAT.14, SAT.17, and SAT.8) is not true, or the set airport is not the same as the closest airport while the information from the set airport phase of flight test (e.g., SAT.14, SAT.17, and SAT.8) is true, the phase of flight algorithm can determine: (1) if the inferred airport is not unknown; (2) if the user set airport is not the inferred airport; and (3) if information from the inferred airport phase of flight test (e.g., IAT.8) is true, as shown in
If the pattern leg is unknown, departure, or the crosswind, the phase of flight algorithm can determine whether the phase of flight is arrival, maneuver, or en route. For example, as shown in
In some embodiments, after identifying a phase of flight, the phase of flight algorithm can send the phase of flight to a buffer 402 of the phase of flight algorithm to proceed with the sensibility stage.
Each time a new phase is calculated, the new phase can be added to the tracker and the older one can be removed, then the algorithm figures out if the transition makes sense. For example, an aircraft cannot go from en route to takeoff. Such a transition would likely indicate poor location data, and, in such a case, the phase of flight algorithm may set the phase of flight to unknown to ensure the phase of flight dependent algorithms do not issue false or misleading notifications.
The buffer can provide a way to provide a smooth answer for the phase of flight. The buffer can remove the first phase of flight from the tracker and append the newest calculated phase of flight to the tracker. In some embodiments, the buffer can store transitions between a predetermined number (e.g., 5) of the most recent identified phases of flights. The buffer can be used to then check for unique phases of flight in the tracker. If there are more than 2 unique phases of flight, the phase of flight for the overall phase of flight algorithm can be set to unknown. If there is only 1 unique phase of flight, the phase of flight for the overall phase of flight algorithm can be set to that phase of flight. If there are 2 unique phases of flight, the phase of flight algorithm can determine if the phase sequence is allowed for each phase in the tracker. If it is not allowed, the phase of flight for the overall phase of flight algorithm can be set to unknown. If the sequence is allowed, the algorithm can determine if the current phase of flight equals the maneuver phase. If it does, then the phase of flight for the overall algorithm can be set to maneuver. If the current phase of flight does not equal the maneuver phase, the phase of flight for the overall algorithm can be set to the first phase of flight in the tracker.
In some embodiments, the following transitions between a first and a second of the two unique phases of flight described above are allowed (phase A:phase B indicates a phase transition from phase A to phase B): MANEUVER:any phase other than UNKNOWN; any phase other than UNKNOWN:MANEUVER; TAXI:TAKEOFF; TAKEOFF:DEPARTURE; DEPARTURE:CROSSWIND; CROSSWIND:DOWNWIND; DOWNWIND:BASE; BASE:FINAL; FINAL:LANDING; LANDING:TAXI; UNKNOWN:TAXI; FINAL:SHORTFINAL; LANDING:MISSED_APPROACH; and SHORTFINAL:MISSED_APPROACH.
An active runway algorithm can determine where the aircraft currently is within a runway boundary and, if so, whether aligned with the runway.
If the algorithm cannot obtain the airport (e.g., the user did not set one), the active runway may be unknown. Once the airport is obtained (either closest, set destination, or inferred), the active runway algorithm can obtain the runways for the given airport. The active runway algorithm can then determine whether the location of the aircraft is within the runway bounds. If yes, the active runway algorithm can determine the difference between the ownship and the runway end headings and say that the aircraft is aligned with the active runway. If no, the active runway algorithm can obtain the runway whose runway end the aircraft is closest to and can sort the various runways based on the smallest difference between runway bearing and ownship heading. The active runway algorithm can then determine if the bearing to first end and runway heading is less than a certain degree range (e.g., +/−10 degrees). If yes, then the aircraft is aligned with the active runway. If no, then the active runway algorithm can determine the runway end the aircraft is closest to and the aircraft is not aligned with the runway.
The runway remaining algorithm can determine the distance between the aircraft's current position and the end of the runway. In some embodiments, the runway remaining algorithm is only executed when the active runway algorithm has identified an active runway.
The traffic pattern leg algorithm can identify a traffic pattern leg in real time without the pilot providing the destination airport using a quasi-fuzzy algorithm. The algorithm can generate a fuzzy score for each possible traffic pattern leg at each runway at an airport. The fuzzy score can consider along track distance, cross track distance, altitude, and relative bearing. For example,
From there, the base end of the runway, the distance to threshold, the cross track distance, and the along track distance for the runway can be determined. From this information, the traffic pattern leg algorithm (for each traffic pattern leg for a given runway) can get heading delta, calculate a fuzzy score for each pattern leg for the runway (see
If the pattern leg score for the higher of the two pattern legs is less than a threshold value (e.g., 0.56), the traffic pattern leg algorithm can set the traffic pattern leg to unknown. If the pattern leg score for the higher of the two pattern legs is greater than a threshold value (e.g., 0.55), the pattern leg associated with the pattern leg score for the higher of the two pattern legs can be the pattern leg for the overall traffic pattern leg algorithm.
Once the pattern leg is determined for the overall traffic pattern leg algorithm, the belief state can be updated as shown in
In some embodiments, to calculate the probability for the airport, the inferred destination airport algorithm considers one or more of the following factors: a proximity to the airport, whether the aircraft is heading towards the airport, whether a reasonable rate of descent would allow the pilot to reach the airport altitude (referred to as “makeability”), whether the pilot has a history of flights to the airport, and a use (measured in yearly operations at the airport). In some embodiments, which of the one or more above factors to consider are selected based on an aircraft altitude above the airport.
The inferred destination airport algorithm can use a variety of probability distributions. For example, the inferred destination airport algorithm can use:
The inferred destination airport algorithm can obtain the closest (e.g., based on a pre-determined range such as 10 miles) airport information and prior airport information. Every time a user flies, the origin and destination airport can be recorded to keep track of the number of times a pilot landed at a facility after departing from a facility. The prior airport information can be provided as an array of tuples (airportld, probability, airportObject). The inferred destination airport algorithm can determine if the number of prior airport records is greater than 0 and if the closest airport information is not nil. If the number of prior airport records is less than zero or if the closest airport information is equal to nil, then the inferred destination airport algorithm may not be able to provide an output. If both the number of prior airport records is greater than zero and the closest airport is not nil, the inferred destination airport algorithm can determine the altitude above ground level (AGL) using ownship location information. The altitude AGL can be determined by the ownship altitude minus the closest airport altitude. If the altitude AGL is less than a threshold altitude (e.g., 1000 feet), the inferred destination airport can be the closest airport. If the altitude AGL is greater than the first altitude threshold but less than a second threshold altitude (e.g., 2000 feet), then the inferred destination airport algorithm can ignore parameters like the use of an airport as measured by yearly airport operations (e.g., set muteoperations=1) and can set the closest airport proportion to the probability calculated using the Gaussian distribution (1=1000, 6=350). If the altitude AGL is greater than the second threshold altitude but less than a third threshold altitude (e.g., 5000 feet), then the inferred destination airport algorithm can set various parameters such as the muteoperations equal to the probability calculated using the Gaussian distribution (1=2000, 6=1000) and can set the closest airport proportion to zero. If the altitude AGL is greater than or equal to the third threshold altitude, then the muteoperations and the closest airport proportion can be set to zero. Essentially, the inferred destination airport algorithm can balance the aircraft's proximity to the airport versus the number of operations at that airport. Accordingly, one of the ways to infer destination airport over another can be based on how much activity an airport actually gets. This activity can be operations information about an airport (e.g., estimated operations per year).
After the muteoperations and the closest airport proportion are set, the inferred destination airport algorithm can revise the prior airport information based on the probability modifications described above. For example, a quick calculation can be made such as prob−(1−muteoperations)+muteoperations.
For each airport prior in the airport prior collection, the inferred destination airport algorithm can calculate the algorithm disclosed in box 1201. For example, the inferred destination algorithm can obtain the bearings to an airport, the altitude AGL, and if the altitude AGL is less than a threshold altitude (e.g, 2000 ft). If it is less than a threshold altitude, the inferred destination airport algorithm can set the altitude caveat to lowAltitude. If not, the altitude caveat can remain at highAltitude. The inferred destination airport algorithm can then obtain the difference between the ground track and the bearing to the airport and the angle likelihood can be set equal to the probability calculated using the Gaussian distribution (μ=0, σ=10) if the altitude caveat is lowAltitude or the Gaussian distribution (μ=0, σ=90) if the altitude caveat is highAltitude. The inferred destination airport algorithm can then determine whether a descent to the airport altitude is possible based on (1) the current time to the airport and (2) the altitude above the airport. For example, the altitude assuming descent can be set to the altitude AGL minus the time to airport divided by a given number (i.e., 500). The inferred destination airport algorithm can then check to see if the altitude, assuming descent is, less than 0. If not, the altitude assuming descent can be set to 0. If yes (or when the altitude assuming descent is set to the makeability likelihood can be set equal to the probability calculated using the Gaussian distribution (μ=0, σ=2500). In addition, the distance likelihood can be set equal to the probability calculated using the Gaussian distribution (μ=0, σ=5). Each of the outputs in box 1201 can convey Bayes airport information. Accordingly, the Bayes airport information can include elements of airport, the prior airports, the angle likelihood, the angle prior, the makeability likelihood, makeability posterior, and the distance likelihood.
After box 1201, the inferred destination airport algorithm can initialize some variables such as angle posterior denominator (e.g., set to a specific value) and makeability posterior denominator (e.g., set to a specific value) for each of the Bayes airport information elements that came out of box 1201. The inferred destination airport algorithm can then update the makeability posterior denominator by looping through each of the Bayes airport information elements that came out of box 1201. Such a calculation can be accomplished by:
makeabilityPosteriorDenominator+=(bayesInfo[index]·opsPrior*bayesInfo[index]·angleLiklihood/anglePosteriorDenominator)*bayesInfo[index]·makeabilityLikelihood
In addition, the inferred destination airport algorithm can update the makeability posterior for each of the Bayes airport information. Such a calculation can be accomplished by looping through each of the Bayes airport information elements that came out of box 1201:
bayesInfo[index]·makeabilityPosterior=bayesInfo[index]·anglePrior*bayesInfo[index]·makeabilityLikelihood/makeabilityPosteriorDenominator
The inferred destination airport algorithm can then (for each Bayes airport information) calculate the proportioned result. If the proportioned result is better than what was previously calculated by the inferred destination airport algorithm, then the proportioned result is replaced and the inferred airport can be determined.
In some embodiments, there can be three stages, with weighted averages used to transition between each. For example, in a first stage where the aircraft altitude is at above 5000 feet from the nearest airport surface, a Bayesian probability can be calculated based on prior activity and ops, relative bearing to the airport, and makeability (distances and altitude). Between 2000 feet and 5000 feet, the algorithm can start muting the impact of prior activity and ops such that, by the time the aircraft reaches 2000 feet, the Bayesian probability may not consider activity/ops at all. Between 2000 feet and 1000 feet, the algorithm can start weighting distance to the airport as a separate factor. Weight on distance can increase the lower the aircraft is. Below 1000 feet, the algorithm may only care about which airport is closest and set the inferred destination airport to the closest airport.
The set values for the conditions in all the algorithms and tests described above can be adjustable. For example, although
In some embodiments, the digital copilot can be interacted with using a user interface.
In addition, in some embodiments, a user can interact with the digital copilot through speech recognition. For example, a user can verbally speak to the digital copilot to ask for frequencies and the digital copilot can use speech recognition to process the request and then provide the frequency information back to the user verbally through speech synthesis. In some embodiments, a user can request reminders as shown in
Computer 1500 can be a client computer or a server. As shown in
Input device 1520 can be any suitable device that provides input, such as touch screen or monitor, keyboard, mouse, microphone, or speech recognition device. Output device 1530 can be any suitable device that provides output, such as a touch screen, monitor, printer, disk drive, or speaker.
Storage 1540 can be any suitable device that provides storage, such as an electrical, magnetic, or optical memory, including a RAM, cache, hard drive, CD-ROM drive, tape drive, or removable storage disk. Communication device 1560 can include any suitable device capable of transmitting and receiving signals over a network, such as a wired or wireless network interface chip or card, Wi-Fi or Bluetooth. The components of the computer can be connected in any suitable manner, such as via a physical bus or wirelessly. Storage 1540 can be a non-transitory computer readable storage medium comprising one or more programs, which, when executed by one or more processors, such as processor 1510, cause the one or more processors to perform methods described herein, such as the phase of flight algorithm of
Software 1550, which can be stored in storage 1540 and executed by processor 1510, can include, for example, the programming that embodies the functionality of the present disclosure (e.g., as embodied in the systems, computers, servers, and/or devices as described above). In some embodiments, software 1550 can include a combination of servers such as application servers and database servers.
Software 1550 can also be stored and/or transported within any computer-readable storage medium for use by or in connection with an instruction execution system, apparatus, or device, such as those described above, that can fetch instructions associated with the software from the instruction execution system, apparatus, or device and execute the instructions. In the context of this disclosure, a computer-readable storage medium can be any medium, such as storage 1540, that can contain or store programming for use by or in connection with an instruction execution system, apparatus, or device.
Software 1550 can also be propagated within any transport medium for use by or in connection with an instruction execution system, apparatus, or device, such as those described above, that can fetch instructions associated with the software from the instruction execution system, apparatus, or device and execute the instructions. In the context of this disclosure, a transport medium can be any medium that can communicate, propagate, or transport programming for use by or in connection with an instruction execution system, apparatus, or device. The transport readable medium can include, but is not limited to, an electronic, magnetic, optical, electromagnetic, or infrared wired or wireless propagation medium.
Computer 1500 may be connected to a network, which can be any suitable type of interconnected communication system. The network can implement any suitable communications protocol and can be secured by any suitable security protocol. The network can comprise networks links of any suitable arrangement that can implement the transmission and reception of network signals, such as wireless network connections, T1 or T3 lines, cable networks, DSL, or telephone lines.
Computer 1500 can implement any operating system suitable for operating on the network. Software 1550 can be written in any suitable programming language, such as C, C++, Java, Swift, Objective-C, or Python. In various embodiments, application software embodying the functionality of the present disclosure can be deployed in different configurations, such as in a client/server arrangement or through a Web browser as a Web-based application or Web service, for example.
This application discloses several numerical ranges in the text and figures. The numerical ranges disclosed inherently support any range or value within the disclosed numerical ranges even though a precise range limitation is not stated verbatim in the specification because this disclosure can be practiced throughout the disclosed numerical ranges.
The above description is presented to enable a person skilled in the art to make and use the disclosure, and is provided in the context of a particular application and its requirements. Various modifications to the preferred embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the disclosure. Thus, this disclosure is not intended to be limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles and features disclosed herein. Finally, the entire disclosure of the patents and publications referred in this application are hereby incorporated herein by reference.
This application is a continuation of U.S. application Ser. No. 17/083,897, filed Oct. 29, 2020, which is a continuation of U.S. application Ser. No. 15/706,282, filed Sep. 15, 2017, which claims the benefit of U.S. Provisional Application No. 62/395,205, filed Sep. 15, 2016, the entire contents of each of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
62395205 | Sep 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17083897 | Oct 2020 | US |
Child | 18364191 | US | |
Parent | 15706282 | Sep 2017 | US |
Child | 17083897 | US |