System and method for machine code subroutine creation and execution with indeterminate addresses

Information

  • Patent Grant
  • 11842429
  • Patent Number
    11,842,429
  • Date Filed
    Friday, November 12, 2021
    3 years ago
  • Date Issued
    Tuesday, December 12, 2023
    a year ago
Abstract
A method is disclosed. The method may include receiving chart data; converting the received chart data into one or more sets of hardware directives and one or more subroutines, the one or more sets of one or more hardware directives including at least a first set hardware directives and a second set of hardware directives, the first set of hardware directives including one or more relative offsets needing address modification, the second set of hardware directives not needing address modification; generating a display list including the set of 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; providing the generated display list to an on-board aircraft controller; and updating, via the on-board aircraft controller, the one or more absolute addresses of the relative offsets of the first set of hardware directives during run-time.
Description
BACKGROUND

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.


SUMMARY

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.





BRIEF DESCRIPTION OF THE DRAWINGS

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:



FIG. 1A illustrates a simplified block diagram of an aircraft including the system for machine code subroutine creation and execution with indeterminate addresses, in accordance with one or more embodiments of the present disclosure;



FIG. 1B illustrates an aircraft including the system for machine code subroutine creation and execution with indeterminate addresses, in accordance with one or more embodiments of the present disclosure;



FIG. 2 illustrates a simplified block diagram of a display list of the system, in accordance with one or more embodiments of the present disclosure; and



FIG. 3 illustrates a flowchart depicting a method or process for machine code subroutine creation and execution with indeterminate addresses, in accordance with one or more embodiments of the present disclosure.





DETAILED DESCRIPTION OF THE INVENTION

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.



FIGS. 1A-3 generally illustrate a system and method for machine code subroutine creation and execution with indeterminate addresses, in accordance with one or more embodiments of the present 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.



FIG. 1A illustrates a simplified block diagram of an aircraft including the system for machine code subroutine creation and execution with indeterminate addresses, in accordance with one or more embodiments of the present disclosure. FIG. 1B illustrates an aircraft including the system for machine code subroutine creation and execution with indeterminate addresses, in accordance with one or more embodiments of the present disclosure.


Referring now to FIG. 1A, the aircraft 100 may include an aircraft controller 102 (e.g., on-board aircraft controller/run-time aircraft controller). The aircraft controller 102 may include one or more processors 104, memory 106 configured to store one or more program instructions 108, and/or one or more communication interfaces 110.


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 FIG. 1B, the avionics environment (e.g., the cockpit) may include any number of display devices 112 (e.g., one, two, three, or more displays) such as, but not limited to, one or more head-down displays (HDDs) 112, one or more head-up displays (HUDs) 112, one or more multi-function displays (MFDs), one or more adaptive flight displays (AFDs) 112, one or more primary flight displays (PFDs) 112, or the like.


Referring again to FIG. 1A, the aircraft controller 102 may be coupled (e.g., physically, electrically, and/or communicatively) to one or more user input devices 114. The one or more display devices 112 may be coupled to the one or more user input devices 114. For example, the one or more display devices 112 may be coupled to the one or more user input devices 114 by a transmission medium that may include wireline and/or wireless portions. The one or more display devices 112 may include and/or be configured to interact with one or more user input devices 114.


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 FIG. 2, 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.


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 FIG. 2, the display list 200 may include a display list organization structure 212 including at least the first rule 202, the second rule 204, the third rule 206, and the one or more relative offsets 210 (e.g., second set of hardware directives). Further, although not shown, the display list organization structure 212 may include one or more Boolean logic instructions.


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 FIG. 2).


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.



FIG. 3 illustrates a flowchart depicting a method or process for machine code subroutine creation and execution with indeterminate addresses, in accordance with one or more embodiments of the disclosure.


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 FIG. 2, the display list 200 may include a display list organization structure 212 including at least the first rule 202, the second rule 204, the third rule 206, and the one or more relative offsets 210 (e.g., second set of hardware directives). Further, although not shown, the display list organization structure 212 may include one or more Boolean logic instructions.


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.

Claims
  • 1. A system, the system comprising: 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;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;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; andprovide 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.
  • 2. The system of claim 1, 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; andexecute the one or more rules.
  • 3. The system of claim 1, wherein the one or more subroutines includes at least one subroutine configured to draw a symbol.
  • 4. The system of claim 1, wherein the one or more subroutines includes at least one subroutine configured to draw one or more alphanumeric characters.
  • 5. The system of claim 1, wherein the second set of one or more hardware directives includes a chart image to be rendered based on the received chart data from the one or more chart providers.
  • 6. The system of claim 1, wherein the second set of one or more hardware directives includes one or more calls to the one or more subroutines.
  • 7. The system of claim 1, wherein the one or more rules include at least one no operation command rule.
  • 8. The system of claim 1, wherein the one or more rules include at least one set base point opcode rule configured to cause at least one on-board aircraft controller of the one or more on-board aircraft controllers to set a base address for the one or more relative offsets during run-time.
  • 9. The system of claim 1, wherein the one or more rules include at least one branching rule configured to cause at least one on-board aircraft controller of the one or more on-board aircraft controllers to execute the display list in a predetermined order.
  • 10. A method, the method comprising: receiving chart data from one or more chart providers;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;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;providing the generated display list to one or more on-board aircraft controllers; andupdating, via the one or more on-board aircraft controllers, 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.
  • 11. The method of claim 10, wherein the second set of one or more hardware directives includes a chart image to be rendered based on the received chart data from the one or more chart providers.
  • 12. The method of claim 10, wherein the second set of one or more hardware directives includes one or more calls to the one or more subroutines.
  • 13. The method of claim 10, wherein the one or more rules include at least one no operation command rule.
  • 14. The method of claim 10, wherein the one or more rules include at least one set base point opcode rule configured to cause at least one on-board aircraft controller of the one or more on-board aircraft controllers to set a base address for the one or more relative offsets during run-time.
  • 15. The method of claim 10, wherein the one or more rules include at least one branching rule configured to cause at least one on-board aircraft controller of the one or more on-board aircraft controllers to execute the display list in a predetermined order.
CROSS-REFERENCE TO RELATED APPLICATIONS

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.

US Referenced Citations (131)
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
Foreign Referenced Citations (42)
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
Non-Patent Literature Citations (40)
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.
Related Publications (1)
Number Date Country
20230154078 A1 May 2023 US
Provisional Applications (1)
Number Date Country
63278576 Nov 2021 US