|Publication number||US5299300 A|
|Application number||US 08/074,103|
|Publication date||Mar 29, 1994|
|Filing date||Jun 8, 1993|
|Priority date||Feb 22, 1990|
|Publication number||074103, 08074103, US 5299300 A, US 5299300A, US-A-5299300, US5299300 A, US5299300A|
|Inventors||Michael J. Femal, Kenrick W. Kautz|
|Original Assignee||Harris Corporation|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (7), Referenced by (79), Classifications (11), Legal Events (3)|
|External Links: USPTO, USPTO Assignment, Espacenet|
This is a continuation of application Ser. No. 484,098, filed Feb. 22, 1990, now abandoned.
The present invention relates in general to terrain map color imagery display systems and is particularly directed to a mechanism for interpolating data stored within a digital color terrain map database (scene memory), for defining the values of pixel energization signals whose corresponding spatial locations in the stored terrain map image do not necessarily coincide with corresponding spatial locations of the data within that database.
Co-pending U.S. Pat. No. 4,970,682, issued Nov. 13, 1990, derived from parent application Ser. No. 168,437, filed Mar. 15, 1988, (the original `continuation chain` parent application of which, Ser. No. 224,742, now abandoned was filed Jan. 13, 1981), by Paul B. Beckwith et al, entitled Digital Map Generator and Display System, assigned to the assignee of the present application and the disclosure of which is incorporated herein, describes a digital map generation and display system which is capable of accessing and displaying a digital terrain map image to an observer (e.g. the pilot of a fixed or rotary wing aircraft) effectively in real time with the travel of the aircraft over that terrain. A principal factor in the ability of the system to effect a real time display is the combination of a scene memory, which stores a portion of digital map imagery data that has been decompressed from a mass storage device in a prescribed orientation (North-up), and a controlled addressing scheme for reading out data from the scene memory for display in accordance with heading information supplied by the aircraft's on-board navigation equipment. Because the scene memory address signals (which are navigation-dependent) can be expected to be associated with spatial locations in the (terrain map) image that do not necessarily coincide with spatial locations in the map from which the data stored in memory was originally derived, it is necessary to interpolate the data which is used to drive the pixels of the display.
Previously, such interpolation has been accomplished by techniques which include choosing a stored data value associated with that image spatial location closest to the spatial location for the pixel address, or by `truncating` the pixel address to that memory address which is associated with a prescribed one of a set of geometrically dispersed spatial locations adjacent to the spatial location of the pixel of interest. Because such approximations do not take into account variations across the terrain map, such as abrupt color changes, and are limited by the resolution of the database, they may introduce anomalies (e.g. flickering lines) in the displayed image, especially during image rotation, thereby degrading image quality.
In accordance with the present, invention, the system described in the Beckwith et al patent is substantially enhanced by means of a cache memory and improved interpolation mechanism which both increases throughput and processing speed and yields a color image having reduced artifacts between high contrast areas in the image. More particularly, the present invention is directed to a color display apparatus, such as that employed for a cockpit display in a fixed or rotary wing aircraft, the display having an array of color pixels which are controllably energized by respective pixel control signals, for displaying an image, such as a color terrain map, digital data for which read out from a data base stored in a scene memory. Address signals for accessing the scene memory may be generated in accordance with heading information signals derived from the aircraft's navigation system and, as noted previously, can be expected to be associated with spatial locations in the terrain map other than those associated with the actual stored data.
In order to reduce memory size requirements, the present invention employs a half-resolution storage compression scheme and an auxiliary scene memory cache through which full resolution data is accessed. Interpolation of pixel energization signals for any spatial location on the terrain map is performed by the controlled weighting and summing of plural half and full resolution data values that are stored in (half-resolution) memory addresses whose associated spatial locations neighbor that of the spatial location of interest.
Half-resolution storage compression is carried out by storing, in respective half-resolution representative addressable storage locations of the scene memory, imagery data associated with respective half-resolution spatial locations of a (terrain map) image. For a respective storage location, that imagery data includes first (half-resolution) imagery data (such as that representative of color characteristics, elevation, cultural features, linear and area features stored as full-resolution data) of its associated first spatial location in the terrain map and a plurality of second (full-resolution) imagery data for a plurality of second (full-resolution) spatial locations of the terrain map that are located in an adjacent neighborhood surrounding that first spatial location of the terrain map.
For each respective pixel of the display for which a pixel control signal is to be generated, data values associated with a plurality of surrounding spatial locations are pre-fetched from scene memory into the high speed cache. A virtual memory address signal, representative of that pixel's associated spatial location within the scene memory-resident terrain map database, is then used to access plural neighborhood addresses in the cache memory, the neighborhood addresses being associated with half-resolution spatial locations which are adjacent to the spatial location of the virtual memory address. The accessed imagery data is then processed to generate a pixel control signal associated with that respective pixel.
As noted earlier, in order to avoid discontinuities in the displayed image that would result from simply picking the data value of a single closest spatial location, the present invention interpolates each data value by controllably combining (bi-linear weighting and summing) both half and full resolution data stored in the accessed half-resolution addresses. In particular, for the example of generating luminance and chrominance (YIQ) values for a respective pixel within a scanned color map, since most of the image energy is associated with the luminance component, half-resolution I and Q data accessed from a neighborhood of addressed storage locations of the cache are combined to derive a first code representative of a first color characteristic (chrominance), and selected full-resolution Y data (associated with a full-resolution neighborhood of spatial locations adjacent to that of the virtual address) are combined to derive a second code representative of a second image characteristic (luminance).
For another type of image, e.g. symbology, the stored data may be representative of slope shade characteristics of the half-resolution spatial location of the image and the full-resolution data may be representative of cultural characteristics of each of the neighboring full-resolution spatial locations of the image. In this instance, a pixel data value is generated in accordance with a bi-linear interpolation of slope shade representative data associated with the storage locations associated with half-resolution spatial locations to derive a code representative of an interpolated slope shade value for the spatial location of the image associated with the virtual address, and bi-linear combining of cultural feature representative data associated with selected ones of full-resolution spatial locations adjacent to the half-resolution spatial locations to derive a second code representative of an interpolated cultural feature value for the spatial location associated with the virtual address.
In the course of executing bi-linear interpolation, weighting of half and full-resolution data values may be carried out in accordance with the contents of a plurality of matrices of weighting coefficients, each matrix being associated with a respective one of plural spatial locations neighboring the spatial location of the virtual address. Accessed imagery data is multiplied by a weighting coefficient from a respective one of the matrices so as to produce a plurality of weighted values, which are then summed to produce a respective pixel control code.
In order to warn the pilot of the situation where the height of the terrain being displayed is lower than the actual altitude of the aircraft approaching that terrain, a color overlay may be employed to selectively tint the displayed terrain map to a warning or offset color. The selective tinting is executed by an overlay bit processor, which selectively combines color-modifying (overlay bit plane) data with the interpolated YIQ codes to realize a final YIQ color. The YIQ codes are coupled to a downstream YIQ/RGB conversion circuit (YIQ-RGB look-up table) for converting the YIQ codes into corresponding RGB codes for driving the respective pixel of the display.
FIG. 1 diagrammatically illustrates the overall functional architecture of a digital map graphics processing system employing the improved interpolation mechanism in accordance with the present invention;
FIG. 2 shows a portion of a scene of image, information within an array of orthogonally dispersed locations of which is contained in the decompressed imagery data output from the reconstruction processor of FIG. 1;
FIG. 3 shows associated data fields for half and full resolution storage of scanned imagery, symbology and data frames;
FIG. 4 diagrammatically illustrates the storage format of a scene memory subdivided into an array of areal blocks of imagery data, within which a region to be displayed may be defined;
FIG. 5 diagrammatically shows a scene memory cache and its associated write/read control circuits;
FIG. 6 diagrammatically illustrates an 8×8 array of logical block addresses of a scene memory directory for addressing the physical blocks of scene memory;
FIG. 7 shows the organization of an interleaved pair set of odd and even entries of respective odd and even memory banks;
FIG. 8 diagrammatically illustrates the manner in which adjacent address locations of a half-resolution neighborhood are associated with different memory banks;
FIG. 9 shows the functional architecture of the interpolation processor of FIG. 1;
FIGS. 10-13 respectively show half-resolution coefficient look-up tables, associated with each of half-resolution addresses Q, R, S and T;
FIGS. 14-17 respectively show full-resolution coefficient look-up tables, associated with each of full-resolution addresses A, B, C and D;
FIG. 18 diagrammatically illustrates an overlay bit processing circuit; and
FIG. 19 shows the data fields associated with an overlay bit processor.
Before describing in detail the particular improved terrain map color imagery interpolation mechanism in accordance with the present invention, it should be observed that the present invention resides primarily in a novel structural combination of conventional signal processing circuits and components and not in the particular detailed configurations thereof. Accordingly, the structure, control and arrangement of these conventional circuits and components have been illustrated in the drawings by readily understandable block diagrams which show only those specific details that are pertinent to the present invention, so as not to obscure the disclosure with structural details which will be readily apparent to those skilled in the art having the benefit of the description herein. Thus, the block diagram illustrations of the Figures do not necessarily represent the mechanical structural arrangement of the exemplary system, but are primarily intended to illustrate the major structural components of the system in a convenient functional grouping, whereby the present invention may be more readily understood.
As pointed out previously, the above-referenced Beckwith et al patent describes a digital map generation and display system which is capable of accessing and displaying a digital terrain map image to an observer (e.g. the pilot of a fixed or rotary wing aircraft) effectively in real time with the travel of the aircraft over that terrain. A principal factor in the ability of the system to so operate is its use of a scene memory, in which data is stored in a prescribed orientation (North-up) and a controlled addressing scheme for reading out contents of the scene memory for display in accordance with heading information signals supplied by on-board navigation equipment. Pursuant to the present invention, the system described in the Beckwith et al patent is substantially enhanced by means of a cache memory and improved interpolation mechanism which both decreases memory size and speed requirements, and yields a color image having reduced artifacts between high contrast areas in the image.
The architecture of a digital map graphics processing system employing the improved interpolation mechanism in accordance with the present invention is diagrammatically illustrated in FIG. 1 as comprising a reconstruction processor 11, which is coupled via an input image data bus 13 to a mass storage device (not shown), from which compressed video data is supplied for display on a downstream color image display device (CRT) 15. The data itself may be one of several types, e.g. scanned raster color imagery data, such as color paper charts and color terrain photographs, symbolic representation of geographic data, typically in the form of a gridded elevational model and an edge-based vector representation of cultural data, and static images (data frames). The manner in which the present invention processes each of these multiple types of imagery data will be explained in detail below. Reconstruction processor 11 is of conventional construction (for example, of the type described in the above-referenced Beckwith et al patent) and produces a decompressed imagery data output for application to scene memory 21 and associated imagery signal processing circuitry. Although the format (full/half resolution) of the decompressed imagery data will depend upon the type of image being processed, the data itself is always stored at a half resolution coordinate coverage, but with full resolution information, in order to reduce memory address requirements.
More particularly, FIG. 2 shows a portion of an image (e.g. a raster scanned color map), information at an array or matrix of orthogonally dispersed spatial locations 23 in which, termed full-resolution spatial locations, is contained in half-resolution decompressed data, associated with half-resolution spatial locations 33 of the terrain map, output from reconstruction processor 11, as will be described below. Thus, in the case of a color topographical map which has been optically scanned and digitized, each data value is associated with a respective spatial location 23, having a geographically definable set of coordinates on the grid map. For purposes of the present description it will be assumed that the vertical or Y separation between adjacent spatial locations 23 (or 33) is the same as their horizontal or X separation. (The use A, B, C and D designators associated with spatial locations 23 will be detailed below.) For the example of a topographical map, each of spatial locations 23 may occur at some specified terrain separation interval, with the separation (e.g. North-South (Y) or East-West (X)) between adjacent locations being a prescribed geographical distance, e.g. twenty-five meters.
While it is certainly possible to store imagery data at a dedicated address for each spatial location for each of terrain map locations 23 (i.e. each map location has its own memory address), doing so may require a large memory, depending upon the resolution of the image. Because the resolution requirements for imagery reproduction vary with image type (for example, good quality color reproduction for scanned raster imagery data can be achieved with full resolution luminance data, and only half resolution chrominance data), it has been found that scene memory throughput can be enhanced by storing all data in terms of half-resolution image locations or address space, and then selectively accessing the full resolution data as necessary for a executing a particular image processing operation.
More specifically, the array of image locations 23 may be subdivided into generally rectangularly arranged `full-resolution` quartets 25 of locations, encircled at A, B, C and D. Diagrammatically shown within the center of each `full-resolution` quartet 25 is a respective `half-resolution` location 33, four adjacent ones of which Q, R, S and T define a half-resolution neighborhood 35. For the example of a color terrain map image having twenty-five meter separation between map data locations 23, the distance between adjacent half-resolution locations 33 is fifty meters.
As pointed out above, in accordance with the present invention, imagery data is always stored at a half resolution coordinate coverage, namely corresponding to half-resolution locations 33, but with full resolution information for each half-resolution location. By full-resolution information for each half-resolution location is meant that image information for each of the four locations A, B, C and D of a full-resolution quartet 25 surrounding a respective half-resolution location 33 is stored for that half-resolution spatial location. As a consequence, the number of memory addresses required to implement the scene memory (and an associated cache memory) is reduced considerably (by a factor of four), thereby simplifying hardware requirements and expediting signal processing throughput.
Since the data size will vary depending upon the type of image it represents, the storage capacity of each addressable location must be sufficient to accommodate the data having the largest number of bits. To accommodate any of the above-referenced formats having associated fields as shown in FIG. 3, the depth (or code width) of each storage location in memory may be on the order of forty bits. Taking, as an example, raster scanned imagery color map data, its data field entries contain color information in the form of luminance (Y) and chrominance (in-phase (I) and quadrature (Q)) components resolved to a predetermined number of bits. Since most of the signal energy of scanned imagery color map data is contained in the luminance (Y) component (on the order of 90% or more), associated (five bit) Y values for each of the full-resolution spatial locations A, B, C and D of a quartet 25 surrounding a respective half-resolution location 33 are stored in corresponding portions of a data field identified by the index: Y Color Component. The chrominance components, on the other hand, which contain considerably less information, are stored at only half-resolution, i.e. one I, Q pair for each half-resolution spatial location 33, as shown by the singular chrominance data field: I Color, Q Color, of four and three bits, respectively.
As will be described below, in the course of generation of a pixel energization signal for a respective pixel of display 15, having a spatial location P in FIG. 2, the stored luminance data for each of a full-resolution `surrounding neighborhood` 27 of spatial locations A, B, C and D associated with one or more full-resolution quartets 25 is interpolated to obtain an output Y value for that pixel, while the stored chrominance data for each location Q, R, S and T of an associated half-resolution surrounding neighborhood 35 is interpolated to obtain output I and Q values for that pixel. It will be noted that full-resolution spatial locations A, B, C and D of full-resolution `surrounding neighborhood` 27 shown in FIG. 2 are associated with full-resolution data values (and spatial locations) of separate half-resolution spatial locations 33S and 33Q. Namely, full-resolution neighborhood 27 is comprised of spatial locations A and B associated with half-resolution spatial location 33S and spatial locations C and D associated with half-resolution spatial location 33Q. These interpolated Y, I and Q values are then coupled as address inputs to a color conversion look-up table, which generates the requisite R, G and B codes for driving that display pixel.
Symbolic data is stored as its own set of dedicated data fields: Slope Shades, containing two, half-resolution, five bit North and East normals; Elevation data, encoded as seven bits of half-resolution elevation data; Contour lines, comprised of four full-resolution one-bit data; and Cultural data, containing four full-resolution area/linear feature data words. The one bit of contour line data and the four bits of area/linear feature data may be considered five bit full-resolution feature type information. Also shown in FIG. 3 are the data entries for storing a full-resolution thirty-two bit field of a data frame, denoted as Data Frame Index. In a manner similar to that described above with respect to the interpolation processing of scanned imagery data, the contents of the symbology and data frame data fields are selectively processed, to obtain YIQ pixel energization codes which are then converted into RGB signals for energizing a respective pixel of the display.
As pointed out above, signal processing speed is increased in accordance with the present invention by `localizing` or constraining the computation process to a limited portion of the database, specifically within an image area defined by a subset of spatial locations within the image of interest that contain the spatial location of a respective pixel on the screen of the display device. Namely, for any image being displayed (e.g. on a conventional cathode ray tube display screen), the actual generation of the image is accomplished by the sequential energization of the pixels (picture elements) of the display during alternate interlaced field scanning. Since, however, in a typical in-flight environment, address signals for accessing the contents of the scene memory are produced in accordance with signals representative of heading/attitude information supplied by on-board navigation equipment and represent map locations rather than physical memory locations, such read-out address codes are neither necessarily, nor customarily, associated with the precise address entries of the scene memory. Rather, the pixel addresses are virtual addresses having associated spatial locations on an image surface (e.g. terrain map).
On the other hand, the addresses within the scene memory identify storage locations, rather than physical locations of an image, representative data for which is stored in the memory. Since, as noted above, in an image map processing application, the contents of each memory address are associated with and define attributes of an identifiable spatial location on the (terrain) image, any image location may be considered to be a virtual address for accessing the contents of the scene memory and thereby permit a selective combining of those accessed contents to derive a data code that represents an interpolation of what the image looks like at that location. It can be appreciated, therefore, that each pixel on the display where the stored image is recreated has a corresponding spatial location within the stored image, itself. These corresponding spatial locations are represented by the virtual addresses that are used to access the multi-resolution data stored in scene memory, from which accessed data codes are interpolated into YIQ and subsequently converted RGB signals for energizing the respective pixels of the cockpit display.
Thus, within the image surface represented by the contents of the half-resolution addresses (spatial locations) 33 in FIG. 2, the address generated in correspondence with the energization of a respective screen pixel has an associated spatial location P that falls within or is surrounded by some half-resolution neighborhood 35 of spatial locations (scene memory addresses) Q, R, S and T. As described above, pursuant to the invention, the pixel energization code signal used to drive the pixel whose (virtual) address is associated with spatial location P is interpolated by the controlled weighting and summing of a plurality of actual data values (full and half-resolution) stored within the half-resolution storage locations Q, R, S and T of the half-resolution neighborhood 35 containing `virtual address` location P. In particular, where half-resolution data is employed, the data is derived from each of the addresses memory locations associated with the neighborhood of a spatial locations Q, R, S and T of half-resolution neighborhood 35; where full-resolution data is employed, the data is derived from that `full-resolution` neighborhood 27 of spatial locations A, B, C and D most nearly adjacent the spatial location P.
In order to facilitate this process and free up the scene memory for other access operations, an additional `cache` memory 40 (FIG. 1) is coupled to receive a delimited portion of the scene memory in dependence upon where, within the scene memory, image processing (virtual address scanning) is currently being conducted. As diagrammatically illustrated in FIG. 4, and as will be discussed in detail below, the storage format of scene memory 21 is such that it may be subdivided into an array (e.g. sixteen) of areal blocks 21-1 . . . 21-16 of imagery data, within which a region 41 for display may be defined.
For purposes of an illustrative example, within the sixteen block framework of the scene memory and surrounded by a circle 29 is a block 21-11, which contains the current location of a scan line 43 associated with the generation of read-out address codes generated by memory controller 45 (FIG. 1) for accessing data to be displayed. As illustrated in the enlarged depiction in FIG. 4 of the lower region of block 21-11, scan line 43 is associated with the generation of sequential virtual addresses (denoted by Xs along scan 43) associated spatial locations of which pass among spatial locations in the image corresponding to the actual (half-resolution) addresses within the scene memory. The region of scene memory surrounded by an oval 51 contains a sub-array 53 of scene memory addresses (e.g. eight) spatial locations for which immediately surround the spatial location associated with virtual address X in scene memory 21 pointed to by the scanned (pixel) address. As memory controller 45 generates read-out address signals, it updates the scene memory cache 40 with the next associated set of sub-array addresses (e.g. at 30 Hz. or once per update of the display screen), so that irrespective of which spatial location in the image is pointed to by the virtual scan address, cache 40 will provide rapid access to half and full-resolution neighborhood data, and thereby facilitate immediate interpolation processing of the contents of the requisite data fields (via direct accessing of the cache) for energizing the respective pixels of the display.
The scene memory cache 40 and its associated write/read control circuits 42/44 are shown in FIG. 5. As noted earlier, the scene cache stores data that has been pre-fetched from scene memory 21 and provides a sub-array of scene memory data for interpolating an output data value associated with a scanned pixel address. For the above-referenced example of a maximum data field of forty bits, scene memory cache 40 may be an 10×48 bit memory having independent read and write ports 46, 47 as shown. The write port is used to store data pre-fetched from the scene memory, while the read port outputs data for nearest neighborhood sub-arrays for processing by interpolation processor 60 (FIG. 1).
Data accessed from the scene memory is coupled over link 61 and is controllably written into cache 40 under the control of a write address supplied by cache write control circuit 42. Cache write control circuit effectively translates or converts the scan address output by memory controller 45 into sub-array address codes for writing scene memory data into the cache. Scan signals on line 62 cause a pair of sub-array addresses associated with half-resolution spatial locations 33 (FIG. 2) to be written into the cache. The control logic is configured so that if a write into the cache would over-write data being used to generate these sub-array addresses by the cache read control circuit 44, then pre-fetching of data is interrupted, which allows access to the scene memory for rebuilding the scene.
For each (virtual) X,Y address, cache read control circuit 44 reads out data associated with four half-resolution addresses associated with spatial locations Q, R, S and T of a half-resolution neighborhood 35 containing the spatial location P associated with that scan address. The four half-resolution addresses associated with spatial locations Q, R, S and T are identified as follows. That half-resolution address which is closest to the scan address is referred to as the nearest neighbor (NN). In the example shown in FIG. 2, half-resolution address 33S is the nearest neighbor (NN). Using the nearest neighbor address as a point of reference, the half-resolution addresses that are nearest horizontal (East/West) and nearest vertical (North/South) are referred to as X neighbor (XN), (half-resolution address T in the present example) and Y neighbor (YN), (half-resolution address Q in the present example), respectively. The remaining half-resolution address (R in the present example) is referred to as the farthest neighbor (FN) of half-resolution neighborhood 35.
As diagrammatically illustrated in FIG. 4, referenced above, scene memory 21 is subdivided or partitioned into a plurality of (sixteen) memory blocks 21-1 . . . 21-16, an individual one of which 21-i contains a memory capacity of an array of 128×128 half-resolution addresses (each of which is associated with a respective spatial location 33 of FIG. 2), and each having a storage capacity of up to 48 bits, to accommodate the field entries of FIG. 3). Since each half-resolution address stores data for four neighboring full-resolution spatial locations A, B, C and D, each block 21-i within the scene memory effectively stores data associated with an array of 256×256 image locations. The physical blocks are scanned by means of a scene memory directory 70 diagrammatically illustrated in FIG. 6, which maps an 8×8 array of logical block addresses into physical blocks of memory. Scene memory directory 70 wraps around on itself so as to form a continuous map space. Each of scene memory blocks 21-i is organized as an interleaved pair set of odd and even entries of respective odd and even memory banks, as diagrammatically shown in FIG. 7, so that adjacent address locations of a half-resolution neighborhood (e.g. address locations S and T of half-resolution neighborhood 33, shown in FIG. 2) are associated with different memory banks, as diagrammatically shown in FIG. 8.
Referring now to FIG. 9, the functional architecture of interpolation processor 60 is shown as being coupled to a (forty-eight bits wide) scene cache data link 81 from the output of cache memory 40, a local bus color table interface 83, a control register file data link 85 and an X,Y fractional address link 87 from memory controller 45. Interpolation processor 60 is comprised of a set of arithmetic logic circuits that operate on the half and full resolution data accessed from scene memory cache 40 in the course of an address scan, to produce terrain map YIQ color codes, map overlay information, and interpolated slopes and elevation. As noted previously, which codes are produced will depend upon the type of imagery data being processes (e.g. scanned color map imagery data, symbology data, or data frames).
In the course of in-flight display of raster scanned terrain map imagery data, it is important to warn the pilot of the situation where the height of the terrain being displayed is higher than the actual altitude of the aircraft approaching that terrain. For this purpose, a color overlay or mask operation is performed in order to selectively tint the displayed terrain map to a warning or offset color. This operation is initiated in a height above terrain (HAT) calculation circuit 91 which is coupled to links 81 and 85 and compares a set (e.g. a pair) of reference elevation values (based on aircraft altitude) supplied from memory controller with data representative of the actual elevation of the terrain. For a respective address location, if the elevation of the terrain falls below the largest reference elevation, then the output code produced by HAT calculation circuit 91 (which will be combined with the YIQ codes in downstream processing) is essentially all zeros, so that the eventually produced YIQ code for that address is unaffected by the height of the aircraft. On the other hand, if the input code representative of the elevation of the terrain is above the lowest reference elevation code then, a first color offset (first warning color) code will be output from HAT calculation circuit 91. Similarly, if the elevation of the terrain is above the second reference elevation, a second offset (danger) color code will be output. As will be described below, these offset codes (a code zero representing no, or a transparent, offset) are coupled to a downstream overlay bit plane processing unit for controllably modifying the YIQ outputs of the interpolator.
Elevation band select circuit 93 is coupled with links 81 and 85 to produce sixteen bands of elevation color codes, based upon the four most significant bits of elevation data. These elevation color codes are combined with the full resolution cultural data; as consequence, the half-resolution elevation data is selected by elevation band select circuit 93 so that it matches the associated full resolution neighborhood of the half-resolution address code.
Full resolution data select circuit 95 is coupled to cache output link 81 and fraction address link 87 and selects which full resolution neighborhood locations are associated with the half resolution address location supplied from the scene cache. Thus for the example shown in FIG. 2, where pixel virtual address location P falls between the full resolution neighborhoods 25S, 25Q, respectively associated with half resolution addresses S and Q, full resolution data select circuit 95 selects full resolution data A and B for half resolution address S and full resolution data C and D for half resolution address Q, thus defining a full resolution neighborhood 38 about virtual address location P.
The elevation band code produced by elevation band select circuit 93 and the cultural code generated by full resolution data select circuit 95 are combined in elevation band combiner circuit 97. Up to sixteen elevation bands may be employed; those that are used directly replace that number of the thirty-two cultural codes. The elevation bands which are greater than the number of bands enabled are set to the largest number enabled. The cultural codes may be configured as thirty two features with contour lines included or as fifteen features with one bit used to define contour lines.
The combined elevation code produced by elevation band combiner 97 is coupled, together with cache data link 81 and color table data on link 83, to YIQ calculation circuit 101, which converts cultural codes into their YIQ color components or directly selects YIQ data from the (cached) scene memory data. For symbology imagery data, the conversion from cultural codes to YIQ values may implemented by way of a programmable look-up table. If YIQ data is accessed directly from memory, luminance code remains unaltered, whereas the I and Q components are selected from the appropriate half resolution field.
Coefficient calculation circuit 103 is coupled to links 85 and 87 and outputs interpolation coefficients employed by the bi-linear interpolator circuits 102, 104 and 106, to be described below, based upon X and Y fractional address codes associated with the virtual address for the pixel of interest. For this purpose, coefficient calculation circuit 103 may contain a set of half-resolution coefficient look-up tables, associated with each of half-resolution addresses Q, R, S and T, as respectively shown in FIGS. 10-13, and a set of full-resolution coefficient look-up tables, associated with each of full-resolution addresses A, B, C and D, as respectively shown in FIGS. 14-17. Each coefficient look-up table comprises a two-dimensional array or matrix of coefficient values respectively associated with fractional or incremental X and Y values reference to the half-resolution neighborhood 35 containing the virtual address location P, as shown in FIG. 2. The coefficients of each matrix based upon the following functions:
______________________________________neighbor function circuit function______________________________________lower left X*Y X*Ylower right (1 - X)*Y Y - X*Yupper left X*(1 - Y) X - X*Yupper right (1 - X)*(1 - Y) 1 + X*Y - X - Y______________________________________
A slope shade enable circuit 105, which is used to selectively disable slope shading for linear features, contour lines and some area features, is coupled to cache link 81 and detects when a majority of the four full resolution cultural codes for addresses A, B, C and D represent features which are not slope shaded; in this event, the slope shade value for that particular half resolution virtual address (one of Q, R, S and T) is zeroed. Also, should there be a tie between full resolution cultural address values, the slope code is zeroed.
Interpolation of Y, I, Q and slope shade values are executed by respective interpolation calculation circuits 102, 104, 106 and 108, applying full and half resolution neighborhood data to respective bi-linear operations. The interpolation operations are subdivided into half resolution interpolations and full resolution interpolations using the respective sets of coefficients listed in the look-up tables of FIGS. 10-13 and 14-17, referenced above. The interpolation function employed multiplies the four coefficients by the four respective data values and the products are summed together using multiplier/accumulators implemented in combinational logic.
The interpolated north and east shade codes generated by slope interpolator circuit 108 are coupled to a slope normal calculation circuit 111, which generates a slope shade code. This circuit uses the slope shade components and east and north multipliers in a multiplier/accumulator to produce a slope shade code based upon the following set of equations:
P=NORTH SLOPE OF TERRAIN
Q=EAST SLOPE OF TERRAIN
I=SUN AZIMUTH ANGLE
NORTH SLOPE SHADE=P/(1-P**2-Q**2)**.5 (SCENE MEMORY)
EAST SLOPE SHADE=Q/(1-P**2-Q**2)**.5 (SCENE MEMORY)
NORTH MULTIPLIER=SIN I (PRECALCULATED)
EAST MULTIPLIER=COS O (PRECALCULATED)
SLOPE SHADE=NORTH SLOPE SHADE * NORTH MULTIPLIER+EAST SLOPE SHADE * EAST MULTIPLIER.
The outputs of slope normal calculation circuit 111 and luminance interpolation circuit 102 are coupled to a delta Y calculation circuit 113, which sums the slope shade code with the interpolated Y color code and produces a composite Y color code. the degree of slope shading can be modified through the north and east slope shade multipliers.
In order to show threat zones based on stationary ground installations, an overlay bit plane (OBP) is used. The OBP is loaded as a `mask` in bits 31 and 32 of the scene memory as half-resolution data, so that a color overlay may be employed to selectively tint the displayed terrain map to a warning or offset color. The selective tinting is executed by an overlay bit processing circuit, diagrammatically illustrated in FIG. 18 and associated data fields for which are shown in FIG. 19, which selectively combines color-modifying (overlay bit plane) data with the interpolated YIQ codes output from delta Y calculation circuit 113, I interpolation circuit 104 and Q interpolation circuit 106 to realize a final YIQ color. Specifically, an overlay look-up table 121 is addressed by the OBP code to produce overlay YIQ and percent of coverage (e.g. 10-100%) codes on links 123 and 125, respectively. These codes are applied to Y, I and Q modifier circuits 131, 133 and 135, respectively, each of which is comprised of multiplier/accumulator circuits, which perform a weighted average of the YIQ data values based upon the percent of coverage codes. The resulting selectively modified YIQ codes are multiplexed onto output link 141, via HAT code replacement logic 138 which replaces I, Q data with HAT designations; IQ values are defined in a YIQ-RGB look-up table.
As will be appreciated from the foregoing description, anomalies in a color image display of a digitized topographical map, as may occur during rotation of the image, are effectively obviated by the imagery data processing mechanism of the present invention, which employs a half-resolution storage compression scheme and an auxiliary scene memory cache through which full resolution data is accessed. Interpolation is carried out by the controlled weighting and summing of plural half and full resolution data values that are stored in (half-resolution) memory addresses whose associated spatial locations neighbor that of the spatial location of interest, thereby generating pixel energization signals for any spatial location on the terrain map.
While we have shown and described an embodiment in accordance with the present invention, it is to be understood that the same is not limited thereto but is susceptible to numerous changes and modifications as known to a person skilled in the art, and we therefore do not wish to be limited to the details shown and described herein but intend to cover all such changes and modifications as are obvious to one of ordinary skill in the art.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US4428057 *||Jun 9, 1981||Jan 24, 1984||Texas Instruments Incorporated||Electronic chart system|
|US4615013 *||Aug 2, 1983||Sep 30, 1986||The Singer Company||Method and apparatus for texture generation|
|US4638438 *||May 22, 1984||Jan 20, 1987||Hitachi, Ltd.||Navigation apparatus for automotive|
|US4821212 *||Aug 8, 1984||Apr 11, 1989||General Electric Company||Three dimensional texture generator for computed terrain images|
|US4876651 *||May 11, 1988||Oct 24, 1989||Honeywell Inc.||Digital map system|
|US4884971 *||Jul 14, 1988||Dec 5, 1989||Harris Corporation||Elevation interpolator for simulated radar display system|
|US4970682 *||Mar 15, 1988||Nov 13, 1990||Harris Corporation||Digital map generator and display system|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US5604849 *||Mar 20, 1995||Feb 18, 1997||Microsoft Corporation||Overlay management system and method|
|US5684697 *||Jun 26, 1995||Nov 4, 1997||Mullen; Charles H.||Driver emulative vehicle control system|
|US5742277 *||Oct 6, 1995||Apr 21, 1998||Silicon Graphics, Inc.||Antialiasing of silhouette edges|
|US5774826 *||Nov 30, 1995||Jun 30, 1998||Trimble Navigation Limited||Optimization of survey coordinate transformations|
|US5889526 *||Nov 21, 1995||Mar 30, 1999||Matsushita Electric Industrial Co., Ltd.||Interpolation apparatus and method, and image generation apparatus including such an apparatus|
|US5917436 *||Apr 19, 1996||Jun 29, 1999||Hitachi, Ltd.||Map display apparatus|
|US5935198 *||Nov 22, 1996||Aug 10, 1999||S3 Incorporated||Multiplier with selectable booth encoders for performing 3D graphics interpolations with two multiplies in a single pass through the multiplier|
|US5974423 *||Mar 9, 1998||Oct 26, 1999||Margolin; Jed||Method for converting a digital elevation database to a polygon database|
|US6023278 *||Oct 6, 1997||Feb 8, 2000||Margolin; Jed||Digital map generator and display system|
|US6111583 *||Sep 29, 1997||Aug 29, 2000||Skyline Software Systems Ltd.||Apparatus and method for three-dimensional terrain rendering|
|US6177943||Feb 27, 1998||Jan 23, 2001||Jed Margolin||Digital map compression and display method|
|US6243100 *||Jan 11, 1996||Jun 5, 2001||Xerox Corporation||Two dimensional linear interpolation with slope output for a hyperacuity printer|
|US6278383||May 27, 1999||Aug 21, 2001||Hitachi, Ltd.||Map display apparatus|
|US6317523 *||Oct 28, 1997||Nov 13, 2001||Oki Data Corporation||Image data adjusting device and method|
|US6433792||Feb 23, 2000||Aug 13, 2002||Skyline Software Systems, Inc.||Apparatus and method for three-dimensional terrain rendering|
|US6496192 *||Aug 5, 1999||Dec 17, 2002||Matsushita Electric Industrial Co., Ltd.||Modular architecture for image transposition memory using synchronous DRAM|
|US6507677||Aug 21, 2001||Jan 14, 2003||Oki Data Corporation||Image data adjusting device and method|
|US6519055||Mar 30, 2000||Feb 11, 2003||Xerox Corporation||Two-dimensional linear interpolation and registration control for a hyperacuity printer|
|US6600489||Dec 14, 2000||Jul 29, 2003||Harris Corporation||System and method of processing digital terrain information|
|US6603407||Aug 21, 2001||Aug 5, 2003||Hitachi, Ltd.||Map display apparatus|
|US6704017||Feb 23, 2000||Mar 9, 2004||Skyline Software Systems Ltd.||Method for determining scan direction for three-dimensional terrain rendering|
|US6707464||Jan 31, 2001||Mar 16, 2004||Harris Corporation||System and method for identifying tie point collections used in imagery|
|US6756919||May 19, 2003||Jun 29, 2004||Hitachi, Ltd.||Map display apparatus|
|US7068819 *||Jul 12, 2002||Jun 27, 2006||The United States Of America As Represented By The Secretary Of The Navy||System for storing geospecific data|
|US7551172||Jun 2, 2006||Jun 23, 2009||Skyline Software Systems, Inc.||Sending three-dimensional images over a network|
|US8014945||Aug 18, 2009||Sep 6, 2011||Tierravision, Inc.||System and method of wireless downloads of map and geographic based data to portable computing devices|
|US8195118||Jul 15, 2009||Jun 5, 2012||Linear Signal, Inc.||Apparatus, system, and method for integrated phase shifting and amplitude control of phased array signals|
|US8237713||May 27, 2009||Aug 7, 2012||Skyline Software Systems, Inc||Sending three-dimensional images over a network|
|US8361543||Oct 28, 2009||Jan 29, 2013||Certusview Technologies, Llc||Methods and apparatus for displaying an electronic rendering of a marking operation based on an electronic record of marking information|
|US8374789||Dec 16, 2009||Feb 12, 2013||Certusview Technologies, Llc||Systems and methods for using marking information to electronically display dispensing of markers by a marking system or marking tool|
|US8386178||Sep 24, 2008||Feb 26, 2013||Certusview Technologies, Llc||Marking system and method|
|US8401791||Feb 2, 2009||Mar 19, 2013||Certusview Technologies, Llc||Methods for evaluating operation of marking apparatus|
|US8407001||Dec 16, 2009||Mar 26, 2013||Certusview Technologies, Llc||Systems and methods for using location data to electronically display dispensing of markers by a marking system or marking tool|
|US8416995||Jan 30, 2009||Apr 9, 2013||Certusview Technologies, Llc||Electronic manifest of underground facility locate marks|
|US8442766||Feb 11, 2010||May 14, 2013||Certusview Technologies, Llc||Marking apparatus having enhanced features for underground facility marking operations, and associated methods and systems|
|US8457893||Nov 20, 2009||Jun 4, 2013||Certusview Technologies, Llc||Methods and apparatus for generating an electronic record of a marking operation including service-related information and/or ticket information|
|US8467969||Jun 18, 2013||Certusview Technologies, Llc||Marking apparatus having operational sensors for underground facility marking operations, and associated methods and systems|
|US8473209||Apr 24, 2009||Jun 25, 2013||Certusview Technologies, Llc||Marking apparatus and marking methods using marking dispenser with machine-readable ID mechanism|
|US8478523||Feb 2, 2009||Jul 2, 2013||Certusview Technologies, Llc||Marking apparatus and methods for creating an electronic record of marking apparatus operations|
|US8478524||Jun 9, 2010||Jul 2, 2013||Certusview Technologies, Llc||Methods and apparatus for dispensing marking material in connection with underground facility marking operations based on environmental information and/or operational information|
|US8478525||Jun 9, 2010||Jul 2, 2013||Certusview Technologies, Llc||Methods, apparatus, and systems for analyzing use of a marking device by a technician to perform an underground facility marking operation|
|US8478617||Feb 5, 2010||Jul 2, 2013||Certusview Technologies, Llc||Methods and apparatus for generating alerts on a locate device, based on comparing electronic locate information to facilities map information and/or other image information|
|US8510141||Feb 5, 2010||Aug 13, 2013||Certusview Technologies, Llc||Methods and apparatus for generating alerts on a marking device, based on comparing electronic marking information to facilities map information and/or other image information|
|US8527308||Feb 5, 2010||Sep 3, 2013||Certusview Technologies, Llc||Methods and apparatus for overlaying electronic locate information on facilities map information and/or other image information displayed on a locate device|
|US8532488||Nov 30, 2012||Sep 10, 2013||Certusview Technologies, Llc||Cable communication systems and methods employing QAM upstream channels below 16.4 MHz for increased aggregate deployed upstream capacity to support voice and/or data services|
|US8543003||Nov 5, 2012||Sep 24, 2013||Certusview Technologies, Llc||Ingress-mitigated cable communication systems and methods having increased upstream capacity for supporting voice and/or data services|
|US8577707||Mar 11, 2013||Nov 5, 2013||Certusview Technologies, Llc||Methods and apparatus for overlaying electronic locate information on facilities map information and/or other image information displayed on a locate device|
|US8578437||Nov 5, 2012||Nov 5, 2013||Certusview Technologies, Llc||Methods for ingress mitigation in cable communication systems involving repair, replacement and/or adjustment of infrastructure elements|
|US8583264||Sep 30, 2009||Nov 12, 2013||Certusview Technologies, Llc||Marking device docking stations and methods of using same|
|US8589201||Feb 21, 2013||Nov 19, 2013||Certusview Technologies, Llc||Methods and apparatus for generating alerts on a locate device, based on comparing electronic locate information to facilities map information and/or other image information|
|US8589202||Mar 12, 2013||Nov 19, 2013||Certusview Technologies, Llc||Methods and apparatus for displaying and processing facilities map information and/or other image information on a marking device|
|US8600526||Sep 30, 2009||Dec 3, 2013||Certusview Technologies, Llc||Marking device docking stations having mechanical docking and methods of using same|
|US8612148||Jun 9, 2010||Dec 17, 2013||Certusview Technologies, Llc||Marking apparatus configured to detect out-of-tolerance conditions in connection with underground facility marking operations, and associated methods and systems|
|US8620572||Aug 19, 2010||Dec 31, 2013||Certusview Technologies, Llc||Marking device with transmitter for triangulating location during locate operations|
|US8620616||Aug 13, 2010||Dec 31, 2013||Certusview Technologies, Llc||Methods and apparatus for assessing marking operations based on acceleration information|
|US8644965||Sep 30, 2009||Feb 4, 2014||Certusview Technologies, Llc||Marking device docking stations having security features and methods of using same|
|US8649968||May 4, 2012||Feb 11, 2014||Tierravision, Inc.||System and method of wireless downloads of map and geographic based data to portable computing devices|
|US8650606||Nov 5, 2012||Feb 11, 2014||Certusview Technologies, Llc||Cable communication systems and methods employing 256-QAM upstream channels and having increased upstream capacity for supporting voice and/or data services|
|US8700325||Feb 2, 2009||Apr 15, 2014||Certusview Technologies, Llc||Marking apparatus and methods for creating an electronic record of marking operations|
|US8731830||Jun 9, 2010||May 20, 2014||Certusview Technologies, Llc||Marking apparatus for receiving environmental information regarding underground facility marking operations, and associated methods and systems|
|US8770140||Jun 9, 2010||Jul 8, 2014||Certusview Technologies, Llc||Marking apparatus having environmental sensors and operations sensors for underground facility marking operations, and associated methods and systems|
|US8775077||Nov 27, 2012||Jul 8, 2014||Certusview Technologies, Llc||Systems and methods for using location data to electronically display dispensing of markers by a marking system or marking tool|
|US8806559||Oct 15, 2013||Aug 12, 2014||Certusview Technologies, Llc||Methods for ingress mitigation in cable communication systems involving repair, replacement and/or adjustment of infrastructure elements|
|US8811191||Nov 5, 2012||Aug 19, 2014||Certusview Technologies, Llc||Iterative mapping methods for ingress mitigation in cable communication systems|
|US8872719||Nov 9, 2010||Oct 28, 2014||Linear Signal, Inc.||Apparatus, system, and method for integrated modular phased array tile configuration|
|US8903643||Mar 15, 2013||Dec 2, 2014||Certusview Technologies, Llc||Hand-held marking apparatus with location tracking system and methods for logging geographic location of same|
|US8948596||Jun 30, 2012||Feb 3, 2015||CetusView Technologies, LLC||Neighborhood node mapping methods and apparatus for ingress mitigation in cable communication systems|
|US8949918||Mar 17, 2014||Feb 3, 2015||Certusview Technologies, Llc||Hybrid fiber-coaxial (HFC) cable communication systems having well-aligned optical and radio-frequency links to facilitate upstream channel plans having high aggregate data capacity|
|US8965700||Sep 28, 2009||Feb 24, 2015||Certusview Technologies, Llc||Methods and apparatus for generating an electronic record of environmental landmarks based on marking device actuations|
|US8977132||Sep 23, 2013||Mar 10, 2015||Certusview Technologies, Llc||Ingress-mitigated RF cable plants and ingress mitigation methods for same|
|US9019855||Nov 30, 2012||Apr 28, 2015||Certusview Technologies, Llc||Cable communication systems and methods employing TDMA/ATDMA QAM upstream channels below 20 MHz for increased upstream capacity to support voice and/or data services|
|US9086277||Feb 2, 2009||Jul 21, 2015||Certusview Technologies, Llc||Electronically controlled marking apparatus and methods|
|US9088310||Sep 9, 2013||Jul 21, 2015||Certusview Technologies, Llc||Cable communication systems and methods employing QAM upstream channels below 16.4 MHz for increased aggregate deployed upstream capacity|
|US9097522||May 25, 2010||Aug 4, 2015||Certusview Technologies, Llc||Methods and marking devices with mechanisms for indicating and/or detecting marking material color|
|US20100198663 *||Aug 5, 2010||Certusview Technologies, Llc||Methods and apparatus for overlaying electronic marking information on facilities map information and/or other image information displayed on a marking device|
|USRE41983||Aug 25, 2008||Dec 7, 2010||Tierravision, Inc.||Method of organizing and compressing spatial data|
|USRE44925||Apr 11, 2011||Jun 3, 2014||Transcenic, Inc.||Spatial referenced photographic system with navigation arrangement|
|EP1490836A1 *||Mar 19, 2003||Dec 29, 2004||Harris Corporation||Efficient digital map overlays|
|WO2000030033A2 *||Nov 17, 1999||May 25, 2000||Huelson Phillip W||Device and method for antialiasing high resolution pixel data for lower resolution display|
|U.S. Classification||345/428, 345/557, 345/531, 340/995.18, 345/611|
|International Classification||G06T15/00, G06F17/17|
|Cooperative Classification||G06T15/00, G06F17/175|
|European Classification||G06T15/00, G06F17/17M|
|Sep 29, 1997||FPAY||Fee payment|
Year of fee payment: 4
|Sep 28, 2001||FPAY||Fee payment|
Year of fee payment: 8
|Sep 29, 2005||FPAY||Fee payment|
Year of fee payment: 12