Avionics display systems often do not have ample data storage space available to store avionics chart data. Further, the time required to display chart images during run-time is often extensive.
A system is disclosed, in accordance with one or more embodiments of the present disclosure. The system includes one or more offboard aircraft controllers including one or more processors configured to execute a set of program instructions stored in a memory. The set of program instructions configured to cause the one or more processors to receive chart data from one or more chart providers. The set of program instructions configured to cause the one or more processors to convert the received chart data into one or more sets of one or more hardware directives and one or more subroutines, the one or more sets of one or more hardware directives including at least a first set of one or more hardware directives and a second set of one or more hardware directives, the first set of one or more hardware directives including one or more relative offsets needing address modification, the second set of one or more hardware directives not needing address modification. The set of program instructions configured to cause the one or more processors to generate a display list including the set of one or more hardware directives and one or more rules, the one or more relative offsets needing address modification arranged at a beginning position of the generated display list. The set of program instructions configured to cause the one or more processors to provide the generated display list to one or more on-board aircraft controllers configured to update one or more absolute addresses of the one or more relative offsets of the first set of one or more hardware directives during run-time.
In some embodiments, the system may further include the one or more on-board aircraft controllers, the one or more on-board aircraft controllers including one or more processors configured to execute a set of program instructions stored in a memory, the set of program instructions configured to cause the one or more processors to: update the one or more absolute addresses of the one or more relative offsets of the first set of one or more hardware directives during run-time; perform at least one hardware directive of the set of one or more hardware directives; execute the one or more subroutines; and execute the one or more rules.
In some embodiments, the one or more subroutines may include at least one subroutine configured to draw a symbol.
In some embodiments, the one or more subroutines may include at least one subroutine configured to draw one or more alphanumeric characters.
In some embodiments, the second set of one or more hardware directives may include a chart image to be rendered based on the received chart data from the one or more chart providers.
In some embodiments, the second set of one or more hardware directives may include one or more calls to the one or more subroutines.
In some embodiments, the one or more rules may include at least one no operation command rule.
In some embodiments, the one or more rules may include at least one set base point opcode rule configured to cause the one or more on-board aircraft controllers to set a base address for the one or more relative offsets during run-time.
In some embodiments, the one or more rules may include at least one branching rule configured to cause the one or more on-board aircraft controllers to execute the display list in a predetermined order.
A method is disclosed, in accordance with one or more embodiments of the present disclosure. The method includes receiving chart data from one or more chart providers. The method includes converting the received chart data into one or more sets of one or more hardware directives and one or more subroutines, the one or more sets of one or more hardware directives including at least a first set of one or more hardware directives and a second set of one or more hardware directives, the first set of one or more hardware directives including one or more relative offsets needing address modification, the second set of one or more hardware directives not needing address modification. The method includes generating a display list including the set of one or more hardware directives and one or more rules, the one or more relative offsets needing address modification arranged at a beginning position in the generated display list. The method includes providing the generated display list to one or more on-board aircraft controllers. The method includes updating, via the one or more on-board aircraft controllers, the one or more absolute addresses of the one or more relative offsets of the first set of one or more hardware directives during run-time.
In some embodiments, the second set of one or more hardware directives may include a chart image to be rendered based on the received chart data from the one or more chart providers.
In some embodiments, the second set of one or more hardware directives may include one or more calls to the one or more subroutines.
In some embodiments, the one or more rules may include at least one no operation command rule.
In some embodiments, the one or more rules may include at least one set base point opcode rule configured to cause the one or more on-board aircraft controllers to set a base address for the one or more relative offsets during run-time.
In some embodiments, the one or more rules may include at least one branching rule configured to cause the one or more on-board aircraft controllers to execute the display list in a predetermined order.
This Summary is provided solely as an introduction to subject matter that is fully described in the Detailed Description and Drawings. The Summary should not be considered to describe essential features nor be used to determine the scope of the Claims. Moreover, it is to be understood that both the foregoing Summary and the following Detailed Description are examples and explanatory only and are not necessarily restrictive of the subject matter claimed.
The detailed description is described with reference to the accompanying figures. The use of the same reference numbers in different instances in the description and the figures may indicate similar or identical items. Various embodiments or examples (“examples”) of the present disclosure are disclosed in the following detailed description and the accompanying drawings. The drawings are not necessarily to scale. In general, operations of disclosed processes may be performed in an arbitrary order, unless otherwise provided in the claims. In the drawings:
Reference will now be made in detail to the subject matter disclosed, which is illustrated in the accompanying drawings.
Before explaining one or more embodiments of the present disclosure in detail, it is to be understood the embodiments are not limited in their application to the details of construction and the arrangement of the components or steps or methodologies set forth in the following description or illustrated in the drawings. In the following detailed description of embodiments, numerous specific details may be set forth in order to provide a more thorough understanding of the present disclosure. However, it will be apparent to one of ordinary skill in the art having the benefit of the instant disclosure the embodiments disclosed herein may be practiced without some of these specific details. In other instances, well-known features may not be described in detail to avoid unnecessarily complicating the instant disclosure.
As used herein a letter following a reference numeral is intended to reference an embodiment of the feature or element that may be similar, but not necessarily identical, to a previously described element or feature bearing the same reference numeral (e.g., 1, 1a, 1b). Such shorthand notations are used for purposes of convenience only and should not be construed to limit the disclosure in any way unless expressly stated to the contrary.
Further, unless expressly stated to the contrary, “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).
In addition, use of “a” or “an” may be employed to describe elements and components of embodiments disclosed herein. This is done merely for convenience and “a” and “an” are intended to include “one” or “at least one,” and the singular also includes the plural unless it is obvious that it is meant otherwise.
Finally, as used herein any reference to “one embodiment” or “some embodiments” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment disclosed herein. The appearances of the phrase “in some embodiments” in various places in the specification are not necessarily all referring to the same embodiment, and embodiments may include one or more of the features expressly described or inherently present herein, or any combination of or sub-combination of two or more such features, along with any other features which may not necessarily be expressly described or inherently present in the instant disclosure.
Avionics display systems often do not have ample data storage space available to store avionics chart data for each aeronautical chart. For example, avionics display systems may only have 4 Gb of available data storage space for chart data, however, the uncompressed chart data may approach approximately 40 Gb. Further, the time required to display chart images during run-time is often extensive. For example, hardware directives often rely on knowledge of a base address, which is not known when the tools run and may be different based on the hardware of the display system. However, parsing the entire set of display directives in order to replace all the directives that require a base address is time consuming and not feasible in most applications.
As such, it would be desirable to provide a system and method for machine code subroutine creation and execution with indeterminate addresses. The system and method should minimize the amount of time required to access chart data during run-time and lower the space required to store the display images. The system and method should allow the implementation of hardware level drawing directives without knowledge of the hardware base address. For example, the system and method may be configured to convert hardware display directives off-line and create sorted keys (e.g., subroutines) to speed up data access during run-time. The system and method should minimize the time required to update the hardware directives with the current base address.
Referring now to
The aircraft 100 may include an avionics environment such as, but not limited to, a cockpit. The aircraft controller 102 may be coupled (e.g., physically, electrically, and/or communicatively) to one or more display devices 112. The one or more display devices 112 may be configured to display two-dimensional images and/or three-dimensional images. For example, the one or more display devices 112 may be configured to display one or more avionics charts (or aeronautical charts). Referring now to
Referring again to
The one or more display devices 112 and the one or more user input devices 114 may be standalone components within the aircraft 100. It is noted herein, however, that the one or more display devices 112 and the one or more user input devices 114 may be integrated within one or more common user interfaces 116.
Where the one or more display devices 112 and the one or more user input devices 114 are housed within the one or more common user interfaces 116, the aircraft controller 102, one or more offboard controllers 124, and/or the one or more common user interfaces 116 may be standalone components. It is noted herein, however, that the aircraft controller 102, the one or more offboard controllers 124, and/or the one or more common user interfaces 116 may be integrated within one or more common housings or chassis.
The aircraft controller 102 may be coupled (e.g., physically, electrically, and/or communicatively) to and configured to receive data from one or more aircraft sensors 118. The one or more aircraft sensors 118 may be configured to sense a particular condition(s) external or internal to the aircraft 100 and/or within the aircraft 100. The one or more aircraft sensors 118 may be configured to output data associated with particular sensed condition(s) to one or more components/systems onboard the aircraft 100. Generally, the one or more aircraft sensors 118 may include, but are not limited to, one or more inertial measurement units, one or more airspeed sensors, one or more radio altimeters, one or more flight dynamic sensors (e.g., sensors configured to sense pitch, bank, roll, heading, and/or yaw), one or more weather radars, one or more air temperature sensors, one or more surveillance sensors, one or more air pressure sensors, one or more engine sensors, and/or one or more optical sensors (e.g., one or more cameras configured to acquire images in an electromagnetic spectrum range including, but not limited to, the visible light spectrum range, the infrared spectrum range, the ultraviolet spectrum range, or any other spectrum range known in the art).
The aircraft controller 102 may be coupled (e.g., physically, electrically, and/or communicatively) to and configured to receive data from one or more navigational systems 120. The one or more navigational systems 120 may be coupled (e.g., physically, electrically, and/or communicatively) to and in communication with one or more GPS satellites 122, which may provide vehicular location data (e.g., aircraft location data) to one or more components/systems of the aircraft 100. For example, the one or more navigational systems 120 may be implemented as a global navigation satellite system (GNSS) device, and the one or more GPS satellites 122 may be implemented as GNSS satellites. The one or more navigational systems 120 may include a GPS receiver and a processor. For example, the one or more navigational systems 120 may receive or calculate location data from a sufficient number (e.g., at least four) of GPS satellites 122 in view of the aircraft 100 such that a GPS solution may be calculated.
It is noted herein the one or more aircraft sensors 118 may operate as a navigation device 120, being configured to sense any of various flight conditions or aircraft conditions typically used by aircraft and output navigation data (e.g., aircraft location data, aircraft orientation data, aircraft direction data, aircraft speed data, and/or aircraft acceleration data). For example, the various flight conditions or aircraft conditions may include altitude, aircraft location (e.g., relative to the earth), aircraft orientation (e.g., relative to the earth), aircraft speed, aircraft acceleration, aircraft trajectory, aircraft pitch, aircraft bank, aircraft roll, aircraft yaw, aircraft heading, air temperature, and/or air pressure. By way of another example, the one or more aircraft sensors 118 may provide aircraft location data and aircraft orientation data, respectively, to the one or more processors 104, 126.
The aircraft controller 102 of the aircraft 100 may be coupled (e.g., physically, electrically, and/or communicatively) to one or more offboard controllers 124.
The one or more offboard controllers 124 may include one or more processors 126, memory 128 configured to store one or more programs instructions 130, and/or one or more communication interfaces 136.
The offboard controller 124 may be configured to receive chart data from one or more chart providers. For example, the offboard controller 124 may be configured to receive chart data from one or more third party chart providers.
It is noted that the offboard controller 124 may be configured to receive any type of avionics chart data from any chart provider. For example, the offboard controller 124 may be configured to receive chart data for one or more terminal avionics charts. By way of another example, the offboard controller 124 may be configured to receive chart data for one or more enroute avionics charts. By way of another example, the offboard controller 124 may be configured to receive one or more hybrid avionics charts (e.g., VFR landmarks, terrain data, obstacle data, or the like).
The offboard controller 124 may be configured to convert the received chart data into one or more sets of one or more hardware directives 132 and one or more sorted keys 134. For example, the one or more program instructions 130 of the offboard controller 124 may be configured to cause the one or more processors 126 to convert the received chart data into one or more sets of one or more hardware directives 132 and store the converted hardware directives in memory 128. By way of another example, the one or more program instructions 130 of the offboard controller 124 may be configured to cause the one or more processors 126 to convert the received chart data into one or more sorted keys 134 (e.g., subroutines 220) and store the sorted keys 134 (e.g., subroutines 220) in memory 128. In this regard, the converted hardware directives and the sorted keys (e.g., subroutines 220) may be configured to speed up data access during run-time.
The one or more sets of hardware directives may include at least a first set of one or more hardware directives (e.g., offsets 210) needing address modification. For example, the first set of one or more hardware directives (e.g., offsets 210) may include one or more relative offsets 210, where the one or more relative offsets 210 may be generated remotely without knowledge of one or more base addresses. As previously discussed herein, it is noted that the base address is not known offline (e.g., prior to run-time) and often varies depending on the hardware of the display system.
The one or more sets of hardware directives may include at least an additional set of one or more hardware directives not needing address modification (e.g., hardware directives 214).
The one or more generated hardware directives may include any type of hardware directive suitable for displaying avionics chart images on display hardware (e.g., display devices 112) including, but not limited to, move, draw, set color, call subroutine, rotate, translate, scale, return, and the like.
The one or more sorted keys (e.g., subroutines) may include any type of sorted key (e.g., subroutine) suitable for avionics charts. For example, the one or more sorted keys (e.g., subroutines) may include a subroutine configured to draw a symbol (e.g., an arrowhead). In this regard, during run-time, the aircraft controller 102 may execute (e.g., “call”) the subroutine each time a symbol (e.g., an arrowhead) is encountered, rather than creating the symbol (e.g., the arrowhead) multiples times. By way of another example, the one or more sorted keys (e.g., subroutines) may include a subroutine configured to draw an alphanumeric character. In this regard, during run-time, the aircraft controller 102 may execute (e.g., “call”) the subroutine each time an alphanumeric is encountered, rather than drawing multiple lines each time an alphanumeric is encountered. For instance, the subroutine may be configured to draw an “A” and during run-time, the aircraft controller 102 may execute (e.g., “call”) the subroutine each time an “A” is encountered, rather than drawing multiple lines each time an “A” is encountered. By way of another example, the one or more sorted keys (e.g., subroutines) may include a graphics control directive subroutine. In this regard, during run-time, the aircraft controller 102 may execute (e.g., “call”) the subroutine each time a graphics control directive (e.g., dash pattern, color, or the like) is encountered, rather than executing the graphics control directive each time the directive is encountered. For instance, the subroutine may be configured to draw an “dash pattern” and during run-time, the aircraft controller 102 may execute (e.g., “call”) the subroutine each time an “dash pattern” is encountered, rather than drawing multiple lines each time an “dash pattern” is encountered. By way of another example, the one or more sorted keys (e.g., subroutines) may include a subroutine configured to draw a repeating pattern (e.g., special use airspaces (SUAs), air route traffic control center (ARTCC) regions, air defense identification zones (IADIZs), or the like). In this regard, during run-time, the aircraft controller 102 may execute (e.g., “call”) the subroutine each time the repeating pattern is encountered, rather than drawing the repeating pattern each time the repeating pattern is encountered.
It is noted that the aforementioned examples are provided merely for illustrative purposes and shall not be construed as limiting the scope of the present disclosure.
Referring to
The set of one or more rules may include any set of rules. For example, the set of one or more rules may include a first rule 202 including a no operation command. In one instance, during run-time, the aircraft controller 102 may be configured to set the first rule 202 as return (e.g., “Ret”) when no image is loaded. In another instance, during run-time, the aircraft controller 102 may be configured to set the first rule 202 as no operation (e.g., “Noop”) when an image is loaded.
By way of another example, the set of one or more rules may include a second rule 204 configured to set the base pointer opcode. For instance, during run-time, the aircraft controller 102 may be configured to place the base address into this opcode when the absolute address is known and the chart is loaded.
By way of another example, the set of one or more rules may include a third rule 206 configured to “branch” to a portion of the display list 200. For example, the “branch” may be configured to cause the aircraft controller 102 to execute the display list 200 in a predetermined order (e.g., skip over data that needs to be updated and move on to the actual image itself) and provide the display list organization structure 212 size (e.g., to tell the controller 102 how much data needs to be updated with base pointer/absolute address information during run-time). It is noted that this allows the processors 104 to modify addresses in a highly limited area of the display list 200.
Referring to
The one or more relative offsets 210 may be arranged at the beginning of the display list 200. In this regard, all references which need updated may be placed at the beginning of the display list 200, such that the time required to update the hardware directives with the current base address is reduced.
The offboard controller 124 may be configured to provide the generated display list 200 to the on-board aircraft controller 102 to perform during run-time. For example, the communication interface 110 may be configured to receive the generated display list 200 and store the generated display list 200 in memory 106. For instance, during run-time, the aircraft controller 102 may be configured to access the generated display list 200 in memory 106 and perform during run-time.
The communication interface 134 of the offboard controller 124 may be communicatively coupled to the communication interface 110 of the on-board aircraft controller 102. For example, the communication interface 134 may be configured to provide the generated display list 200 (stored in memory 128) to the communication interface 110 via a wireless and/or wireline connection.
During run-time, the on-board aircraft controller 102 may be configured to insert a no operation (e.g., “No op”) position if an image is loaded.
During run-time, the on-board aircraft controller 102 may be configured to insert a return (e.g., “Ret”) position if no image is loaded. For example, if a return position is inserted, then the image will need to be called and nothing is displayed.
During run-time, the on-board aircraft controller 102 may be configured to set the base pointer. The base pointer may be configured to indicate to the hardware that any relatively addressed hardware directives (e.g., offsets) may be addressed from the base pointer location. For example, when the generated display list 200 is loaded, the one or more program instructions 108 of the aircraft controller may be configured to place the base address into the base pointer opcode 206 (as shown in
For instance, as discussed previously herein, offsets may be generated by the offboard controller 124 as relative offsets to a specific location. During run-time, only these addresses need to be updated by adding the base address (which is only known at run-time) to the relative addresses provided by the offboard (or offline) controller 124.
During run-time, the on-board aircraft controller 102 may be configured to perform the second set of one or more hardware directives (e.g., hardware directives that do not require updating during run-time). For example, during run-time, the on-board aircraft controller 102 may be configured to “branch” to the second set of one or more hardware directives, while skipping the first set of one or more hardware directives (e.g., offsets) in the display list organization structure.
The second set of one or more hardware directives may include the chart image to be rendered. Further, the second set of one or more hardware directives may include calls to subroutines (accessed by calls through addresses stored in the display list organization structure).
During run-time, when a subroutine is encountered, the on-board aircraft controller 102 may be configured to make an indirect call. It is noted that to execute the call, an absolute address must reside at the indirect address given. In this regard, the offboard controller 124 may be configured to store the relative (or negative) address of the offset, pointing to the display list organization structure.
During run-time, the on-board aircraft controller 102 may be configured to update the addresses in the display list organization structure after the base address is determined (as discussed previously herein). For example, the one or more processors 104, after determining the base address, may be configured to updates the addresses in the display list organization structure. For instance, the one or more program instructions 108 of the aircraft controller 102 may be configured to cause the one or more processors 104 to update one or more absolute addresses of the first set of one or more hardware directives during run-time. It is noted that by adding the base address to the offboard controller provided offsets, an absolute address is yielded.
During run-time, the on-board aircraft controller 102 may be configured to execute the subroutine from the absolute address stored in the display list organization structure. The subroutine return 222 may be configured to pass control back to the next location following the original call the second set of hardware directives 214 of the display list 200.
The aircraft controller 102 and/or the one or more offboard controllers 124 may be coupled (e.g., physically, electrically, and/or communicatively) to one or more satellites 138. For example, the aircraft controller 102 and/or the one or more offboard controllers 124 may be coupled (e.g., physically, electrically, and/or communicatively) to one another via the one or more satellites 138. For instance, at least one component of the aircraft controller 102 may be configured to transmit data to and/or receive data from at least one component of the one or more offboard controllers 124, and vice versa. By way of another example, at least one component of the aircraft controller 102 may be configured to record event logs and may transmit the event logs to at least one component of the one or more offboard controllers 124, and vice versa. By way of another example, at least one component of the aircraft controller 102 may be configured to receive information and/or commands from the at least one component of the one or more offboard controllers 124, either in response to (or independent of) the transmitted event logs, and vice versa.
It is noted herein that the aircraft 100 and the components onboard the aircraft 100, the one or more offboard controllers 124, the one or more GPS satellites 122, and/or the one or more satellites 138 may be considered components of a system 140, for purposes of the present disclosure. The system may be generally discussed in concurrently filed U.S. Patent Publication No. 2023/0154338, published on May 18, 2023 entitled TOOL TO FACILITATE CUSTOMER GENERATED CHART DATABASES FOR USE WITH A CERTIFIED AVIONICS SYSTEM, which is incorporated herein by reference in the entirety.
The one or more processors 104, 126 may include any one or more processing elements, micro-controllers, circuitry, field programmable gate array (FPGA) or other processing systems, and resident or external memory for storing data, executable code, and other information accessed or generated by the aircraft controller 102 and/or the one or more offboard controllers 124. In this sense, the one or more processors 104, 126 may include any microprocessor device configured to execute algorithms and/or program instructions. It is noted herein, however, that the one or more processors 104, 126 are not limited by the materials from which it is formed or the processing mechanisms employed therein and, as such, may be implemented via semiconductor(s) and/or transistors (e.g., using electronic integrated circuit (IC) components), and so forth. In general, the term “processor” may be broadly defined to encompass any device having one or more processing elements, which execute a set of program instructions from a non-transitory memory medium (e.g., the memory), where the set of program instructions is configured to cause the one or more processors to carry out any of one or more process steps.
The memory 106, 128 may include any storage medium known in the art suitable for storing the set of program instructions executable by the associated one or more processors. For example, the memory 106, 128 may include a non-transitory memory medium. For instance, the memory 106, 128 may include, but is not limited to, a read-only memory (ROM), a random access memory (RAM), a magnetic or optical memory device (e.g., disk), a magnetic tape, a solid state drive, flash memory (e.g., a secure digital (SD) memory card, a mini-SD memory card, and/or a micro-SD memory card), universal serial bus (USB) memory devices, and the like. The memory 106, 128 may be configured to provide display information to the display device (e.g., the one or more display devices 112). In addition, the memory 106, 128 may be configured to store user input information from a user input device of a user interface. The memory 106, 128 may be housed in a common controller housing with the one or more processors. The memory 106, 128 may, alternatively or in addition, be located remotely with respect to the spatial location of the processors and/or a controller. For instance, the one or more processors and/or the controller may access a remote memory (e.g., server), accessible through a network (e.g., internet, intranet, and the like).
The aircraft controller 102 and/or the one or more offboard controllers 124 may be configured to perform one or more process steps, as defined by the one or more sets of program instructions 108, 130. The one or more process steps may be performed iteratively, concurrently, and/or sequentially. The one or more sets of program instructions 108, 130 may be configured to operate via a control algorithm, a neural network (e.g., with states represented as nodes and hidden nodes and transitioning between them until an output is reached via branch metrics), a kernel-based classification method, a Support Vector Machine (SVM) approach, canonical-correlation analysis (CCA), factor analysis, flexible discriminant analysis (FDA), principal component analysis (PCA), multidimensional scaling (MDS), principal component regression (PCR), projection pursuit, data mining, prediction-making, exploratory data analysis, supervised learning analysis, boolean logic (e.g., resulting in an output of a complete truth or complete false value), fuzzy logic (e.g., resulting in an output of one or more partial truth values instead of a complete truth or complete false value), or the like. For example, in the case of a control algorithm, the one or more sets of program instructions 108, 130 may be configured to operate via proportional control, feedback control, feedforward control, integral control, proportional-derivative (PD) control, proportional-integral (PI) control, proportional-integral-derivative (PID) control, or the like.
The one or more communication interfaces 110, 134 may be operatively configured to communicate with one or more components of the aircraft controller 102 and/or the one or more offboard controllers 124. For example, the one or more communication interfaces 110, 134 may also be coupled (e.g., physically, electrically, and/or communicatively) with the one or more processors 104, 126 to facilitate data transfer between components of the one or more components of the aircraft controller 102 and/or the one or more offboard controllers 124 and the one or more processors 104, 126. For instance, the one or more communication interfaces 110, 134 may be configured to retrieve data from the one or more processors 104, 126, or other devices, transmit data for storage in the memory 106, 128, retrieve data from storage in the memory 106, 128, or the like. By way of another example, the aircraft controller 102 and/or the one or more offboard controllers 124 may be configured to receive and/or acquire data or information from other systems or tools by a transmission medium that may include wireline and/or wireless portions. By way of another example, the aircraft controller 102 and/or the one or more offboard controllers 124 may be configured to transmit data or information (e.g., the output of one or more procedures of the inventive concepts disclosed herein) to one or more systems or tools by a transmission medium that may include wireline and/or wireless portions (e.g., a transmitter, receiver, transceiver, physical connection interface, or any combination). In this regard, the transmission medium may serve as a data link between the aircraft controller 102 and/or the one or more offboard controllers 124 and the other subsystems (e.g., of the aircraft 100 and/or the system 140). In addition, the aircraft controller 102 and/or the one or more offboard controllers 124 may be configured to send data to external systems via a transmission medium (e.g., network connection).
The one or more display devices 112 may include any display device known in the art. For example, the display devices 112 may include, but are not limited to, one or more head-down displays (HDDs), one or more HUDs, one or more multi-function displays (MFDs), or the like. For instance, the display devices 112 may include, but are not limited to, a liquid crystal display (LCD), a light-emitting diode (LED) based display, an organic light-emitting diode (OLED) based display, an electroluminescent display (ELD), an electronic paper (E-ink) display, a plasma display panel (PDP), a display light processing (DLP) display, or the like. Those skilled in the art should recognize that a variety of display devices may be suitable for implementation in the present invention and the particular choice of display device may depend on a variety of factors, including, but not limited to, form factor, cost, and the like. In a general sense, any display device capable of integration with the user input device (e.g., touchscreen, bezel mounted interface, keyboard, mouse, trackpad, and the like) is suitable for implementation in the present invention.
The one or more user input devices 114 may include any user input device known in the art. For example, the user input device 114 may include, but is not limited to, a keyboard, a keypad, a touchscreen, a lever, a knob, a scroll wheel, a track ball, a switch, a dial, a sliding bar, a scroll bar, a slide, a handle, a touch pad, a paddle, a steering wheel, a joystick, a bezel input device, or the like. In the case of a touchscreen interface, those skilled in the art should recognize that a large number of touchscreen interfaces may be suitable for implementation in the present invention. For instance, the display device may be integrated with a touchscreen interface, such as, but not limited to, a capacitive touchscreen, a resistive touchscreen, a surface acoustic based touchscreen, an infrared based touchscreen, or the like. In a general sense, any touchscreen interface capable of integration with the display portion of a display device is suitable for implementation in the present invention. In another embodiment, the user input device may include, but is not limited to, a bezel mounted interface.
In a step 302, chart data may be received from a third-party chart provider. For example, the offboard controller 124 may be configured to receive chart data from a third-party chart provider. In one instance, the offboard controller 124 may be configured to receive enroute chart data from a third-party enroute chart provider. In another instance, the offboard controller 124 may be configured to receive terminal chart data from a third-party terminal chart provider.
It is noted that the offboard controller 124 may be configured to receive any type of chart from any suitable third-party chart provider.
In a step 304, the received chart data may be converted into one or more sets of one or more hardware directives 132 and one or more sorted keys 134 (e.g., subroutines). For example, the offboard controller 124 may be configured to convert the received chart data into one or more sets of one or more hardware directives 132 and one or more sorted keys 134. In one instance, the one or more program instructions 130 of the offboard controller 124 may be configured to cause the one or more processors 126 to convert the received chart data into one or more sets of one or more hardware directives 132 and store the converted hardware directives in memory 128. In another instance, the one or more program instructions 130 of the offboard controller 124 may be configured to cause the one or more processors 126 to convert the received chart data into one or more sorted keys 134 (e.g., subroutines 220) and store the sorted keys 134 (e.g., subroutines 220) in memory 128. In this regard, the converted hardware directives and the sorted keys (e.g., subroutines 220) may be configured to speed up data access during run-time.
In a step 306, a display list 200 may be generated. For example, the offboard controller 124 may be configured to generate a display list 200 including the generated set of one or more hardware directives 210, 212, the one or more subroutines 220, and a set of one or more rules. Referring to
In a step 308, the generated display list 200 may be provided to the on-board controller 102 to perform during run-time. For example, the offboard controller 124 may be configured to provide the generated display list 200 to the on-board controller 102 to perform during run-time. For instance, the communication interface 110 may be configured to receive the generated display list 200 and store the generated display list 200 in memory 106. In this regard, during run-time, the aircraft controller 102 may be configured to access the generated display list 200 in memory 106 and perform during run-time.
In a step 310, one or more absolute addresses of the one or more relative offsets may be updated. For example, the aircraft controller 102 may be configured to update the one or more absolute addresses of the one or more relative offsets of the first set of one or more hardware directives during run-time.
Although the disclosure has been described with reference to the embodiments illustrated in the attached drawing figures, equivalents may be employed and substitutions made herein without departing from the scope of the claims. Components illustrated and described herein are merely examples of a system/device and components that may be used to implement embodiments of the present disclosure and may be replaced with other devices and components without departing from the scope of the claims. Furthermore, any dimensions, degrees, and/or numerical ranges provided herein are to be understood as non-limiting examples unless otherwise specified in the claims.
The present disclosure claims the benefit under 35 U.S.C. § 119(e) of U.S. Provisional Application Ser. No. 63/278,576, filed Nov. 12, 2021, entitled SYSTEMS AND METHODS FOR GENERATION, SELECTION, AND DISPLAY OF MAP-BASED CHART DATABASES FOR USE WITH CERTIFIED AVIONICS SYSTEMS, naming Jeff M. Henry, Kyle R. Peters, Todd E. Miller, Jason L. Wong, Reed A. Kovach, and Srinath Nandakumar as inventor, which is incorporated herein by reference in the entirety.
Number | Name | Date | Kind |
---|---|---|---|
3522586 | Kiji et al. | Aug 1970 | A |
3656178 | Maine et al. | Apr 1972 | A |
4096527 | Furuta | Jun 1978 | A |
4736303 | Itoh et al. | Apr 1988 | A |
4792981 | Cahill, III et al. | Dec 1988 | A |
4876651 | Dawson et al. | Oct 1989 | A |
5050230 | Jones et al. | Sep 1991 | A |
5428692 | Kuehl | Jun 1995 | A |
5454076 | Cain et al. | Sep 1995 | A |
5499382 | Nusinov et al. | Mar 1996 | A |
5537669 | Evans et al. | Jul 1996 | A |
5546572 | Seto et al. | Aug 1996 | A |
5559707 | DeLorme et al. | Sep 1996 | A |
5577170 | Karow | Nov 1996 | A |
5936637 | Seto | Aug 1999 | A |
5978715 | Briffe et al. | Nov 1999 | A |
6014133 | Yamakado et al. | Jan 2000 | A |
6240341 | Snyder | May 2001 | B1 |
6275610 | Hall, Jr. et al. | Aug 2001 | B1 |
6320984 | Shigeta | Nov 2001 | B1 |
6448922 | Kelly | Sep 2002 | B1 |
6501441 | Ludtke et al. | Dec 2002 | B1 |
6839714 | Wheeler et al. | Jan 2005 | B2 |
7039505 | Southard et al. | May 2006 | B1 |
7096211 | Fujihara | Aug 2006 | B2 |
7173738 | Kohn | Feb 2007 | B2 |
7552010 | Saito | Jun 2009 | B2 |
7552011 | Ishii et al. | Jun 2009 | B2 |
7562289 | Bufkin et al. | Jul 2009 | B2 |
7581036 | Powell et al. | Aug 2009 | B2 |
7609263 | Nagasaki et al. | Oct 2009 | B2 |
7739622 | DeLine et al. | Jun 2010 | B2 |
7777749 | Chung et al. | Aug 2010 | B2 |
7948502 | Stanton | May 2011 | B2 |
7966609 | Serebryany | Jun 2011 | B2 |
8035642 | Suzuki | Oct 2011 | B2 |
8165732 | Corbefin et al. | Apr 2012 | B2 |
8169505 | Hoshi | May 2012 | B2 |
8306745 | Clark et al. | Nov 2012 | B1 |
8339417 | Stroila et al. | Dec 2012 | B2 |
8374390 | Stroila et al. | Feb 2013 | B2 |
8379065 | Nam et al. | Feb 2013 | B2 |
8515658 | Foster et al. | Aug 2013 | B1 |
8583368 | Sindlinger et al. | Nov 2013 | B1 |
8704732 | Pourbigharaz et al. | Apr 2014 | B2 |
8937737 | Tsutsumi et al. | Jan 2015 | B2 |
9035969 | Ivashin et al. | May 2015 | B2 |
9195637 | Peraza et al. | Nov 2015 | B2 |
9430195 | Pecoraro et al. | Aug 2016 | B1 |
9443433 | Conway et al. | Sep 2016 | B1 |
9465513 | Sims | Oct 2016 | B2 |
9489121 | Davis et al. | Nov 2016 | B2 |
9547727 | Passani et al. | Jan 2017 | B2 |
9619919 | Postnikov | Apr 2017 | B1 |
9639309 | Pugh | May 2017 | B1 |
9671935 | Miichi et al. | Jun 2017 | B2 |
9703455 | Cocco et al. | Jul 2017 | B2 |
9781294 | Chapman | Oct 2017 | B1 |
9818051 | Panek et al. | Nov 2017 | B2 |
9858823 | Lynn et al. | Jan 2018 | B1 |
9891875 | Kim et al. | Feb 2018 | B2 |
9921721 | Beavers et al. | Mar 2018 | B2 |
9939271 | Foster et al. | Apr 2018 | B1 |
10001376 | Tiana et al. | Jun 2018 | B1 |
10061480 | McCusker et al. | Aug 2018 | B1 |
10170010 | McCusker et al. | Jan 2019 | B1 |
10372292 | Vogel et al. | Aug 2019 | B2 |
10674075 | Kimura | Jun 2020 | B2 |
10684769 | Yamat et al. | Jun 2020 | B2 |
10872274 | Mao et al. | Dec 2020 | B2 |
10880522 | McCutchen et al. | Dec 2020 | B2 |
10984501 | Milan et al. | Apr 2021 | B2 |
11030477 | Becker et al. | Jun 2021 | B2 |
11061563 | Nielsen et al. | Jul 2021 | B1 |
11106329 | He et al. | Aug 2021 | B2 |
20030151630 | Kellman et al. | Aug 2003 | A1 |
20040071351 | Rade | Apr 2004 | A1 |
20040225440 | Khatwa et al. | Nov 2004 | A1 |
20050030321 | Anwar | Feb 2005 | A1 |
20050091340 | Facemire | Apr 2005 | A1 |
20060031006 | Stenbock et al. | Feb 2006 | A1 |
20060215915 | Kim | Sep 2006 | A1 |
20070067095 | King | Mar 2007 | A1 |
20070094591 | Etgen et al. | Apr 2007 | A1 |
20070112517 | Goldstein | May 2007 | A1 |
20070185651 | Motoyama et al. | Aug 2007 | A1 |
20080046254 | Nuno et al. | Feb 2008 | A1 |
20080103641 | Ratcliffe | May 2008 | A1 |
20080240152 | Quinn et al. | Oct 2008 | A1 |
20090080801 | Hatfield et al. | Mar 2009 | A1 |
20090123070 | Xiaoying | May 2009 | A1 |
20090125837 | Hatem et al. | May 2009 | A1 |
20090324065 | Ishida et al. | Dec 2009 | A1 |
20100128020 | Oh et al. | May 2010 | A1 |
20100218089 | Chao et al. | Aug 2010 | A1 |
20100262318 | Ariens | Oct 2010 | A1 |
20100328353 | McDonald et al. | Dec 2010 | A1 |
20110191014 | Feng et al. | Aug 2011 | A1 |
20120019673 | Narayanan | Jan 2012 | A1 |
20120242687 | Choi | Sep 2012 | A1 |
20120287151 | James et al. | Nov 2012 | A1 |
20140168277 | Ashley et al. | Jun 2014 | A1 |
20140225928 | Konnola et al. | Aug 2014 | A1 |
20140282038 | Royster et al. | Sep 2014 | A1 |
20150070373 | Clinton | Mar 2015 | A1 |
20150239574 | Ball et al. | Aug 2015 | A1 |
20150278626 | Nakamura | Oct 2015 | A1 |
20150324088 | Pasetto et al. | Nov 2015 | A1 |
20160092557 | Stojanovic et al. | Mar 2016 | A1 |
20170262413 | Song et al. | Sep 2017 | A1 |
20170299633 | Pietrowicz | Oct 2017 | A1 |
20170313332 | Paget | Nov 2017 | A1 |
20180181646 | Balasa et al. | Jun 2018 | A1 |
20180253889 | Nagasaka | Sep 2018 | A1 |
20190057671 | Baer et al. | Feb 2019 | A1 |
20190220234 | Lewis et al. | Jul 2019 | A1 |
20190237043 | Tahmasebi | Aug 2019 | A1 |
20190299701 | Bartels | Oct 2019 | A1 |
20200089694 | Cabra et al. | Mar 2020 | A1 |
20200195924 | Hsiang | Jun 2020 | A1 |
20200251029 | Tseng | Aug 2020 | A1 |
20200255350 | Baek | Aug 2020 | A1 |
20200320142 | Malak et al. | Oct 2020 | A1 |
20200386567 | Igarashi | Dec 2020 | A1 |
20210004930 | Kamath et al. | Jan 2021 | A1 |
20210035453 | Khan et al. | Feb 2021 | A1 |
20210056300 | Chitta et al. | Feb 2021 | A1 |
20210192202 | Tripuraneni et al. | Jun 2021 | A1 |
20210225181 | Feyereisen et al. | Jul 2021 | A1 |
20210349615 | Ruby et al. | Nov 2021 | A1 |
20230154338 | Henry et al. | May 2023 | A1 |
Number | Date | Country |
---|---|---|
3095088 | Feb 2021 | CA |
1045835 | Oct 1999 | CN |
100440222 | Dec 2008 | CN |
101751449 | Jun 2010 | CN |
101676988 | Dec 2011 | CN |
102714759 | Oct 2016 | CN |
107026958 | Aug 2017 | CN |
107402734 | Nov 2017 | CN |
109325083 | Feb 2019 | CN |
110727747 | Jan 2020 | CN |
110906938 | Mar 2020 | CN |
0341645 | Nov 1989 | EP |
0380294 | Aug 1990 | EP |
0748562 | Oct 1998 | EP |
1352315 | Oct 2003 | EP |
1366462 | Dec 2003 | EP |
1454213 | Sep 2004 | EP |
1272977 | Dec 2004 | EP |
1687777 | Aug 2006 | EP |
2224359 | Sep 2010 | EP |
2792998 | Oct 2014 | EP |
2879061 | Jun 2015 | EP |
1736894 | Jul 2016 | EP |
3201879 | Aug 2017 | EP |
3538978 | Aug 2020 | EP |
3845862 | Jul 2021 | EP |
2504085 | Jan 2014 | GB |
S622721 | Jan 1987 | JP |
S62196772 | Aug 1987 | JP |
S6393273 | Apr 1988 | JP |
H05205069 | Aug 1993 | JP |
3871040 | Jan 2007 | JP |
2007133231 | May 2007 | JP |
2008022215 | Jan 2008 | JP |
2009282855 | Dec 2009 | JP |
4728744 | Jul 2011 | JP |
9523364 | Aug 1995 | WO |
1998043208 | Jan 1999 | WO |
2011036499 | Mar 2011 | WO |
2014146561 | Sep 2014 | WO |
2021035223 | Feb 2021 | WO |
2021035954 | Mar 2021 | WO |
Entry |
---|
Anonymous: “SkyDemon Mobile, GBS handheld navigation devices for aircrfaft”, Dec. 4, 2021; Internet URL https://web.archive.org/web/20211204140934/https://www.skydemon.aero/inflight/. |
C. Pschierer et al., “Human factors analysis for a 2D enroute moving map application”, SPIE, PO Box 10, Bellingham, WA 98227-0010 USA, vol. 5802, May 25, 2005. |
Extended European Search Report dated Apr. 11, 2023; European Application No. 22207123.5. |
Extended European Search Report dated Apr. 12, 2023; European Application No. 22207050.0. |
Extended European Search Report dated Apr. 12, 2023; European Application No. 22207124.3. |
Extended European Search Report dated Apr. 18, 2023; European Application No. 22207164.9. |
Rockwell Collins: “Flight Database Services for Pro Line Fusion”, Jan. 12, 2021, XP093035870, Internet URL: https://www.rockwellcollins.com/-/media/files/unsecure/products/product-brochures/navigation-and-guidance/flight-management-systems/resources/fusion-data-base-services-01.pdf?a=en&lastupdate=20210125195039&csrt=15271691716207860418, p. 5. |
Skysectionals: “Tour Low-Altitute Enroute Charts”, Sep. 22, 2021; XP093035866, Internet: URL:https://web.archive.org/web/20210922184910/https://skysectionals.com/tour-enroute/. |
Stephen Dubet; Institute of Electrical and Electronics Engineers: “Aeronautical charts for electronic flight bags”, 22nd. DASC. The 22nd Digital Avionics Systems Conference Proceedings. Indianapolis, IN Oct. 12-16, 2003. vol. 2, pp. 13_D_1_1_13_D_1_9, XP010669024. |
ArcGIS, “Introduction to export a map or layout”, retrieved from the Internet Nov. 11, 2021. |
Bongwon Suh, Haibin Ling, Benjamin B. Bederson, and David W. Jacobs. 2003. Automatic thumbnail cropping and its effectiveness. In Proceedings of the 16th annual ACM symposium on User interface software and technology (UIST 03). Association for Computing Machinery, New York, NY, USA, 95-104. |
Houston, Ben & Nielsen, Michael & Batty, Christopher & Nilsson, Ola & Museth, Ken. (2006). Hierarchical RLE Level Set: A compact and versatile deformable surface representation. ACM Trans. Graph.. 25. 151-175. |
Jeppesen, “JeppView for Windows, User Guide”, (2016), 92 pages. |
Lufthanasa Systems Blog, “Lido eRouteManual 4.3 Design Overview”, (2016) Retrieved from the Internet. |
Maptiler, “Software performs Geocoding, Place name search, and Reverse Geocoding.” Retrieved from Internet on Nov. 11, 2021. |
Microsoft, “Generate a thumbnail sprite with Azure Media Services”, (2021), Retrieved from Internet Nov. 11, 2021. |
Narkive Mailinglist Archive, “Fastest Method of Drawing a TileMap”, (2002), Retrieved from Internet Nov. 11, 2021. |
Navigraph, “Navigraph Charts”, Retrieved from the Internet. |
Pamental, Jason, “Digging in to dynamic typography”, Retrieved from Internet , Nov. 11, 2021, 11 pages. |
Pamental, Jason, “The evolution of typography with variable fonts”, Retrieved from the Internet , Nov. 11, 2021. |
Penquerch, “[AD] RLE clipping speedup patch” (2002), Retrieved from Internet , Nov. 11, 2021. |
QGIS: Open-source cross-platform GIS software, Retrieved from Internet , Nov. 11, 2021. |
Somasundaram, K. “A Method for Filling Holes in Objects of Medical Images Using Region Labeling and Run Length Encoding Schemes.” (2010). |
Extended European Search Report dated Mar. 24, 2023; European Application No. 22207029.4. |
Anonymous: “algorithm-Contour of a run-length-coded digital shape”, Stack Overflow, Dec. 31, 2015, pp. 1-5, URL:https://stackoverflow.com/questions/32354807/contour-of-a-run-length-coded-digital-shape. |
Anonymous: “Pilot's Guide to Foreflight Mobile 82nd Edition Covers ForeFlight Mobile v12.7”, Aug. 26, 2020, pp. 161-165. |
Anonymous: Pilot's Guide to Foreflight Mobile 82nd Edition Covers ForeFlight Mobile v12.7, Aug. 26, 2020, pp. 78-90. |
Extended European Search Report dated Apr. 5, 2023, European Application No. 22207025.2. |
Extended European Search Report dated Apr. 5, 2023, European Application No. 22207047.6. |
Extended European Search Report dated Apr. 5, 2023; European Application No. 22207057.5. |
Extended European Search Report dated Apr. 11, 2023; European Application No. 22207049.2. |
Extended European Search Report dated Apr. 4, 2023; European Application No. 22207012.0. |
Extended European Search Report dated Apr. 5, 2023; European Application No. 22207019.5. |
Hatlapatka Radim: “JBIG2 Supported by OCR”, EUDML Jul. 9, 2012, pp. 1-9. |
Shang Junqing et al.: “JBIG2 text image compression based on OCR”, Proceedings of the SPIE, vol. 6067, Jan. 15, 2006, p. 6067D. |
Seo et al., “Fast Contour-Tracing Algorithm Based on a Pixel-Following Method for Image Sensors”, Sensors, MPDI (Year: 2016). |
Extended European Search Report dated Apr. 21, 2023; European Application No. 22207060.9. |
Extended European Search Report dated Jun. 13, 2023; European Application No. 22206954.4. |
Neupane Prasanga et al.: “Extracting Unknown Repeated Pattern in Tiled Images: 19th International Conference on Hybrid Intelligent Systems (HIS 2019) held in Bhopal, India, Dec. 10-12, 2019” In: Intelligent Autonomous Systems 13, International Publishing, Cham, vol. 1179, pp. 92-102. |
Yang Y. et al: “Vectorization of Linear Features in Scanned Topographic Maps Using Adaptive Image Segmentation and Sequential Line Tracking”, The International Archives of the Photogrammetry, Remote Sensing and Spatial Information Sciences, vol. XXXIX-B4, Aug. 25, 2012, pp. 103-108. |
Number | Date | Country | |
---|---|---|---|
20230154078 A1 | May 2023 | US |
Number | Date | Country | |
---|---|---|---|
63278576 | Nov 2021 | US |