The present application relates to determining a spatial hierarchy of polygon data for representing images on a display device. More specifically, the application relates to a system and method for assigning polygon budgets, ranges, object sizes, etc., to a spatial hierarchy by using cube-root altitude scaling.
Computer generation of visual scenes is constrained by limitations in data storage and representation of objects in the scenes. A number of image rendering techniques have been proposed.
U.S. Pat. No. 4,715,005 describes a technique of computer generation of visual scenes of rolling terrain and seascape, using a database of math models. A mathematical formula determines the extent of terrain or sea that must be used to cover a portion of the display. The terrain and sea are modeled using sine waves. There is neither a description nor a suggestion of (i) using a polygonal representation and/or (ii) a hierarchical representation of the data (terrain). There is also no description or suggestion in U.S. Pat. No. 4,715,005 of adapting the technique described in the context of terrain and seascape therein to cultural features (such as buildings).
U.S. Pat. No. 5,367,615 describes spatial augmentation of vertices and continuous level of detail transition for smoothly varying terrain polygon density, in which the details are statistically derived. There is no description or suggestion in U.S. Pat. No. 4,715,005 of adapting the detail processing technique described in the context of terrain therein to cultural features (such as buildings). There also is neither a description nor a suggestion of deriving range rings mathematically.
The present application provides a system and method for determining a spatial hierarchy for polygon data. The method comprises, in accordance with one embodiment, obtaining a switching range, and determining a polygon density for the spatial hierarchy, by using the switching range and a cube-root scaling factor.
The method comprises, according to another embodiment, determining a cube-root scaling factor based on an altitude parameter, and using the cube-root scaling factor to scale level-of-detail switching ranges for the spatial hierarchy.
The methods may be embodied in a computer program (or some unit of code) stored on a computer readable medium, such as a compact disc (CD), and/or transmitted via a computer network, such as the Internet, or another transmission medium.
The application also provides a system for determining a spatial hierarchy for polygon data. In one embodiment, the system includes a user interface and a feature analyzer. The feature analyzer determines a polygon density for the spatial hierarchy by using (i) a cube-root scaling factor and (ii) a switch-in distance and switch-out distance obtained through the user interface.
The cube-root scaling factor may be determined based on an altitude parameter. The spatial hierarchy may be tile-based. The polygon data may corresponds to cultural feature.
Design parameters of the spatial hierarchy may be obtained and/or modified through the user interface. For example, one or more of the following may be obtained and/or modified through the user interface: a number of levels in the spatial hierarchy; an extent of tiles for each level of the spatial hierarchy; a critical size of polygonal elements to be inserted in each level of the spatial hierarchy; and a switching distance for tiles of each level of the spatial hierarchy.
The features of the present application may be more readily understood from the following detailed description by referring to the accompanying drawings wherein:
The present application provides new methodologies (for example, in the form of a system and methods) for determining a spatial hierarchy for polygon data for representing images on a display and/or output medium (such as conventional display and output devices). In the spatial hierarchy, the level-of-detail of a displayed feature varies according to the distance between an eyepoint and the feature.
A density computation method provided by the present application may be used, along with a feature prioritization method, to provide selection of source feature data and assignment of geometric models to specific levels-of-detail of the database. The methods provided by the present application may be used to maximize a feature content in a database without exceeding the capacity of the image rendering system. The methods also may be used to achieve a constant polygon density at any elevation. The methods may be adapted for, e.g., flight simulation/visual simulation/geographic database, system or software.
A system 110, in accordance with one embodiment shown in
A method, according to one embodiment of the present application, for determining a spatial hierarchy for polygon data will be described with reference to
A method, according to another embodiment of the present application, for determining a spatial hierarchy for polygon data will be described with reference to
A more detailed description of the system and methods for determining a spatial hierarchy for polygon data will now be provided.
Given a polygon budget, e.g., corresponding to the storage space in a database, an ideal polygon density on the ground (assumed to be flat) may be expressed as a function of an altitude of observation z, and the distance d to an eyepoint, as follows:
FOVh denotes a horizontal field of view, FOVu denotes an angle above the vertical line of sight, and FOVd denotes an angle below the vertical line of sight.
For a given (design) altitude z0, the equations above may be used to compute an (ideal) number of polygons that a polygon-tile may contain (depending upon the tile's switching range and extent).
When rendering at an altitude z significantly different from the design altitude z0, the polygon budget may be violated, e.g., very few polygons at high altitudes, and too many at low altitudes. This can be prevented by scaling level-of-detail (LOD) switching ranges with cube-root scaling, (z/z0)⅓.
1 Analysis in the Continuum
1.1 Area on the Ground Corresponding to a Horizontal Screen Band
To compute the polygon density, referring to
where FOVh denotes the horizontal field-of-view, p denotes the pitch angle zo the altitude of the eyepoint, and
The intermediate results are as follows:
Equation (1) can be greatly simplified by choosing a very small θ, thus achieving t<<tanp, for all pitches (since the existence of a far clipping plane implies that p has a lower bound), such that the following is true:
For computing a correct polygon density, when intersecting the horizontal field-of-view with the ground, the angle β is actually smaller than FOVh.
1.2 Polygon Density in the Continuum
To determine polygon density, a focal length is first determined from the vertical field-of-view parameters. As explained below, the number of vertical pixels that represent a given object is determined using the focal length.
Referring to
To infer density from Equation (1), the number of polygons n assigned to the horizontal screen band (angle θ) is divided with the area of Equation (1).
The following equation is obtained:
1.3 Density Fall-Off and Correction
The density in the center of the screen (line of sight) typically is larger than at the periphery. An equal-screen-area vertical band corresponds to a smaller angle at the bottom and top edges of the screen. The overall fall-off for the up field-of-view is as follows, and a similar equation holds for the down field-of-view:
The total vertical density fall-off is an average of Equation (3) for the up and down fields of view, weighted by (tanFOVu, tanFOVd). With equal screen length increments (t), the angle corresponding with a screen band reduces with the angle from the center of the screen from θ down to θ cos2ψ, as shown in
Referring now to
The polygon budget may be increased by dividing with the product of Equations (3) and (4). The maximum angle φ in Equation (4) is less than FOVh/2 for a deviation angle ψ from the vertical line of sight different from zero (the tangent of the maximum angle is multiplied by cosψ). Also, tiling artifacts may alleviate the horizontal fall-off. The density fall-off may be a beneficial phenomenon, assuming that the center of the screen deserves more detail.
2 Analysis for a Hierarchical Tiling System
2.1 Polygon-Density for a Tile
If (d1, d2) denotes the switching range of a tile, and z0 the design altitude, a suitable density for the tile may be computed by averaging the overall polygon contribution of Equation (2) for the ground area covered between d1 and d2, as follows:
Integrating over the ground range r is the same as integrating over the slant range (or distance) d, as shown by the following change of variables:
The polygon budget for the tile may be obtained by multiplying Equation (5) with the area of the tile.
Additive and substitutive tile hierarchies may be considered. In an additive tile hierarchy, the switch-out distance is zero for each tile. When children tiles switch in, they add to the polygon density. The parent is not switched out unless the distance to the tile center becomes larger than the switch-in distance for that tile.
In a substitutive hierarchy, when a tile switches out, the children tiles occupying the void left by the switched-out tile are forced to switch in, in substitution of the parent tile. It follows that only the switch-out information is used to determine visibility. The polygon density equation for a substitutive hierarchy is as follows:
where d1 is the switch-out distance of the tile and d2 is the “switch-in distance” (switch-out distance of the parent tile).
For an additive hierarchy, the same equation is used as a starting point, where d2 denotes the tile switch-in distance and d1 denotes the switch-in distance of the next smaller tile-set, and add to it the cumulative density of all larger tiles (because densities are being added).
2.2 Scaling the LOD Switching Ranges
To determine how the switching distances may be “transformed” to match the density curve for z0 with the density curve for z, a constant density is imposed on Equation (2), and the cube-root scaling is derived directly as follows:
Equating the altitude with the switch-in distance si after it was scaled, the maximum altitude at which a given tile is visible is obtained as follows:
Using cube-root scaling at altitudes significantly smaller than the smaller tile's switch-in radius may not be suitable under some circumstances. For example, cube-root scaling matches ideal density curves, and thus assumes that smaller tiles with yet higher densities are indefinitely available.
Also, once the altitude is smaller than some fraction of the smallest switch-in radius, all ground ranges increases only minimally when altitude decreases. The polygon counts thus stay approximately constant without scaling. For example, the second observation, the ground range r of the smallest tile may be plotted as a function of altitude as shown in
where si is the static (before scaling) switch-in radius of that tile. The altitude corresponding to the largest range, which is obtained by solving for the altitude that sets the derivative of r2 to zero, is as follows:
This altitude corresponds to a good clamping altitude for scaling. Below that altitude, scaling reduces polygon counts for all levels simultaneously, with no additional level to fill the gap.
2.3 Recommending Sizes for Objects Populating Each Set of Tiles
The user defines a MINPIX value, as well as a MAXPIX value, e.g., [1 pixel, 4 pixels]. MINPIX is the smallest size in (vertical) pixels (the channel does not necessarily use square pixels) that an object may be. MAPIX is the largest size in (vertical) pixels an object can be when it switches (or “pops”) in and out of the scene.
Consider the following:
The user may specify the ground range of the smallest tile, e.g., expressed in a factor of the tile's diameter. A number in the vicinity of three is a reasonable choice, which specifies that ten to twenty or so such tiles are visible. The design altitude z0 may be set to within this ground range, as described above. Scaling works better up than down (limitation of the smallest tile). However, the design altitude cannot be much smaller than this first ground range (providing some up-and-down scaling leverage before having to clamp scaling).
With z0 determined as described, the first switch-in distance can be determined. Subsequent switch-in distances can be set so as to have approximately the same polygon count in each tile (with potentially some tuning). For example, if the tiles double in size (as in a quad-tree), the density is divided by four, which occurs when multiplying the switch-in distance by (4)⅓≈1.6 [see Equation (2)].
Cube-root scaling matches exactly the (ideal) density curves at varying altitudes. In order to use a single scale for the entire polygonal database, the polygon-tiles may be designed at the same altitude and Equation (5) used, even if not all tiles are visible, to prescribe a density.
An exemplary embodiment is described below. The embodiment uses a spreadsheet to provide a user interface. It should be understood, however, that other types of user interface may be used also or alternatively. For example, the user interface may be one or a combination of standard, conventional or application specific graphical user interfaces. The user interface may also include voice interface features, which are also conventionally known and therefore not discussed in detail here.
3 Point Feature Density Analysis Tool
The Point Feature Density Analysis Tool (PFDA) may be provided for specifiing a tile-based spatial hierarchy for polygon data representing, e.g., cultural features. The information that may be specified includes the type of hierarchy (additive or substitutive), a number of levels in the hierarchy, an extent of tiles for each level of the hierarchy, and switching distances for tiles of each level. The specified information also may include polygon densities to be applied to each level, a LOD scaling function (which is a function of altitude), and a critical size (described below) of the polygonal elements to be inserted in each level. The PFDA provides a user interface and a feature analyzer. A Point Feature Selection and Allocation Tool (not discussed herein) optionally may be provided for assigning actual features to tiles of a culture hierarchy.
Critical size is the size of a feature as perceived on the display, or difference in sizes between two representations of the same feature. In general, this is the largest dimension of the feature, but other cases may apply depending upon the type of feature. Examples of some special cases include airports, radio towers and other “wireframe” features, and features that are particularly elongated. When substituting models, a measure of the difference between the two models is used.
Critical size is used to determine the range at which a model is appropriate in the scene. An extreme example is a model of a house with a textured picture of a door at a low LOD and a polygonal doorframe at a high LOD. The critical size of the high LOD is only ½ inch! Although the door is 7×3 feet, the frame of the door is only relevant when the observer is close enough to discriminate the ½ inch thickness of the door. Critical size is a modeling consideration, and can only be grossly approximated by algorithmic inspection of the model's geometry.
The PFDA may be implemented, according to one embodiment, as an Excel spreadsheet for analyzing point features (buildings, bridges, trees, etc.), but also may provide means for analyzing other visual elements. The PFDA may have a built-in validation step, by which visible tiles are interactively computed for a wide range of altitudes and lines of sight, to simulate how the polygon budget is utilized under various settings, assuming that recommendations for polygon counts per tile are followed.
Design definitions may be entered in cells N3-6. The user specifies the “minimum and maximum size of objects in a tile” (minpix and maxpix) parameters in cells N3-4. Minpix refers to how small any object can be at any time on the screen (generally, one pixel is a reasonable choice). Maxpix refers to how large an object can be when it “pops” in and out as its tile switches in or out. If an object is substituted with a different LOD of that object, then the visual difference between the two is what is measured. The polygon budget may be entered in cell N5. The maximum altitude for which minpix and maxpix are relevant may be entered in cell N6.
Tiling scheme definition may be entered via cells E13-20. The overall coverage size is specified in cells E13-14. The user may choose to divide it in any (integer) number of quad-trees in the x and y directions E15-16.
The number of quad-tree levels may be entered in cell E17, and typically is between 2 and 8. The number of valid levels also may be reflected in output sheets. More levels in the quad-tree yield smaller tiles at the highest LOD and thus also the opportunity for smaller features. This comes at the expense of increased cull depth and larger memory footprint for region files.
The number of tiles in the first range band (highest LOD) may be entered in cell E18, and is a parameter of particular interest. When increasing this number, all the range bands increase in size, following the first band. A finer granularity of the quad-tree is thus obtained, often corresponding to a more graceful matching of the polygon budget. This is obtained at the expense of lower polygon counts per tile, and a larger cull and switching load. Lowering this number causes tile switching to be more aggressive, and therefore increases the likelihood that levels of the hierarchy are skipped in substitutive designs. Quad-Tree simulation provides a visualization of this effect.
The “polygons per tile fall-off ratio” may be entered in cell E19, and used to control the number of polygons per tile for subsequent Quad-Tree LODs. When set to 1, it is approximately constant. When increased, the number of polygons per tile decreases and the sizes of the range bands decreases.
The type of hierarchy (additive=1, substitutive=0) is specified in cell E20. An additive hierarchy causes features to switch in and stay in as the observer approaches. In substitutive hierarchies, features are replaced with higher polygon count versions as the observer approaches. This selection has a major impact on the way density is distributed throughout the scene and the type of models that are used. Quad-Tree simulation provides a visualization of this effect.
A summary of outputs (rows 24 through 35) may be provided on the Input sheet (see
Cells P27-Q34 show actual polygon budget for each tile and actual density in number of polygons per 1 km square. Using the inputs the user may determine what cumulative density is reasonable. Decreasing the number of Quad-Tree levels (E17), decreases significantly the density of the highest level. Increasing the number of quad-trees in the coverage (E15:16) increases this density. Increasing the number of tiles in the range band of the highest level (E18) decreases the density and the polygons per tile. Increasing polygons per tile fall-off ratio (E19) only affects the polygons per tile of the subsequent levels (lower than highest level), but not the polygon count and density of the highest level.
Cells R27-T34 show recommended minimum and maximum object sizes for each tile, based upon the information input in cells N3:N4. If the minimum size exceeds the maximum size, Min>Max appears in the T column. The size distribution is satisfactory if “Min>Max” does not occur, if the range of sizes match the user's data, and if the gaps are not too wide between tiles. Increasing the number of Quad-Tree levels provides a larger distribution and smaller sizes. Increasing the number of Quad-Trees per coverage decreases the sizes globally. Increasing the polygons/tile fall-off ratio may eliminate Min>Max problems, at the expense of fewer polygons in the larger tiles. The same applies to increasing the number of tiles in the range band of the highest level. Again, after changing any of these, the user may press the Quad-Tree Simulation button to validate the new culling load and number of visible tiles.
To validate the number of visible tiles of each type and the number of visible polygons for a given altitude, the Quad-Tree macro may be activated by pressing the “Run QuadTree Simulation” button in cells K25-L25. A graphical display of the visible tiles for the chosen altitude (N9) and line of sight (N10) is then produced in the Output-QuadTree sheet (
Cells K27-L31 show a summary of the validation/simulation, including a measure of the LOD culling (L28) and frustrum culling (L29) load. The number of visible tiles (L30) and polygons (L31) also may be provided. The number of polygons indicated in cell L31 correspond approximately to the budget, depending upon the altitude (N9), vertical line of sight (N10) and eyepoint location (N12-13). After any change of input data, the “Run QuadTree Simulation” button is activated, so that these numbers may be updated. They are based upon counting visible tiles in the simulation, and do not represent what an actual scene graph may provide.
More detailed output information may be supplied on other sheets, as shown for example in
Outputs in the Output-TileDesign Sheet (
When Quad-Tree validation is performed (triggered by depressing the “Run QuadTree” button in the Input Sheet), validation output is provided, including culling and LOD switching loads (G2,G3), visible tiles (F11-19) and visible polygon counts (I11-19). These visible tiles and polygons are computed using the simulation, but are NOT used for density computations (a general equation is used instead). They depend upon the viewing parameters (altitude, pitch angle, eyepoint x and y locations). The simulation performs tile culling only, as opposed to precise view-frustrum culling. Also, the viewing frustrum may be larger than the working space of the simulation. Therefore, the input polygon budget is not exactly matched in cell 119. Further, the simulation assumes that exact polygon counts (G11-18, or H11-18 when the user decides to override) are applied to each tile, as shown by an artifact of aggregating features into geographic tiles. Varying the simulation's eyepoint location result in aliasing effects in the tile culling process. “Dynamic culture scaling” is enabled within the scaling module.
Outputs in the Output-FeatureSizes Sheet (
The upper table (B4-I11) applies to other LODs. The user specifies the appropriate LOD number in cell D2. The chart to the right illustrates the minimum and maximum feature critical sizes corresponding to the upper table.
The Output-QuadTree sheet (
The above specific embodiments are illustrative, and many variations can be introduced on these embodiments without departing from the spirit of the disclosure or from the scope of the appended claims. Elements and/or features of different illustrative embodiments may be combined with each other and/or substituted for each other within the scope of this disclosure and appended claims.
For example, additional variations may be apparent to one of ordinary skill in the art from reading U.S. provisional application Ser. No. 60/279,181, filed Mar. 27, 2001, which is incorporated herein by reference.
This application claims the benefit of co-pending provisional application Ser. No. 60/279,181, filed Mar. 27, 2001 and entitled “SYSTEM AND METHOD FOR ASSIGNING POLYGON BUDGETS, RANGES AND OBJECT SIZES TO A SPATIAL HIERARCHY USING CUBE-ROOT ALTITUDE SCALING.”
Number | Date | Country | |
---|---|---|---|
60279181 | Mar 2001 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10648144 | Aug 2003 | US |
Child | 10873716 | Jun 2004 | US |
Parent | 10307737 | Dec 2002 | US |
Child | 10648144 | Aug 2003 | US |
Parent | 10112500 | Mar 2002 | US |
Child | 10307737 | Dec 2002 | US |