The technical field generally relates to aircraft guidance systems, and more particularly relates to systems and related operating methods for predicting loss of separation events.
Specified minima for lateral and vertical separation of airborne aircraft are often referred to as loss of separation (LOS) rules. These LOS rules are usually published by regulating authorities such as the Federal Aviation Association (FAA), and they may vary in accordance with controlled airspaces, phase of flight, and other factors. A loss of separation (LOS) event occurs whenever a specified separation minimum between airborne aircraft in controlled airspace is breached. The loss of separation event may be due to a variety of reasons, and they may be ATC induced situations or pilot induced situations.
As may be appreciated, a LOS event is undesirable. Responding to a LOS event is a very cognitively demanding and time sensitive endeavor. One challenging aspect is that many traffic avoidance maneuvers are restricted to only the vertical plane. Another challenging aspect is that many traffic data systems work independently of the aircraft navigation or flight management systems. Therefore, LOS evaluation systems that monitor the traffic data systems may be unable to address proposed flight profile changes for the host aircraft.
Accordingly, improved LOS evaluation systems that process neighbor traffic data with CPDLC conditional clearances and CPDLC requests are desired. The following disclosure provides these technological enhancements, in addition to addressing related issues.
This summary is provided to describe select concepts in a simplified form that are further described in the Detailed Description. This summary is not intended to identify key or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
Provided is a method for evaluating loss of separation. The method includes: continuously receiving, from a source of host aircraft status data, a host speed, host position and location, and a host flight path angle; continuously receiving, from a traffic data system, traffic flight information for a plurality of neighbor traffic; receiving, from a controller pilot data link communication (CPDLC) source, a CPDLC message including a host flight profile change; and, responsive to receiving the CPDLC message, processing, at a control module, the CPDLC message with loss of separation rules, the host aircraft status data, and the traffic flight information, to (a) construct a modified host flight path based on incorporating the host profile change without delay, (b) identify a potential loss of separation (LOS) event between the modified host flight path and a neighbor aircraft trajectory, and (c) responsive to identifying the potential LOS event, generating annunciation commands for an annunciation system; and annunciating, by the annunciation system, the potential LOS and its location, responsive to the annunciation commands.
A system for evaluation loss of separation is provided. The system includes a source of host aircraft status data providing a host speed, host position and location, and a host flight path angle; a traffic data system providing traffic flight information for a plurality of neighbor traffic; a controller pilot data link communication (CPDLC) source providing a CPDLC message including a host flight profile change; a traffic management control module configured to: receive the host aircraft status data, the traffic flight information, and the CPDLC message; reference loss of separation rules; and construct a modified host flight path based on incorporating the host profile change without delay; identify a potential loss of separation (LOS) event between the modified host flight path and a neighbor aircraft trajectory, and (c) responsive to identifying the potential LOS event, generate annunciation commands.
Also provided is a method. The method includes, at a control module, continuously receiving, from a source of host aircraft status data, a host speed, host position and location, and a host flight path angle; continuously receiving, from a traffic data system, traffic flight information for a plurality of neighbor traffic; receiving, from a controller pilot data link communication (CPDLC) source, a CPDLC message including a host flight profile change; and, responsive to receiving the CPDLC message, (a) processing the host aircraft status data and the traffic flight information, to (i) construct a modified host flight path based on incorporating the host profile change without delay, and (ii) construct a neighbor aircraft trajectory for a neighbor aircraft; and (b) processing the modified host flight path and the neighbor aircraft trajectory with loss of separation (LOS) rules, to identify a potential loss of separation (LOS) event; and responsive to identifying the potential LOS event, annunciating, by an annunciation system, the potential LOS and its location.
Furthermore, other desirable features and characteristics of the system and method will become apparent from the subsequent detailed description and the appended claims, taken in conjunction with the accompanying drawings and the preceding background.
The present application will hereinafter be described in conjunction with the following drawing figures, wherein like numerals denote like elements, and:
The following detailed description is merely illustrative in nature and is not intended to limit the embodiments of the subject matter or the application and uses of such embodiments. As used herein, the word “exemplary” means “serving as an example, instance, or illustration.” Thus, any embodiment described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other embodiments. The embodiments described herein are exemplary embodiments provided to enable persons skilled in the art to make or use the invention and not to limit the scope of the invention that is defined by the claims. Furthermore, there is no intention to be bound by any expressed or implied theory presented in the preceding technical field, background, summary, or the following detailed description.
Exemplary embodiments of the novel disclosed system for evaluation of loss of separation (
Turning now to
The control module 104 performs the functions of the system 102. In order to perform these functions, the control module 104 may be operatively coupled to any combination of the following aircraft systems: a transceiver 106, a source of aircraft status data, such as a flight management system (FMS) 108, a user input device 110, and one or more annunciation systems, such as display system 112 and/or audio system 116. The functions of these aircraft systems, and their interaction, are described in more detail below.
The FMS 108 is configured to provide real-time navigational data and/or information regarding operation of the aircraft 100, including real-time flight guidance for aircraft 100. As used herein, “real-time” is interchangeable with current and instantaneous. In operation, the FMS 108 may further be integrated with, or receive and process, real-time data and information from a navigation system 20 and a navigation database 22. As used herein, the FMS 108 supports bidirectional pilot-to-ATC (air traffic control) communications via a datalink, generally referred to as controller pilot data link communications (CPDLC), such as through a reporting system (ACARS) router; this feature may be referred to as a communications management unit (CMU) or communications management function (CMF). An instance of pilot-to-ATC communications is often referred to as a controller pilot datalink communications (CPDLC) message, and the CPDLC messages of relevance herein contain a flight profile change (lateral and/or vertical) for the host aircraft; further, a CPDLC message is referred to as a request when it is sourced by a pilot, and as a conditional clearance when it is sourced from ATC.
The navigation system 20 may be realized as including a global positioning system (GPS), inertial reference system (IRS), or a radio-based navigation system (e.g., VHF omni-directional radio range (VOR) or long-range aid to navigation (LORAN)), and may include one or more navigational radios or other sensors suitably configured to support operation of the FMS 108, as will be appreciated in the art. The navigation database 22 may be a storage location that may maintain a database of flight plans, as well as information regarding terrain and airports and/or other potential landing locations (or destinations) for the aircraft 100. In this regard, the navigation database 22 can maintain an association between a respective airport, its geographic location, runways (and their respective orientations and/or directions), instrument procedures (e.g., approaches, arrival routes, and the like), airspace restrictions, and/or other information or attributes associated with the respective airport (e.g., widths and/or weight limits of taxi paths, the type of surface of the runways or taxi path, and the like).
Accordingly, the FMS 108 is a source for real-time aircraft status of the aircraft 100, the aircraft status data (also referred to herein as navigation data) including any of: (i) the instantaneous position and location, vertical speed, and ground speed of the aircraft 100 (e.g., the latitude, longitude, orientation, and flight path angle), (ii) the instantaneous altitude (or height above ground level) for the aircraft 100, (iii) the instantaneous heading of the aircraft 100 (i.e., the direction the aircraft is traveling in relative to some reference), and (iv) a current phase of flight. Additionally, the FMS 108 is configured to compare the instantaneous position and heading of the aircraft 100 with an intended flight plan for the aircraft 100. Host aircraft status data is made available such that the display system 112, the transceiver 106, and the control module 104, may further process and/or handle the aircraft status data.
The display system 112 includes a display device 114. The display system 112 is configured to continuously receive real-time flight status and flight plan information from the FMS 108. The control module 104 and the display system 112 are cooperatively configured to generate the commands (“display commands”) for the display device 114 to render thereon the various graphical user interface elements, such as the tables, menus, and buttons, as described herein. In exemplary embodiments, the display device 114 is realized on one or more electronic display devices configured as a combination of a vertical situation display (VSD) and a lateral navigation display (ND). The VSD renders a graphical representation of the aircraft 100 and one or more of the airspace, air traffic, navigational reference points, and a vertical flight plan associated with a flight plan of the aircraft 100. The ND renders a top down graphical representation of the aircraft 100 and one or more of the terrain, meteorological conditions, airspace, air traffic, navigational reference points, and a route associated with a lateral flight plan of the aircraft 100. Each of the VSD and ND are responsive to display commands from the control module 104 and/or display sy stem 112.
Renderings on the display system 112 may be processed by a graphics system, components of which may be integrated into the display system 112 and/or be integrated within the control module 104. Display methods include various types of computer generated symbols, text, and graphic information representing, for example, pitch, heading, flight path, airspeed, altitude, runway information, waypoints, targets, obstacles, terrain, and required navigation performance (RNP) data in an integrated, multi-color or monochrome form. Display methods also include various techniques for visually distinguishing objects. The control module 104 is said to display various images and selectable options described herein. In practice, this may mean that the control module 104 generates display commands, and responsive to receiving the display commands from the control module 104, the display system 112 displays, renders, or otherwise visually conveys on the display device 114, graphical representations or images associated with operation of the aircraft 100, and specifically, one or more pictorial images as described herein.
The user input device 110 and the control module 104 are cooperatively configured to allow a user (e.g., a pilot, co-pilot, or crew member) to interact with the display devices 114 in the display system 112 and/or other elements of the system 102, as described in greater detail below. Depending on the embodiment, the user input device 110 may be realized as a keypad, touchpad, keyboard, mouse, touch panel (or touchscreen), joystick, knob, line select key or another suitable device adapted to receive input from a user. When the user input device 110 is configured as a touchpad or touchscreen, it may be integrated with the display system 112. As used herein, the user input device 110 may be used to provide a pilot requested flight profile change in the form of a CPDLC request.
In various embodiments, any combination of the FMS 108, user input device 110, and transceiver 106, may be coupled to the display system 112 such that the display system 112 may generate or render, on a display device, real-time information associated with respective aircraft 100 components. Coupled in this manner, the FMS 108 and transceiver 106 are configured to support navigation, flight planning, and other aircraft control functions in a conventional manner, as well as to provide real-time data and/or information regarding the operational status of the aircraft 100 to the control module 104. Additionally, in some embodiments, the user input device 110, FMS 108, and display system 112 are configured as a control display unit (CDU).
External sources communicate with the aircraft 100, generally by way of transceiver 106. External sources include traffic data system(s) 120, air traffic control (ATC) 122, and a variety of other radio inputs 124. The traffic data system(s) 120 include numerous systems for providing real-time neighbor traffic data and information. For example, traffic data systems 120 may include any combination of: traffic collision avoidance system (TCAS), automatic dependent surveillance broadcast (ADS-B), traffic information system (TIS), crowd sourced traffic data and/or another suitable avionics system. Flight traffic information that is received from the traffic data system may include, for each neighbor aircraft of a plurality of neighbor aircraft, one or more of a respective (i) instantaneous position and location, vertical speed, and ground speed, (ii) instantaneous altitude, and (iii) instantaneous heading of the aircraft.
The transceiver 106 is configured to support instantaneous (i.e., real time or current) communications between the aircraft 100 and the one or more external data source(s). As a functional block, the transceiver 106 represents one or more transmitters, receivers, and the supporting communications hardware and software required for the system 102 to communicate with the various external data source(s) as described herein. In an example, the transceiver 106 is configured to include or support an automatic dependent surveillance broadcast system (ADS-B), a communication management function (CMF) uplink, a terminal wireless local area network (LAN) unit (TWLU), or any other suitable radio communication system that supports communications between the aircraft 100 and the various external source(s). In this regard, the transceiver 106 may allow the aircraft 100 to receive information that would otherwise be unavailable to the pilot and/or co-pilot using only the onboard systems.
In various embodiments, the control module 104 is additionally operationally coupled to an automatic pilot system (AP) 26 and a database 24. The AP 26 may coordinate aircraft systems, such as an engine thrust system and the navigation system 20, to control aircraft 100 flight along an intended flight path. The database 24 may be utilized to maintain the aforementioned loss of separation rules (LOS rules) for reference during operation of the system 102. Additionally, in some embodiments, the database 24 may include airport status data for the runways and/or taxi paths at the airport indicating operational status and directional information for the taxi paths (or portions thereof).
When used for alerting, the display system 112 may be considered an annunciation system. The control module 104 and the display system 112 are cooperatively configured to cause the display device 114 to render thereon visual alerts regarding potential LOS events. In an example, a pictorial image is rendered that visually distinguishes: the host aircraft; the modified host flight path; the associated neighbor aircraft; a trajectory of a neighbor aircraft; and the location of the potential LOS. Display commands from the control module 104 that specifically direct the herein described tabular and pictorial displays are called annunciation commands. The audio system 116 may also be used for annunciation. It may be appreciated that the audio system 116 generally includes one or more audio devices for emitting sound and/or speech. In various embodiments, in response to receiving annunciation commands, the audio system 116 may emit sounds or speech suitable to alert a pilot or crew of a potential LOS. Audio commands from the control module 104 that specifically direct the herein described sounds and speech for LOS alerts are also annunciation commands.
As mentioned, the control module 104 performs the functions of the system 102. As used herein, the term “module” refers to any means for facilitating communications and/or interaction between the elements of the system 102 and performing additional processes, tasks and/or functions to support operation of the system 102, as described herein. In various embodiments, the control module 104 may be any hardware, software, firmware, electronic control component, processing logic, and/or processor device, individually or in any combination. Depending on the embodiment, the control module 104 may be implemented or realized with a general purpose processor (shared, dedicated, or group) controller, microprocessor, or microcontroller, and memory that executes one or more software or firmware programs; a content addressable memory; a digital signal processor; an application specific integrated circuit (ASIC), a field programmable gate array (FPGA); any suitable programmable logic device; combinational logic circuit including discrete gates or transistor logic; discrete hardware components and memory devices; and/or any combination thereof, designed to perform the functions described herein.
As depicted in
A novel program 162 is embodied in the memory 152 (e.g., RAM memory, ROM memory, flash memory, registers, a hard disk, or the like) or another suitable non-transitory short or long-term storage media capable of storing computer-executable programming instructions or other data for execution. The program 162 includes rules and instructions which, when executed, cause the system 102 to perform the functions, techniques, and processing tasks associated with the operation of the system 102 described herein.
Based in part on being programmed with program 162, the processor 150 and the memory 152 form a novel LOS evaluation processing engine that performs the processing activities of the system 102. During operation, the processor 150 loads and executes one or more programs, algorithms and rules embodied as instructions and applications 160 contained within the memory 152 and, as such, controls the general operation of the control module 104 as well as the system 102. In executing the process described herein, the processor 150 specifically loads and executes the instructions embodied in the program 162. Additionally, the processor 150 is configured to, in accordance with the program 162: receive a CPDLC message, and process the CPDLC message with loss of separation rules, received host aircraft status data, and received traffic flight information, to (a) construct a modified host flight path based on incorporating the host profile change without delay, (b) identify a potential loss of separation (LOS) event between the modified host flight path and a neighbor aircraft trajectory, and (c) responsive to identifying the potential LOS event, generate annunciation commands for an annunciation system.
In various embodiments, the processor/memory unit of the control module 104 may be communicatively coupled (via a bus 155) to an input/output (I/O) interface 154, and a database 156. The bus 155 serves to transmit programs, data, status and other information or signals between the various components of the control module 104. The bus 155 can be any suitable physical or logical means of connecting computer systems and components. This includes, but is not limited to, direct hard-wired connections, fiber optics, infrared and wireless bus technologies.
The I/O interface 154 enables intra control module 104 communication, as well as communications between the control module 104 and other system 102 components, and between the control module 104 and the external data sources via the transceiver 106. The I/O interface 154 may include one or more network interfaces and can be implemented using any suitable method and apparatus. In various embodiments, the I/O interface 154 is configured to support communication from an external system driver and/or another computer system. Also, in various embodiments, the I/O interface 154 may support communication with technicians, and/or one or more storage interfaces for direct connection to storage apparatuses, such as the database 156. In one embodiment, the I/O interface 154 is integrated with the transceiver 106, and obtains data from external data source(s) directly.
The database 156 may include an aircraft-specific parameters database (comprising aircraft-specific parameters for aircraft 100, as well as for a variety of other aircrafts) and parameters and instructions for processing user inputs and rendering images on the display device 114, as described herein. In some embodiments, the database 156 is part of the memory 152. In various embodiments, the database 156 and the database 24 are integrated, either within the control module 104 or external to it. Accordingly, in some embodiments, the LOS rules are pre-loaded and internal to the control module 104.
The images displayed on the display device 114 are understood to be based on current host aircraft status data for the aircraft 100 and to be dynamically updated based on continuously obtaining the current aircraft status data. As used herein, a “viewing segment” is at least a portion of a current path that the aircraft 100 is traveling on; in various embodiments, the display device 114 depicts the same viewing segment on each of the VSD and ND. The images on display device 114 may also be continuously updated to reflect neighbor traffic within the bounds of the viewing segment.
Turning now to
As mentioned, a technological effect of the present disclosure is the earlier warnings of potential LOS, particularly as related to profile changes embedded in a CPDLC command. This expands the amount of decision time for a pilot to react to a potential LOS, which then expands the options for response to the potential LOS. Accordingly, timelines 214 and 222 show exemplary sequences of events using the novel system for evaluating loss of separation.
Regarding the timeline 214: The host aircraft 100 is flying on an intended flight path in accordance with a flight plan. At 204, (time T for reference) a CPDLC message with a flight profile change for the host aircraft is received from ATC, and at 216 traffic flight information for a plurality of neighbor traffic is received. At 218, the system 102 evaluates potential loss of separation, in accordance with a method, such as method 500 of
Constructing a modified host flight path implies that the CPDLC message is parsed to isolate the flight profile change, which is with respect to a current flight path 302 that the host aircraft 100 is flying. The control module 104 then identifies a potential loss of separation (LOS) event between the modified host flight path and a neighbor aircraft trajectory. Identifying a potential LOS event implies that the control module 104 has first constructed, for a neighbor aircraft, a trajectory of the neighbor aircraft (called neighbor aircraft trajectory herein), using the received traffic flight information. Responsive to identifying the potential LOS event, the control module 104 promptly generates annunciation commands for the annunciation system. The pilot may then view and/or hear the annunciation and respond accordingly. At 220 the pilot, having advance notice of the potential LOS associated with the profile change in the CPDLC, may reject the CPDLC message with a reason, such as the predicted LOS provided by the system 102.
Regarding the timeline 222: The host aircraft 100 is flying on a current flight path 302 in accordance with a flight plan. At 204, (time T for reference) a CPDLC message with a flight profile change for the host aircraft is received from ATC, and at 216 traffic flight information for a plurality of neighbor traffic is received. At 224, the CPDLC message is either accepted, open, standby state. Accordingly, if the CPDLC is ultimately acted on, it will result in constructing a modified host flight path based on incorporating the host profile change with a delay (delay time t, for reference). At 218, the system 102 evaluates potential loss of separation, in accordance with a method, such as method 500 of
Image 300 (
As alluded to above, in some scenarios, a neighbor aircraft trajectory intersects the modified host flight path, therefore, the LOS events have an included point of intersection (POI). The control module 104 then determines, for a POI, a POI type from the set including: none, a point of convergence (POC) and a point of divergence (POD), and associates an angle with the POC or POD, as well as any attendant vertical or lateral distance. Turning now to
As in the previous images, initially, host aircraft 100 is flying current flight path 302. The control module 104 is continuously receiving the traffic flight information, and continuously receiving host aircraft status data. At time T, a CPDLC message with a profile change (to altitude 306) is received. A modified host flight path 403 to altitude 306 and path 308 thereafter is constructed, based on incorporating the host profile change without delay (i.e., substantially at time T). Based on the climb initiated at time T 402, the control module 104 identifies:
The control module 104 also constructs a second modified host flight path 451 to altitude 306 and path 308, based on incorporating the host profile change with a delay of time t 450 (i.e., substantially at time T+t). Based on the second modified host flight path 451 at time T+t, the control module 104 identifies:
As before, the control module 104 generates annunciation commands for the annunciation system, and components of the annunciation system respond to the annunciation commands by annunciating each potential LOS and its location. In an embodiment, the annunciation system is the display system 112, and the subsequent annunciation takes the form of a displayed table, such as TABLE 2, below. In TABLE 2, each entry includes neighbor aircraft information for the LOS event, accordingly, as it applies to the neighbor aircraft: POI type, a vertical distance, a lateral distance, and an angle. In some embodiments, the received traffic flight information includes an aircraft ID, and the aircraft ID for each relevant neighbor aircraft is also annunciated, by being displayed in the table and/or on a pictorial image displayed on the display device 114, and/or aurally via the audio system 116. Techniques may be used to visually distinguish the table entries that most need attention from determinations made about neighboring aircraft that are a lesser threat, or those that do not impose a LOS threat at all. In TABLE 2, a color may be used to indicate that flight BA 150 is a moderate level lateral LOS event at 1 nautical mile (NM), and a separate color may be used to indicate that the following are critical level LOS events: flight AA 205 is a lateral LOS and a vertical LOS event at 0.5 NM and 100 feet, respectively, and flight SA 1344 is a vertical LOS at 50 feet.
In some embodiments, the LOS events are rendered on the display as a pictorial image. Techniques such as changing colors and line thickness may be used to distinguish a path from another path such that the resulting pictorial image visually distinguishes: the host aircraft; the modified host flight path; the neighbor aircraft; the associated neighbor aircraft trajectory; and the location of the potential LOS. In some embodiments, both the pictorial images and the tables are used to annunciate the LOS. In some embodiments, the audio system is also used to emit speech and sounds sufficient to alert a pilot of at least: the potential LOS and the location of the potential LOS.
As mentioned, the processor 150 and the program 162 form a LOS evaluation engine that continually, and in real time, processes various data received and, responsive to a CPDLC message, identifies and annunciates potential LOS events, in accordance with a set of rules encoded in the program 162. Referring now to
The method starts, and at 502 the control module 104 is initialized. As mentioned above, initialization may comprise uploading or updating instructions and applications 160, program 162, stored variables 164, and the various lookup tables stored in the database 156. Predetermined variables may include, for example, predetermined distances and times to use as thresholds, parameters for setting up a user interface, and the various shapes, various colors and/or visually distinguishing techniques used for tables, icons, and alerts. In some embodiments, program 162 includes additional instructions and rules for rendering information differently based on type of display device in display system 112. Initialization at 502 may also include identifying external sources and/or external signals and the communication protocols to use with each of them.
At 504 aircraft status data is received from a source of aircraft status data, such as a FMS 108; this is continuous during operation. At 504, the display system 112 may also be continuously rendering and updating the viewing segment surrounding the host aircraft. At 506, traffic flight information is received for one or more neighbor aircraft throughout flight operation. A threshold of distance or time may be used to determine which of the neighbor traffic are relevant to render on the viewing segment. The traffic flight information is continuously received during operation. At 508, a CPDLC message having a flight profile change is received. The CPDLC message may be sent from ATC, via datalink, and may therefore be a CPDLC conditional clearance. The CPDLC message may also be a request for a profile change that a pilot has entered. At 510, if a delay is not utilized, a modified host flight path 403 based on incorporating the host profile change without a delay (i.e., at time T (
At 514, one or more neighbor aircraft trajectories are constructed for neighbor traffic in the vicinity of the modified host flight path. At 516, the LOS evaluation engine in the system 102 identifies one or more potential LOS events using the modified host flight path and the neighbor aircraft trajectories. When a LOS is identified, it is further determined whether it is a lateral LOS or a vertical LOS, and the associated distance and angle is determined. Also, for each identified LOS, it is determined, based on the LOS rules, whether it is a moderate or critical LOS. Additionally, when a LOS is identified, it is also evaluated for whether there is a point of intersection, and if so, a point of intersection (POI) type. The POI is then labeled from among the set including: none, a point of convergence (POC), and a point of divergence (POD). For each POI, the system 102 determines an associated angle.
At 518, responsive to identifying the potential LOS event, the system 102 generates annunciation commands for an annunciation system. And, at 520, the system 102 annunciates the potential LOS and its location, responsive to the annunciation commands. At 520, the potential LOS may be further annunciated as described above, i.e., in tabular format on a display device 114, as a pictorial image on the display device 114, and/or as audible sounds and speech via the audio system 116. After 520, the method may repeat or end.
As is readily appreciated, the above examples of the system for evaluation of loss of separation 102 are non-limiting, and many others may be addressed by the control module 104. Thus, systems and methods directed to providing advance notice of a potential LOS event responsive to a CPDLC command are provided.
Those of skill in the art will appreciate that the various illustrative logical blocks, modules, circuits, and algorithm steps described in connection with the embodiments disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. Some of the embodiments and implementations are described above in terms of functional and/or logical block components (or modules) and various processing steps. However, it should be appreciated that such block components (or modules) may be realized by any number of hardware, software, and/or firmware components configured to perform the specified functions. To clearly illustrate the interchangeability of hardware and software, various illustrative components, blocks, modules, circuits, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present invention. For example, an embodiment of a system or a component may employ various integrated circuit components, e.g., memory elements, digital signal processing elements, logic elements, look-up tables, or the like, which may carry out a variety of functions under the control of one or more microprocessors or other control devices. In addition, those skilled in the art will appreciate that embodiments described herein are merely exemplary implementations.
Further, the various illustrative logical blocks, modules, and circuits described in connection with the embodiments disclosed herein may be implemented or performed with a general-purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general-purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
The steps of the method or algorithm described in connection with the embodiments disclosed herein may be embodied directly in hardware, in a software module executed by a controller or processor, or in a combination of the two. A software module may reside in RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, a removable disk, a CD-ROM, or any other form of storage medium known in the art. An exemplary storage medium is coupled to the processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. The processor and the storage medium may reside in an ASIC.
In this document, relational terms such as first and second, and the like may be used solely to distinguish one entity or action from another entity or action without necessarily requiring or implying any actual such relationship or order between such entities or actions. Numerical ordinals such as “first,” “second,” “third,” etc. simply denote different singles of a plurality and do not imply any order or sequence unless specifically defined by the claim language. The sequence of the text in any of the claims does not imply that process steps must be performed in a temporal or logical order according to such sequence unless it is specifically defined by the language of the claim. When “or” is used herein, it is the logical or mathematical or, also called the “inclusive or.” Accordingly, A or B is true for the three cases: A is true, B is true, and, A and B are true. In some cases, the exclusive “or” is constructed with “and;” for example, “one from the set including A and B” is true for the two cases: A is true, and B is true.
Furthermore, depending on the context, words such as “connect” or “coupled to” used in describing a relationship between different elements do not imply that a direct physical connection must be made between these elements. For example, two elements may be connected to each other physically, electronically, logically, or in any other manner, through one or more additional elements.
While at least one exemplary embodiment has been presented in the foregoing detailed description of the invention, it should be appreciated that a vast number of variations exist. It should also be appreciated that the exemplary embodiment or exemplary embodiments are only examples, and are not intended to limit the scope, applicability, or configuration of the invention in any way. Rather, the foregoing detailed description will provide those skilled in the art with a convenient road map for implementing an exemplary embodiment of the invention. It being understood that various changes may be made in the function and arrangement of elements described in an exemplary embodiment without departing from the scope of the invention as set forth in the appended claims.
It will also be appreciated that while the depicted exemplary embodiment is described in the context of a fully functioning computer system, those skilled in the art will recognize that the mechanisms of the present disclosure are capable of being distributed as a program product with one or more types of non-transitory computer-readable signal bearing media used to store the program and the instructions thereof and carry out the distribution thereof, such as a non-transitory computer readable medium bearing the program 162 and containing computer instructions stored therein for causing a computer processor (such as the processor 150) to perform and execute the program 162. Such a program product may take a variety of forms, and the present disclosure applies equally regardless of the particular type of computer-readable signal bearing media used to carry out the distribution. Examples of signal bearing media include: recordable media such as floppy disks, hard drives, memory cards and optical disks, and transmission media such as digital and analog communication links. It will be appreciated that cloud-based storage and/or other techniques may also be utilized in certain embodiments.