WO2000013146A1  System and method for interactively displaying a model having a complex surface  Google Patents
System and method for interactively displaying a model having a complex surface Download PDFInfo
 Publication number
 WO2000013146A1 WO2000013146A1 PCT/US1999/019024 US9919024W WO0013146A1 WO 2000013146 A1 WO2000013146 A1 WO 2000013146A1 US 9919024 W US9919024 W US 9919024W WO 0013146 A1 WO0013146 A1 WO 0013146A1
 Authority
 WO
 WIPO (PCT)
 Prior art keywords
 surface
 eye
 means
 point
 super
 Prior art date
Links
 238000007781 preprocessing Methods 0 abstract claims description 20
 238000009877 rendering Methods 0 abstract description 52
 230000002452 interceptive Effects 0 abstract description 17
 238000009966 trimming Methods 0 claims description 16
 238000000034 methods Methods 0 description 19
 239000000047 products Substances 0 description 15
 239000010410 layers Substances 0 description 14
 238000004422 calculation algorithm Methods 0 description 13
 238000005070 sampling Methods 0 description 11
 239000000470 constituents Substances 0 description 8
 230000000875 corresponding Effects 0 description 7
 230000001976 improved Effects 0 description 6
 238000010276 construction Methods 0 description 5
 230000001965 increased Effects 0 description 5
 230000036961 partial Effects 0 description 5
 230000002104 routine Effects 0 description 5
 230000003068 static Effects 0 description 5
 230000001131 transforming Effects 0 description 5
 230000015654 memory Effects 0 description 4
 230000001419 dependent Effects 0 description 3
 TVMXDCGIABBOFYUHFFFAOYSAN Octane Chemical compound   CCCCCCCC TVMXDCGIABBOFYUHFFFAOYSAN 0 description 2
 239000011159 matrix materials Substances 0 description 2
 230000001603 reducing Effects 0 description 2
 239000010703 silicon Substances 0 description 2
 230000007958 sleep Effects 0 description 2
 239000007787 solids Substances 0 description 2
 239000002344 surface layers Substances 0 description 2
 230000001360 synchronised Effects 0 description 2
 238000000844 transformation Methods 0 description 2
 239000006244 Medium Thermal Substances 0 description 1
 238000007792 addition Methods 0 description 1
 239000000872 buffers Substances 0 description 1
 239000011203 carbon fibre reinforced carbon Substances 0 description 1
 230000015556 catabolic process Effects 0 description 1
 238000004891 communication Methods 0 description 1
 230000004059 degradation Effects 0 description 1
 238000006731 degradation Methods 0 description 1
 238000009826 distribution Methods 0 description 1
 230000000694 effects Effects 0 description 1
 238000006062 fragmentation Methods 0 description 1
 238000003780 insertion Methods 0 description 1
 230000003993 interaction Effects 0 description 1
 230000000750 progressive Effects 0 description 1
 230000002829 reduced Effects 0 description 1
 238000006722 reduction reaction Methods 0 description 1
 230000004044 response Effects 0 description 1
Classifications

 G—PHYSICS
 G06—COMPUTING; CALCULATING; COUNTING
 G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
 G06T15/00—3D [Three Dimensional] image rendering
 G06T15/10—Geometric effects
 G06T15/40—Hidden part removal
Abstract
Description
SYSTEM AND METHOD FOR INTERACTIVELY DISPLAYING A MODEL HAVING A COMPLEX SURFACE
BACKGROUND OF THE INVENTION
1. Field of the Invention
The present invention relates to an improved display system and, more specifically, it relates to a system for interactively displaying a model and, most specifically, is particularly advantageous in interactively displaying a geometric model having a complex surface from a plurality of eyepoints. The invention also relates to an improved display method.
2. Description of the Prior Art
NonUniform Rational BSpline (NURBS) surfaces are routinely used to represent largescale models (e.g. , without limitation, geometric models representing automobiles, submarines, airplanes, building architectures, sculptured models, mechanical parts, other models for applications involving surface fitting over scattered data or surface reconstruction) for computer graphics, geometric modeling, computeraided design (CAD), computeraided manufacturing (CAM), visualization, and animation applications. Many applications like interactive walkthroughs and design validation need to interactively visualize these complex surface models.
This class of representation includes tensorproduct and triangular Bezier surfaces. Often these surfaces are approximated with triangles for efficient display on current graphics systems. Bezier surfaces defined over a triangular domain are often called Bezier triangles. Bezier triangles were later generalized to tensorproduct surfaces. The theory of triangular NURBS is disclosed by W. Dahmen, et al., Blossoming begets Bspline bases built better by Bpatches, Mathematics of Computation, 59(199):97115, 1992.
In order to exploit recent advances in triangle rendering capabilities of graphics systems, it is common to generate a onetime polygonal approximation of the surfaces of a model and discard the analytic representation. Unfortunately, such polygonal approximations require an unduly large number of polygons, thereby necessitating the need for polygon simplification. What is more, due to discretization of geometry, even a dense tessellation is sometimes inadequate for zoomed up views. On the other hand, recent advances in efficient tessellation of surfaces allows the dynamic generation of an appropriate number of triangles from the analytic representation based on the user's location or eyepoint in a virtual environment. Curved surface rendering has been an active area of research for more than two decades. A number of techniques for rendering splines based on polygonization, ray tracing, scanline conversation and pixellevel subdivision have been proposed. The fastest known algorithms are based on polygonization. Algorithms based on viewdependent polygonization have been proposed to render spline surfaces. However, the fastest algorithms and systems can only render models composed of a few thousand spline patches at interactive rates on highend graphics systems (e.g. , SGI Onyx with a Reality Engine^{2} graphics accelerator). None of these approaches are suitably efficient on current graphics systems. In order to exploit fast triangle rendering hardware, recent research has focussed on generating polygonal approximations of surfaces. See, for example, S. Kumar, et al. , Interactive display of large NURBS models, IEEE Transactions on Visualization and Computer Graphics, 2(4):323336, Dec. 1996.
A onetime static tessellation of many real world models usually requires the generation of millions of triangles. Most current graphics systems are not able to render these many triangles at interactive speeds (e.g. , more than about 510 times a second).
A number of surface simplification schemes have recently been proposed that speed up polygonal rendering. See, for example, J. Cohen, et al. , Simplification envelopes, Proc. ACM SIGGRAPH, pp. 11928, 1996; M. Garland, et al. , Surface simplification using quadric error metrics, Proc. ACM SIGGRAPH, pp. 20916, 1997; and H. Hoppe, View dependent refinement of progressive meshes, Proc. ACM SIGGRAPH, 1997.
The prior approaches often require management of large amounts of data and are still unable to generate more detail than the initial tessellation. Moreover, it seems unnatural that in order to render surfaces, one first generates a large number of triangles and then finds a way to reduce the count.
On the other hand, efficient techniques for dynamic surface tessellation have made it possible to approximate surfaces with a small number of triangles in the first place. See, for example, A. Rockwood, et al. , Realtime rendering of trimmed surfaces, ACM Computer Graphics, 23(3): 107117, 1989; S. AbiEzzi, et al., Tessellation of curved surfaces under highly varying transformations, Proceedings of Eurographics, pp. 38597, 1991; S. Kumar, et al. , Interactive display of large NURBS models; and S. Kumar, et al., Accelerated walkthrough of large spline models, Proc.
Symposium on Interactive 3D Graphics, pp. 91101, 1997.
S. Kumar, et al., Accelerated walkthrough of large spline models, discloses surface simplification. Most surface triangulation algorithms produce at least two triangles for each tensor product Bezier patch. Furthermore, each trimming curve must be tesselated into at least one edge and this adds further to the triangle count.
For example, a relatively small part like a "Utah teapot" consists of 32 Bezier patches.
However, 64 triangles are not required to represent it when its size is, say, a few pixels on screen. As part of preprocessing, polygonal simplifications of a mesh of trimmed Bezier patches are computed. Adjacent surfaces are combined and polygonal approximations for supersurfaces are computed. For a supersurface with n Bezier patches, polygonal simplifications with less than 2n triangles are generated. Surface patches and their simplifications are represented using spatial hierarchies. Given a viewpoint, an appropriate polygonal approximation is computed based on surface simplification and incremental triangulation. Since two adjacent supersurfaces may be rendered at different detail, algorithms prevent cracks between these super surfaces. Algorithms which approximate surfaces with a small number of triangles provide much finer control on the update of detail as compared to approaches which reduce the count of the triangles as in J. Xia, et al. , A dynamic viewdependent simplification for polygonal models, Proc. IEEE Visualization, pp. 32734, 1996; and
H. Hoppe, View dependent refinement of progressive meshes. Accordingly, the dynamic tessellation approach also promises to be more scalable and efficient, in general.
A combination of online tessellation (for highdetail objects) and off line tessellation combined with multiple levels of detail (for lower detail objects) has also been used (see S. Kumar, et al. , Accelerated walkthrough of large spline models). While model sizes in new applications will continue to grow, the representation for a model that must be processed every frame need not grow linearly.
In other words, more information may be compressed in a small number of higher order primitives like surfaces and supersurfaces (see S. Kumar, et al. , Accelerated walkthrough of large spline models). For these reasons, there remains a very real and substantial need for an improved system for interactively displaying a model having a complex surface at still faster speeds.
SUMMARY OF THE INVENTION The present invention has met this need by providing a system for interactively displaying a model having a complex surface. The system comprises: means for preprocessing the model to provide a plurality of surface primitives; means for displaying the model with respect to a first eyepoint of a plurality of eyepoints and for selecting a second eyepoint of the eyepoints for display of the model with respect to the second eyepoint; means for providing a value for each of the surface primitives with respect to the first eyepoint; means for selecting surface primitives for display with respect to the second eyepoint as a function of the first and second eye points and the value with respect to the first eyepoint for each of the surface primitives; means for tessellating each selected surface primitive to provide a plurality of triangles or trianglestrips representative of the selected surface primitive with respect to the second eyepoint; and means for displaying the triangles or triangle strips to display the model with respect to the second eyepoint.
As another aspect of the invention, a method interactively displays a model having a complex surface. The method comprises: preprocessing the model to provide a plurality of surface primitives; displaying the model with respect to a first eyepoint of a plurality of eyepoints; selecting a second eyepoint of the eyepoints for display of the model with respect to the second eyepoint; providing a value for each of the surface primitives with respect to the first eyepoint; selecting surface primitives for display with respect to the second eyepoint as a function of the first and second eyepoints and the value with respect to the first eyepoint for each of the surface primitives; tessellating each selected surface primitive to provide a plurality of triangles or trianglestrips representative of the selected surface primitive with respect to the second eyepoint; and displaying the triangles or trianglestrips to display the model with respect to the second eyepoint. The invention will be more fully understood from the following detailed description of the invention on reference to the illustrations appended hereto. BRIEF DESCRIPTION OF THE DRAWINGS
Figure 1 is a software block diagram illustrating three separate layers of an interactive display library in accordance with the invention;
Figure 2 is a hardware block diagram illustrating four separate processors for use with the interactive display library of Figure 1 ;
Figure 3 illustrates a triangular domain and bary centric coordinates; Figures 4A4C illustrate a supersurface hierarchy in which three levels of the hierarchy of a "Utah teapot" are represented;
Figure 5A shows a supersurface construction for a uniform tessellation (dashed lines) of a single supersurface in its domain;
Figure 5B shows four adjacent supersurfaces and their constituent patches;
Figure 6 shows a backpatch computation in which the bounding volume of a patch defines a backspace such that if the normal direction lies entirely in the backspace, then all points on the patch are back facing;
Figures 7A7C illustrate triangulation in the triangular domain; Figure 8 is a plot of model size versus average memory size per patch; Figure 9 is a plot of model size versus average time to render; Figure 10A is a flowchart of a visibility test in accordance with the invention; and
Figure 10B is a flowchart of a tessellation test in accordance with the invention.
DESCRIPTION OF THE PREFERRED EMBODIMENTS
Referring to Figure 1, an interactive display library 1 is divided into three exemplary layers including a systems layer 2, a surface layer 4 and a utility layer
6. The exemplary library 1 interactively displays models with trimmed NURBS surfaces. The library 1 includes a suite of algorithms and is based on dynamic triangulation of groups of surface primitives.
The five major components of the library 1 are: (1) surface pre processing as provided by the model hierarchy manager 7 of the systems layer 2, and the surface triangulator algorithm 8 and the trimming curve processor algorithm 10 of the surface layer 4; (2) pipeline management provided by the pipeline manager 12; (3) visibility computation by the visibility thread 14; (4) tessellation by the tessellation thread 16; and (5) triangle rendering by the rendering thread 18.
Referring to Figures 1 and 2, the pipeline manager 12 monitors the performance of the processors 20,22,24,26 and the graphics board 27 to tune the system for performance improvement. The library 1 provides users with the ability to configure the rendering pipeline based on the available hardware (i.e. , the number of processors and the quality of the graphics board). It will be appreciated that while reference has been made to the exemplary four processors 20,22,24,26, a wide range and count (e.g. , 1 or more) of other processors such as, for example, mainframe computers, minicomputers, workstations, personal computers, microcomputers, and other microprocessorbased computers, central processing units (CPUs) or networked processors may be employed.
The library 1 incorporates all software components of a surface display system except the application program 43 and user interface (e.g. , OpenGL layer 28), for efficient rendering of parametric surfaces. The library 1 may be used to read a list of tensorproduct or triangular NURBS or Bezier surfaces and render them. The internal representation is based on the Bezier form. More importantly, the library 1 seamlessly integrates the different algorithms to obtain rendering speeds not obtained before. In addition, the library 1 performs runtime performance monitoring to dynamically rearrange the surface rendering pipeline.
Each module, M_{a}, of the library 1 is preferably designed such that if it needs the results of another module, M_{b}, the appropriate data structures of M_{b} are accessible in its local space. If M_{b} is disabled, M_{a} can be configured to either disable itself automatically or enable M_{b} via a callback. The library 1 also provides support for multiprocessor systems. A lockfree synchronization scheme (see S. Kumar, et al. , Scalable algorithms for interactive visualization of curved surfaces, Super computing, 1996) is employed to reduce the number of system calls needed for mutual exclusion by appropriately ordering readwrite operations.
A function in any of the layers 2,4,6 has access to all functions in the layers below it. However, most calls are only to functions in the layer immediately below. Functions in the system layer 2 typically call other functions of that layer via callbacks. The current scheme provides a number of plugin opportunities for exploring tradeoffs via function pointers. To avoid the overhead associated with function pointers, the library 1 also allows hardwiring of function calls using conditional compiling.
As a part of preprocessing by the model hierarchy manager 7, a hierarchical representation of the model is generated, adjacencies between surfaces are computed, and surface properties like maximum magnitudes of derivatives and bounds on Gauss map are generated. NURBS representation is also converted to Bezier at this stage. Complex Bezier surfaces are further subdivided into simpler parts, as well. Adjacent Bezier patches are hierarchically combined into supersurfaces as discussed below in connection with Figures 5A5B. The pipeline manger 12 functions like a job scheduler, except jobs are not separate processes. The default initial order of jobs may be changed via calls to library routines. This order dynamically changes at rendering time when a system bottleneck is discovered. In order to keep the system stable, reconfigurations are not performed unless a bottleneck persists. Also, the application program 43 in the applications layer 29 may disable the dynamic reconfiguration altogether.
The library 1 employs the visibility thread 14 to determine the visibility of surface primitives (e.g. , Bezier patches or supersurfaces). A visibility primitive is the smallest entity which may be deemed by the library 1 to be visible or invisible. A visibility primitive is a node in the hierarchical representation of the model. Not all surface primitives need be at the same level at a time. For example, one surface primitive could be a single Bezier patch, while another is a supersurface (i.e. , a collection of patches). The library 1 includes a variety of viewfrustum and backpatch culling routines. Different types of bounding box hierarchies are available and one (or more) of them may be activated. Additionally, the application program 43 may provide its own visibility processor.
The tessellation thread 16 triangulates one surface primitive at a time. The library 1 tessellates a surface primitive based on a number of different quality constraints (as discussed below in connection with Figures 5A5B and 6), one or more of which may be enabled. Using the current viewing parameters and the stored surface properties (generated by the model hierarchy manager 7), the library 1 computes the sampling size required for each surface primitive. These samples are subsequently triangulated in a crackfree manner. The library 1 directly generates trianglestrips, using an incremental algorithm that exploits coherence. The triangle rendering thread 18 is the interface to the OpenGL layer 28. It passes trianglestrips to the graphics board 27. The exemplary embodiment employs OpenGL, although it can easily be modified for a wide variety of other graphics standards (e.g. , without limitation, DIRECT3D, PHIGS). Any of the foregoing five major components may be turned on or off.
The exemplary library 1 renders more than 50,000 tensorproduct and triangular Bezier patches up to 5 times a second on the exemplary Onyx2 30 which employs the four processors 20,22,24,26 and the exemplary InfiniteReality graphics board 27. The library 1 also outperforms simple triangle rendering on a variety of other platforms such as, for example, without limitation, Silicon Graphics O2 employing IRIX (i.e. , a version of Unix), INDIGO2 Extreme, Octane, other Onyx systems, and PCs running System V or BSD Berkeley Unix, Windows 98 or Windows NT. The library 1, CPU 30 including OpenGL layer 28, and application program 43 form a system 44 for interactively displaying a model having a complex surface. Referring to Figure 3, a triangular domain and bary centric coordinates are illustrated. A rational tensorproduct Bezier patch, F(u,v), of degree m x n, defined for (u,v) £ [0,1] x [0, 1], is specified by a mesh of control points, p_{y}, and their weights, w„: m n
¥(u, v) = ^2 (1)
wherein 0 < i < m; 0 < j < n; and the Bernstein function is:
^{β}» = O '(I ^{"}")"
The normal direction is given by N(w,v) = F„ x F_{v}, where F„ and F_{v} are the partial derivatives of F(u,v).
The library 1 employs the barycentric coordinates of the domain triangle as shown, for example, by the triangle abc of Figure 3. Each point on the domain is represented by three coordinates, u, v, and w. The coordinates of a point q are: _{u =} A(q,b, ) _{v =} A(a,q,c) ^ _{=} A(a,b,q) Q)
A (a,b,c) ' A(a,b,c)' A (a,b,c)
wherein A is the area function; and u + v + w = 1, and, hence, there are only two independent variables A triangular Bezier patch of degree n is given by:
wherein U is a point on the domain represented by some (u,v,w); I is a vector of three numbers (ij,k);
\ I \ = i + j + k;
i + j + k = n;
Σ is over enumeration of (ij,k) that sum to n (i.e. , i+j+k = );
P_{J} is a control point; and w, is the weight of the control point
The control points pj form a triangular mesh of control points. The three boundary curves of a triangular Bezier patch, «=0, v=0, and w—0, are all
Bezier curves. Instead of partial derivatives with respect to the two axes of the rectangular domain, directional derivatives are computed. The cross product of two directional derivatives produces the normal direction at a point on the surface.
The directional derivatives of a Bezier surface are also triangular Bezier surfaces themselves. In general, the polynomial derivative in the direction d' = (d,e ) is:
wherein q_{t} = [dw_{I+el}p_{I+e}ι + ew_{I+e2}p_{I+e2} + fwι_{+e3}p_{1+e3}]; el = (1,0,0); e2 = (0,1,0); and e3 = (0,0,1) In particular, the derivatives along the u, v and w axes, respectively, are:
D_{U}(P(U)) = n (6)
wherein the quotient rule for derivatives of rationals is employed As employed by the library 1 during rendering, "supersurfaces" are a dynamically selected collection of patches, rather than a static cluster as shown by the prior art. The exemplary library 1 tessellates supersurfaces at rendering time and treats them as first class primitives, thereby obtaining a better control on the triangulation generated for interactive update of the frames. In addition to reducing the complexity of crackprevention, this parametric scheme also allows the library 1 to build a hierarchy of supersurfaces. The library 1 performs simplification of a small number of surfaces directly, as opposed to that of a potentially large number of polygons.
While S. Kumar, et al. , Interactive display of large NURBS models, and S. Kumar, et al. , Accelerated walkthrough of large spline models, report that the most expensive operation in their system is testing if the tessellation of a surface patch needs to change from the current frame to the next, the exemplary library 1 improves the performance of this test by using a fractional condition framework. Instead of executing the loop "for each patch, if processing needed, then process patch", the library 1 computes the change required in viewing parameters to warrant reprocessing of a given surface primitive. Note that the viewing parameter changes just once a frame. In this manner, the library 1 reduces both the time for testing if a surface primitive is visible, and the time for testing if the surface primitive needs re tessellation. Other important contributions of the library 1 include: (1) dynamic supersurface construction and tessellation; (2) computation of patch adjacencies and construction of a hierarchial surface representation; (3) an improvement of the back patch culling algorithm of S. Kumar, et al., Hierarchical visibility culling for spline models, Proc. Graphics Interface, pp. 14250, 1996; (4) triangle reduction when trimming curves are specified in a piecewise linear form; (5) extension of algorithms for tensor product Bezier surfaces to triangular Bezier surfaces; and (6) crackfree tessellation of models with both triangular and tensorproduct surfaces (also, a simple extension of the triangular scheme works for Spatches with nsided domains as well) . As shown in Figures 4A4C, a supersurface hierarchy in which three levels of the hierarchy of the exemplary "Utah teapot" are represented. Each super surface is colored in a single color. Figure 4C is the highest level, Figure 4B is the intermediate level, and Figure 4 A is lowest level of the exemplary hierarchy.
The input to the library 1 is specified as an unordered list of triangular Bezier or NURBS surface patches. Optionally, each surface patch may include trimming curves specified in Bezier, NURBS, or piecewise linear forms. While representing smooth curves as polygonal chains is contrary to the exemplary design of the library 1 , many real world models do maintain a dense sampling of trimming curves. For example, constructive solid geometry modelers generate curves of intersection as the trimming curves. It is often not possible to find an exact rational parametrization of these curves in the domains of the corresponding intersecting surfaces.
NURBS curves and surfaces are subdivided into Bezier form using knot insertion as shown by G. Farin., Curves and Surfaces for Computer Aided Geometric Design: A Practical Guide, 1993. Additionally, each Bezier trimming curve is also subdivided at patch boundaries. For the following, the input to the library 1 is assumed, for convenience of description, to be in the Bezier form.
Referring to Figures 5A5B, the supersurface construction of Figure 5 A shows a uniform tessellation (dashed lines) of a single supersurface 31 in its domain. Domains of its exemplary eight constituent patches are marked with solid lines in Figure 5A. Figure 5B shows four adjacent supersurfaces 32,34,36,38 and their constituent patches (e.g. , each of the supersurfaces 32,34 has 6 patches). Special points are marked in bold. For each Bezier surface, the model hierarchy manager 7 precomputes the bounding boxes of its Gauss maps and the maximum magnitudes of its partial derivatives. Such data are termed surface properties herein. The volume of the bounding box of a Gauss map is referred to as its magnitude. Each complex Bezier surface is subdivided. The complexity of a Bezier patch, F, is defined as complex by the following algorithm:
First, subdivide F into F, and F_{2}, at u (or v) = 1/2.
Next, if:
λ _{<} l^^' l < _{2} (9,
2 T(F) ' wherein T denotes a property; and i £ {1,2} then, output F since it is notcomplex.
Otherwise, since F is complex, output F, and F_{2}. The library 1 performs uniform subdivision of the domain. This subdivision of complex patches ensures that the simpler half is not overtessellated to satisfy quality constraints on the complicated half.
Before the library 1 constructs the surface hierarchy, it derives adjacencies between surface patches. The library 1 employs an extension of the scheme proposed in G. Barequet, et al., Repairing CAD models, Proc. IEEE Visualization, pp. 36370, 1997. If boundary control polygons pj and p_{2} of patches P, and P_{2}, respectively, match exactly, then the library 1 draws an edge between P_{!} and P_{2} in the adjacency graph. Otherwise, if the curves do not match exactly, then the library 1 employs an adjacency score (based on relative distances to neighboring boundary curves) to assign adjacencies.
The surface hierarchy is constructed in a bottomup fashion. At each level, , the library 1 employs a technique similar to S. Kumar, et al. , Accelerated walkthrough of large spline models, to construct a supersurface (i) . First, grow super surfaces (i1) into larger supersurfaces (i). Then, continue to merge adjacent super surfaces of level 1 until the number of supersurfaces reduces approximately by a factor of log: _{! r x /}_{M} i I [super surf ace(iY)Λ j ,_{1 Λ}>
I [super surface(ι)] I ≤ ^  — — —  (10)
U_{k} log [super surface(iT \
wherein U_{k} is a small constant (e.g. , 2)
Mergers between candidate pairs of supersurfaces proceed in the order of increasing relative difference in the magnitude of their properties. In practice, the library 1 typically constructs about five to eight levels for the best performance. More levels only add extra overhead. At rendering time, this hierarchy is traversed. Based on the viewing parameter, a supersurface is either further expanded, or else is output as a primitive for subsequent tessellation and rendering.
The properties of a supersurface are obtained by a union of the properties of the component surfaces. Note that when supersurfaces are merged, their trimming curves with overlapping edges are also merged. Since not all supersurfaces are tessellated at the same level, it is important to maintain a valid representation of the boundary curves between supersurfaces. In particular, there are special points on the boundary curves of a supersurface that must be included in any sampling: points adjacent to more than two supersurfaces are special points. These are exactly the domain corners, such as 40,42, of the supersurfaces of Figure 5B.
S. Kumar, et al. , Accelerated walkthrough of large spline models, discloses a technique to combine adjacent Bezier patches into supersurfaces. Each supersurface is triangulated and various levels of detail (LODs) (see J. Cohen et al. , Simplification envelopes) of the triangulation are generated. At rendering time, the appropriate level of detail is displayed for each supersurface based on its distance from the viewer. If the highest level of detail of a supersurface is insufficient, then each Bezier patch of the supersurface is triangulated separately. Extra processing is required to prevent cracks between supersurfaces at different levels of detail.
Incremental tessellation and rendering of Bezier patches is discussed in S. Kumar, et al. , Interactive display of large NURBS models. In brief, referring to
Figure 6, viewfrustum and backface culling are first performed, after which, by using the bounding volume of a Bezier patch, F, the backspace, an open cone S_{B}, is computed. If N = F_{u} x F_{v} is contained in the backspace S_{B}, then F is backfacing. It will be appreciated that this approach uses bounding volumes for both F and N, while, as discussed below in connection with Equations 1114 and the fractional condition test, the library 1 reduces this to just one bound and improves the accuracy of the test.
Continuing to discuss the prior incremental tessellation and rendering of Bezier patches, the sampling is tested to satisfy one or more of the screenspace quality constraints: bounded triangle size, bounded normal deviation, bounded surface deviation, and bounded normal difference. The number of samples needed is computed as s_{F}(B_{F}) x ^(F), where s_{F} is the scaling factor for the bounding box of F and T(F) is a precomputed property of the surface. The scaling factor is the maximum ratio between any unit vector in B_{F}, and its projection onscreen. Finally, if a sampling different from the previous frame is required, the interior of the patch and the boundary curves are resampled and the new set of samples are incrementally retriangulated. While the prior art shows that up to 30% of processor time is spent in computing s_{F} at rendering time, as discussed below in connection with the improved backpatch computation, the library 1 reduces this time. For the improved backpatch computation disclosed herein, a rational
Bezier function, F(«,v), is denoted as ■ ' . For simplicity of presentation, the w(u,v)
parameters (u,v) are eliminated from the subsequent disclosure, as they are implicit from the context. A Bezier patch, F, is backfacing if:
N*(FE) > 0 (11) wherein N = F_{u} x F_{v} for all (u,v) £ [0, 1] x [0, 1]; and
E is the eyepoint as determined by application program 43 of Figure 1
In turn, the application program 43 displays a model with respect to the eyepoint E and, then, selects another eyepoint E' to display the model with respect to that eye point E'. The exemplary visibility test may also be written as:
NF > N»E (12) wherein F = f/w is set forth in Equation 1 ; N . E = F.. x E. . F (13)
MT W w
F x F . F = ^{Wf}" ^{X fv " Wv f}" ^{X f}  ^{W« f x fv} I _{=} f^{u x} f^{v} f. _{(14)} w^{3} w _{w} ^{3}
/„ is δ_{/} δ«; f is δ/7δv; w„ is δw/δu; and w_{v} is δw δv Therefore, if F is an m x n rational Bezier patch, and Ν is a 3m x 3n rational Bezier patch, then Ν*F is a 3m 1 x 3nl rational Bezier patch. At rendering time, the library 1 checks if N*Ε is greater than m_{F}, a precomputed surface property equal to the minimum value of N^{«}F, such that the test of Equation 12 is safely met. This test can be performed if py*E is greater than m_{F}, where py are the control points of rational Bezier patch N. In practice, the library 1 just tests against the bounding box of the control points. Since the library 1 precomputes the exact m_{F} and employs a bound just once in the exemplary technique, this visibility test is about 20% more accurate in practice than that of known previous attempts.
It will be appreciated that both the test if a Bezier patch is visible and the test if a patch needs to be retesselated are applicable directly to supersurfaces.
In particular, the precomputed surface visibility property, m_{P}, for any supersurface, P, is the minima of m_{F} of all its constituent patches. Similarly, the scaling factor, s_{P}, of a supersurface, P, is the maxima of the scaling factors, s_{F}, of all its constituent patches. The bounding volume of N is the union of the bounding volumes of all the constituent patches. Hence, the library 1 does not need to compute an analytical representation for a supersurface.
To perform an n_{u} x n_{v} tessellation of a supersurface, P, the library 1 simply considers the union of the domains of all its constituent patches, arranged in an arbitrary plane as shown in Figure 5A. Each sample point of P is contained in exactly one of the constituent domains. The library 1 employs the representation of the corresponding patch to raise the sample to the three dimension Euclidean space (M^{3}). Again, boundary curves are tessellated separately. Triangulation between the interior of a supersurface and the boundary curves continues to be a planar triangulation just as in the simple Bezier patch case. The rest of the algorithm remains the same.
As mentioned earlier, two of the most important operations in prior art surface rendering are the tests: (1) whether a primitive, P, is visible; and (2) whether the current sampling of P is sufficient. As compared to these prior tests, the library
1 introduces a significant speedup by changing the "whether" to "how much". Instead of Boolean answers, the library 1 employs a fractional response and, hence, expresses "visibility" and "retessability" as real numbers. In this manner, a high magnitude of the visibility value, d_{v}, of a surface primitive implies that it is highly invisible and need not be retested for small changes to the eyepoint (e.g. , viewpoint) as provided by application program 43. Similarly, a high magnitude of the retessability value, d,, of a surface primitive implies that the primitive need not be retested for small changes in the eyepoint.
The visibility value, d_{v}, of a surface primitive, P, is defined as the minimum distance the eyepoint must move until visibility of P needs to be recomputed. If the eyepoint moves less than d_{v}(P), then P continues to be either visible or hidden.
Retessability, d_{t}, is the minimum distance the eyepoint must move until the primitive must be retested to check if re tessellation is needed. The computation of fractional backpatch visibility is set forth below.
It will be appreciated that the other fractional conditions are computed in an analogous manner. For example, the visibility is computed for frame i by comparing:
Vj = NE to m_{F} (15) wherein m_{F} is a precomputed surface property equal to minimum value of N»F; N = F_{u} x F_{v} is a 3m x 3n rational Bezier patch; and
E is the eyepoint for frame i For frame i+ 1, the visibility is computed by comparing: v_{i+ 1} = NE' to m_{F} (16) wherein E' is the eyepoint for frame i+ 1 As discussed above, the visibility need not be recomputed for frame i+ 1 if:
NE' < m_{F} (17) or if:
N«(E'  E) < m_{F}  NE (18) N»(E'  E) < m_{F}  _{Vi} (19)
Hence, while the maximum value of N*(E'  E) remains less than m_{F}  N*E, the visibility need not be recomputed.
The maximum value of N»(E'  E) is  N   E'  E  . This implies that retesting is not required for:
I E' E I < d_{v} = ^i (20)
wherein  E' E  is movement (i.e. , change in distance) of the eyepoint; and m_{F} and maximum value of  N  are prestored properties of primitives S. Kumar, et al. , Accelerated walkthrough of large spline models, discloses a sampling of all trimming curves to obtain a piecewise linear representation.
However, if the trimming curves are already specified in a highly tessellated form, it is difficult to reduce the number of points on the trimming curves without introducing cracks in the triangulation. Since the exemplary library 1 computes adjacencies, it simplifies the common boundary curve separately and uses the simplified version on both adjacent patches, thereby avoiding cracks. The library 1 performs this simplification by deleting points on the curve as long as each resulting curve segment is less than Λ in length, where Δ is a usercontrolled bound on the maximum triangle edge length. A problem with this approach is that resulting trimming curve polygon may be self intersecting. In order to avoid this problem, the library 1 selects special points on the curve that cannot be deleted. The special points of a trimming curve on a patch domain are selected as follows. First, choose the point p_{m} with the minimum internal angle. Second, mark p_{m} as special and add it to a polygonal chain which is, thereby, being constructed. Next, add point p_{m}+i to the polygonal chain (in which addition is modulo n). Finally, if a segment of the polygonal approximation of the trimming curve (C) intersects the Convex Hull, as understood by those skilled in the art, of the chain, then p_{m+i} is special, set m = m + i, and proceed recursively.
A point on the common boundary curve is marked as special if it is found to be special in either of the two adjacent surface domains. It can be proven that if special points are included, the resulting trimming polygon is guaranteed to be simple. Often, surfaces are not rectangular in shape. A tensorproduct parametrization of these surfaces is degenerate. It is possible to reparametrize a triangular domain onto a rectangular domain (see K. lino, et al. , Subdivision of triangular Bezier patches into rectangular Bezier patches, Transactions of the ASME, 1992) and then apply the algorithms designed for tensorproduct surfaces, but that defeats the purpose of using triangular Bezier surfaces.
The quality criteria are specified in screen space, whereas sampling is performed in the parametric domain (u, v) of the surface. The relationship between the step size on the domain and the resulting triangle size on the screen is of interest. For the domain D of a threedimensional surface F, and points p, and p_{2} on D, it is assumed that vector T(F(p)) maps the point F(p) to screen space, that \ TrF(pj))T F(p_{2})) \ = /,(  F(j>,)F(p_{2})  ), and that  F(p,)F(p_{2})  = /_{2}( ΛP_{2}  ). The function f_{3} = fj of_{2} is of interest, wherein f_{2} depends only on the control points of F and is independent of the viewing parameters. The function f_{3} may be computed in two ways: (1) by transforming the surface (control points) into screen space and using transformed representation to compute the bounds on derivatives, and the step sizes as a function of these bounds; or (2) by determining bounds on the surface in object space as a preprocessing step, and at run time, computing the step size as a function of the precomputed bounds and viewing parameters. The first method finds f_{3} in one step and all computation must be performed at rendering time. On the other hand, the second method factors f_{3} into two parts, fj and/_{2}. First, the relationship between the domain step size and the step size in the object space, which is independent of the viewing parameters, is precomputed and stored. Second, the triangle sizes in the object space are mapped to the screen space to compute the sampling size at rendering time, fj depends on how much the viewing and perspective transformations scale the lengths of vectors. The minimum scaling over all vectors that lie in the intersection of the viewvolume and the Convex Hull of the surface is computed. For parallel projection, and a linear transformation matrix, the relationship is quite simple, as the scaling is given by the norm of the matrix. For perspective projection, the minimum scaling occurs at one of the hull points. A bounding box, instead of a convex hull, may be employed to reduce computational costs. Given Δ_{0}, the step size in the object space, Δ_{S}, the maximum step size in screen space, is computed as follows. For each point P_{(} on the hull, r„ the length of the major axis of the ellipse projected onto the screen by the circle, c„ with center
P, and radius Δ_{0}, is computed. c, lies in a plane perpendicular to P^E, where E is the eyepoint. Note that a vector perpendicular P,E scales the least on projection, Δ_{S} = rnin , _{λ}
The library 1 employs an algorithm, which generalizes to arbitrary sided domains, to directly tessellate triangular Bezier surfaces. The library 1 extends the prior art sampling algorithm of S. Kumar, et al. , Interactive display of large NURBS models, to triangular surfaces. The present sampling algorithm satisfies the minimum triangleedge length quality constraint, with other constraints being similarly extended. This constraint restricts the screen size of each resulting triangle to be no greater than Δ , a user supplied parameter. Given Δ , the domain stepsize, δ, is computed in two stages. First, as an offline process, δ_{0} (δ_{0} = Δ_{s}/m_{F}), the number of domain steps needed to ensure that each resulting triangle has no edge larger than Δ_{0} in object space, is determined. Then, at run time, s_{F}, the scaling factor of vectors due to viewing transformation, is determined. A step size of δ = δ_{0}s_{F} guarantees that the screen size of each edge of the resulting triangle is less than Δ .
To determine δ_{0}, the library 1 finds a bound on the maximum magnitude of directional derivatives of a Bezier triangle. The library 1 finds the maxima in all three directions: u=0, v=0 and w=0. This is equivalent to finding the maxima of pairwise partial derivatives M_{w} =  F_{u}  F_{v}  , M_{v} =  F_{u}  F_{w}  and M_{u} =  F_{v}  F_{w} I . These maxima are computed using the method of resultants (see, for example, D. Manocha, et al. , Algorithms for intersecting parametric and algebraic curves i: simple intersections, A CM Transactions on Graphics, 13(1):73100, 1994). A domain stepsize of δ_{0} in the direction parallel to u=0 results in an object space stepsize of no more than M_{w}δ_{0} (by the mean value theorem). In order to perform the uniform tessellation, the library 1 discards the minimum of the three maxima and picks isoparametric lines parallel to the axes corresponding to the other two maxima. Interestingly, by generalizing this technique to tensorproduct surfaces and computing F_{d} = min(  F_{u+V}  _{ma},  F_{u}__{v}  ^ in addition to  F_{u}  ^ and
I F_{v} I _{max>} ^{me} library 1 reduces the total number of triangles generated by prior proposals. Instead of using — , respectively, for the stepsizes along the u
and v axes, max(  ^{M}—u ,F_{d}) and max( — ^{M}v ,F_{d}), respectively, are employed. v2 v2
Similarly to the tensorproduct case, to avoid cracks, the library 1 samples the interior separately from the boundary curves and generates filling triangles at three boundaries.
Once the library 1 determines the interior and boundary step sizes, the surface is correspondingly sampled and triangulated. For the stepsize needed on the three boundaries being δ,, δ_{2}, and δ_{3}, respectively, and the interior stepsize needed along the three directions being δ_{u}, δ_{v}, and δ_{w}, respectively, the library 1 picks the minimum two of the interior stepsizes for uniform tessellation.
The main steps of the algorithm are as follows. For convenience of discussion, but without loss of generality, assume δ_{u} < δ_{w} and δ_{v} < δ_{w}. Also, let
= — . First, equispaced samples 50 are selected on the i^{th} boundary of
boundary 52 (boundary 0), boundary 54 (boundary 1) and boundary 56 (boundary 2) δ δ as shown in Figure 7A. Second, offset curves 58 and 60 ( u = — and v = —  ,
respectively) are generated as shown in Figure 7A, with the factor of Vi being employed to guarantee bounds on edge lengths at the boundary. The strips 62,64 are then triangulated between the two offset curves 58,60 and the corresponding boundary curves 52,54 (i.e. , w=0 and v=0). Next, isoparametric lines 66,68,70 (u = (i + V_{2})δ_{v}) and 72,74,76 (v = (j + V6)δ„) are generated, with i > 1 and j > 1. Then, the isoparametric lines 66,68,70,72,74,76 are delimited by the offset curve and the boundary 56 (w=0) as shown in Figure 7B. Finally, as shown in Figure 7C, diagonals, such as 78, are added to each parallelogram, such as 80, generated in the preceding delimiting step and the envelope of these parallelograms is triangulated with curve 54 (v=0).
By tessellating each boundary curve independently of the interior and by avoiding introduction of extra sample points on the curve at the triangulation stage, the library 1 allows two surfaces adjacent to a boundary curve to be independently parameterized, as long as the common curve is consistent. In particular, one of these could be a triangular surface while the other is a tensorproduct surface.
Just as some surfaces are inherently triangular, and are better parameterized on a triangle, there are others that are inherently pentagonal, or hexagonal and so on. There exist parametrizations defined over multisided convex domains. J. Gregory, C^{1} rectangular and nonrectangular surface patches, Surfaces and CAGD, pp. 2533, 1983, discloses some of the pioneering work on multisided patches. Although previous proposals disclose an algorithm to decompose general multisided patches into triangular and rectangular patches, it is more efficient to directly render multisided patches.
C. Loop, et al., A multisided generalization of Bezier surfaces, /I CM
Transactions on Graphics, 8(3):204234, 1989, discloses a unifying framework for multisided patches, called Spatches, and defines surfaces by embedding the msided regularpolygonal domain in a m1 dimensional space. The result is a generalization of bary centric coordinates.
The exemplary tessellation algorithm for triangular Bezier patches easily extends to polygonal domains. The library 1 still chooses two independent (the
independent boundaries of an ngon have no more than —  1 edges between them)
boundary curves and generates isoparametric curves corresponding to the two boundary curves. Offsets are first generated for each of those two curves and the corresponding boundary strips are triangulated. Finally, the envelope of the generated mesh is triangulated with the rest of the boundaries. Interestingly, this general algorithm reduces exactly to the ones discussed above for the cases of triangular and tensorproduct patches.
Referring again to Figures 1 and 2, the pipeline of the library 1 has four major stages. In the exemplary embodiment, the pipeline is not a static sequential pipeline and, hence, the stages are termed threads. The four threads are surfacetree construction (C) by the model hierarchy manager thread 7, visibility computation (V) by the visibility thread 14, surface tessellation (T) by the tessellation thread 16, and rendering (R) by the rendering thread 18. The exemplary threads may interact with each other through inmemory data structures, or through files. The file interface may be extended to use interprocess communication or Unix sockets. The interactions may be synchronous or asynchronous.
The V, T, and R threads are primarily discussed, since the C thread runs just once during preprocessing and, hence, must be completed before the other threads start. In turn, the three threads V,T,R repeat every frame.
Each thread is designed to traverse an associated data structure. During one execution, the library 1 instances a thread one time, although different instances of a thread may be used to compare competing design schemes. Similarly, the data structure traversed by a thread may have several instances. Each corresponding traverse method may output a primitive that the thread decodes by employing its header. The format for a primitive is extensible. Each thread also provides callback hooks ( . e. , routines that are called just before or just after a thread processes a primitive). There also are hooks for two callbacks, respectively, as the first and the last step of each frame of the thread. Similarly, each data structure provides a callback hook at each primitive.
For the concept of autonomy, the pipeline manager 12 schedules only autonomous entities for execution. Other routines employed for rendering are called via callbacks by autonomous entities. Any thread may be marked as autonomous. The pipeline manager 12 does not preempt any autonomous entity. The library 1 lets the application program 43 controls preemption by allowing an entity to explicitly relinquish control by returning. Before returning, a thread saves its state and sets its active flag to request rescheduling.
The frame loop, which repeats for each frame, of the pipeline manager
12 is as follows: (1) set all autonomous routines active; (2) while there exists an active autonomous routine R, call R; and (3) if tuning is enabled, then fine tune the pipeline.
The exemplary pipeline manager 12 allows the library 1 to rearrange the pipeline in a variety of ways. For example, the Surface Tree, as previously constructed by the model hierarchy manager thread 7 (as discussed above in connection with Figures 5A5B and Equations 910), may be declared autonomous. At each node, the pipeline manager 12 performs the visibility computation, tessellation and rendering functions, in that order, via callbacks.
Alternatively, each thread may be declared autonomous, with thread V producing structure L,, a list of visible primitives, that thread T, in turn, traverses to produce L^, a list of trianglestrips, which thread R, in turn, traverses and finally sends to the OpenGL server for display by the graphics board 27. In this example, each of the respective data structures provide concurrency control for simultaneous reads and writes. For an asynchronous rendering scheme, the library 1 disables the concurrency control and allows thread T and thread R to maintain consistency by their order of accesses to list L_{2}.
As an example of one initial configuration of the pipeline (i.e. , the default setup), n processes are created, in which n is user specified and is typically equal to the number (e.g. , n=4 in the exemplary embodiment) of processors in the system.
A default initial 1 process configuration is as follows: (a) the visibility computation thread V is marked as autonomous; (b) the associated data structure is set to the Surface Tree; (c) the PrimitiveEnd callback is set to call procedures Tessellate (Primitive) and Render (Primitive); and (d) the pipeline manager 12, PipeManager, is started.
As another example, a default initial 2process configuration is as follows. For Process 0: (a) the rendering thread R is marked as autonomous; (b) the associated data structure is set to Render List which is the list of triangles to display; and (c) the PipeManager is started, and for Process 1: (a) the visibility computation thread V is marked as autonomous; (b) the associated data structure is set to Surface
Tree; (c) the PrimitiveEnd callback is set to call procedures Tessellate(Primitive) and add to Render List; and (d) the PipeManager is started.
All unspecified callbacks are set to a null. If more than two processors are available, then all the other processors start with thread T as the autonomous entity with the Surface Tree. In Figure 2, there are two processors 20,22 for thread T. The model hierarchy manager 7 and the pipeline manager 12 are distributed and do not reside on any one processor.
In the exemplary embodiment, Surface Tree is actually a forest with a few tens of trees. Load balancing is easily achieved by starting with an equitable distribution of these trees, followed by work stealing as proposed in S. Kumar, et al. ,
Scalable algorithms for interactive visualization of curved surfaces, Supercomputing ,
1996. The exemplary library 1 preferably provides for: (1) increasing the scheduling priority of a bottlenecked autonomous thread; (2) creating an autonomous instance of bottlenecked thread (on a process where it is not autonomous); (3) changing the maximum traversal depth of Surface Tree, thereby obtaining either less detailed or more detailed primitives; and (4) dynamic configuration of the pipeline.
For example, if thread A spends more than 10% of its time waiting at a synchronization barrier with thread B, thread B is declared to be bottlenecked. In the exemplary embodiment, a thread must be bottlenecked for at least three frames in any block of five frames to cause an adjustment in the pipeline. As another example, if the graphics board 27 is found to be the bottleneck, the library 1 changes the maximum traversal depths of threads V and T to offset the bottleneck.
An event recorder module 45 collects statistics on bottlenecks. Preferably, a high precision hardware counter is employed as is available on a Silicon Graphics platform.
The library 1 is preferably implemented using a suitable language (e.g. , C/C + +) and is independent of the platform. Preferably, shared memory 46 for the processors 20,22,24,26 is controlled by shared memory manager 48 which is also employed to cache trianglestrips. The library 1 stores the Bezier surface representation (i.e. , control points) separately from the tessellated triangles, since the control points remain static, but the cache sizes for primitives may change between frames. Caches are allocated in multiples of 1 Kbytes to avoid fragmentation. The library 1 stores the surface properties with the triangle cache such that if retessellation is not required, then no access to the control points' memory page is needed. Since the exemplary surface properties are less than 50 bytes, it does not impose severe overhead to move them when the cache a primitive requires relocation.
As an alternative, the control points are stored with the cache, although that embodiment is slower to relocate, as the representation of a trimmed Bezier patch may take a few hundred bytes. In addition, a primitive may be a supersurface and may comprise multiple sets of control points.
It is believed that the exemplary library 1 is the first system of its kind for rendering large surface models. While prior proposals for efficient rendering management are available, none are designed for dynamic supersurface tessellation, nor are they flexible enough to allow the desired types of rendering. Also, it is believed that most other surface rendering systems are more than a hundred times slower than the library 1. Still other prior art systems are little more than a collection of functions for evaluating properties of NURBS surfaces and for triangulating them, but do not form a comprehensive display system.
Compared to the performance of S. Kumar, et al. , Accelerated walkthrough of large spline models, the library 1 achieves a speedup of about 1.5 to 2.5 times. Approximately 40% of this improvement may be attributed to the fractional condition scheme and another approximately 20% to the improved visibility algorithm.
Most of the rest of the improvement comes from using parametric super surfaces. Furthermore, the tessellations produced by using parametrically constructed super surfaces also satisfy quality constraints not satisfied by the static LODs of S. Kumar, et al. , Accelerated walkthrough of large spline models. To test the performance of the library 1 , a variety of Bezier surface models are rendered on a variety of platforms. Speedups of 5 to 15 times over a simple polygonal rendering are obtained by the exemplary system. In this comparison, multiple LODs for the polygonal rendering are not employed. The best performance on each system (modulo pipeline changes) is provided in which all numbers are for synchronous rendering. Asynchronous rendering is two to three times faster, with a degradation in image quality.
On average, the space consumption was observed to be 800 to 900 bytes per Bezier patch (including cached triangles). On some executions, however, the average space per patch exceeded 10 Kbytes for some frames. These were highly closedup views and a number of nonvisible patches still had their caches active and were thereby contributing to the total count. Furthermore, the average space required per patch went down as the size of models went up as shown in Figure 8, since larger models typically have smaller patches on screen.
As shown in Figure 9, the rendering slowdown curve is well below linear with increasing model size. As model sizes continue to grow, primitives processed per frame by the library 1 consist of more Bezier patches. From these observations, it is believed that the approach of dynamic tessellation scales well. One of the surprising discoveries was the effect of interrupt overhead on the rendering thread R, especially when it is the only autonomous thread on its process. The rendering processor is often blocked waiting for the OpenGL FIFO buffer to be emptied, signifying a rendering bottleneck. This block can cause multiple interrupts on an IRIX system. The rendering thread R on its associated processor waited for OpenGL up to 50% of the time on a dual processor Octane. A significant part of this was attributed to processing interrupts associated with a full FIFO. The total idle time actually went down by about 15 to 20% when sleeps in thread R (sleep times were counted as idle) were artificially introduced. This occurred due to a decrease in the number of interrupts. This result suggests always running a second autonomous thread on the processor running thread R, although at reduced priority.
Figure 10A is a flowchart of the visibility test 82. At 84, the magnitude of the view change vector (  E' E  ) is determined and, at 85, Vj = N*E is determined. Next, at 86, if the test of Equation 20 is not met, then, at 88, the current visibility is employed. On the other hand, if that test is met, then, at 90, the visibility is computed as discussed above in connection with Figure 6. After either 88 or 90, if the surface primitive is not visible, then it is discarded at 94. Otherwise, if the surface primitive is visible, then it is tessellated and displayed as discussed below in connection with Figure 10B. Figure 10B is a flowchart of the tessellation test 96. At 98, the change
(Δs_{F}) in the scaling factor (s_{F}) from the previous frame to the current frame is determined. Next, at 100, if the change in scaling factor (Δs_{F}) is not greater than δ_{0} (δ_{0} = Δ_{s}/m_{F}), then, at 102, the current tessellation is again employed, after which it is rendered at 104. On the other hand, if the change in scaling factor (Δs_{F}) is greater than δ_{0}, then, at 106, the tessellation step size is recomputed. Next, at 108, if the current tessellation step size is equal to the previous tessellation step size, then step 102 is executed. Otherwise, at 110, the tessellation is recomputed, after which it is rendered at 104.
At 106, the tessellation step size may be computed by various methods, such as by employing a difference criteria or a deviation criteria. For example, in the difference criteria, the tessellation step size δ is chosen per Equation 21: δ ≤ — X^ (21) lix (0,r^{/}(4z (0ll wherein F(u,v) = (X(u,v), Y(u,v),Z(u,v), W(u,v)) is a rational Bezier surface; δ = \ln_{u}; for Bezier surface, F(u,v), the tessellation parameters are computed in
object space as n_{u} =
' corresponds to the maximum magnitude of the partial
W(u,v)_{h}
derivative of — ± with respect to u in the domain [0, 1] x [0,1]; and W(u,v)
X'(f), Y'(t), Z'(t)
represent the maximum magnitude of X'(t),Y'(t),Z'(t), respectively, in the domain [0, 1], at eyepoint E' .
The exemplary library 1 is a configurable system useful for interactive rendering of trimmed tensor product or triangular NURBS surfaces. It also forms a general testbed for quickly prototyping new algorithms. In addition, various system tradeoffs can be systematically explored using the library 1 , by changing just the part being profiled and leaving all else constant. As a case in point, a network of workstations may be employed to enable interactive triangulation and rendering of large scale models. The library 1 framework has been quite useful in quick testing of preliminary ideas.
A novel feature of the library 1 is its ability to reconfigure the rendering pipeline to best suit the relative processing powers of the available processor(s) and graphics board. The exemplary library 1 may be successfully employed to obtain faster rendering rates than known prior systems. The library 1 also improves over known prior art visibility and tessellation algorithms. In addition, the fractional condition framework of estimating when a primitive needs to be reevaluated for visibility or for triangulation completely eliminates the need to process about 2025 % of the model being rendered. In summary, it is believed that the library 1 achieves a speedup of about 23 times over the previously best known algorithms. It is also believed that the library 1 scales almost linearly with increased processing power and deteriorates only sublinearly with increased model size.
Also, algorithms may be employed to efficiently distribute the visibility, computation, and tessellation threads over a network of workstations. In addition, the library 1 provides a flexible framework for designing and testing surface rendering algorithms. Whereas particular embodiments of the present invention have been described above for purposes of illustration, it will be appreciated by those skilled in the art that numerous variations in the details may be made without departing from the invention as described in the exemplary claims which are appended hereto.
Claims
Priority Applications (2)
Application Number  Priority Date  Filing Date  Title 

US9851798P true  19980831  19980831  
US60/098,517  19980831 
Publications (1)
Publication Number  Publication Date 

WO2000013146A1 true WO2000013146A1 (en)  20000309 
Family
ID=22269642
Family Applications (1)
Application Number  Title  Priority Date  Filing Date 

PCT/US1999/019024 WO2000013146A1 (en)  19980831  19990820  System and method for interactively displaying a model having a complex surface 
Country Status (1)
Country  Link 

WO (1)  WO2000013146A1 (en) 
Cited By (2)
Publication number  Priority date  Publication date  Assignee  Title 

US7928979B2 (en)  20080201  20110419  Microsoft Corporation  Efficient geometric tessellation and displacement 
US8487944B2 (en)  20081028  20130716  Siemens Aktiengesellschaft  System and method for processing of image data in the medical field 
Citations (6)
Publication number  Priority date  Publication date  Assignee  Title 

US5255352A (en) *  19890803  19931019  Computer Design, Inc.  Mapping of twodimensional surface detail on threedimensional surfaces 
US5261029A (en) *  19920814  19931109  Sun Microsystems, Inc.  Method and apparatus for the dynamic tessellation of curved surfaces 
US5377320A (en) *  19920930  19941227  Sun Microsystems, Inc.  Method and apparatus for the rendering of trimmed nurb surfaces 
US5381521A (en) *  19930514  19950110  Microsoft Corporation  System and method of rendering curves 
US5696837A (en) *  19940505  19971209  Sri International  Method and apparatus for transforming coordinate systems in a telemanipulation system 
US5929861A (en) *  19960823  19990727  Apple Computer, Inc.  Walkthrough rendering system 

1999
 19990820 WO PCT/US1999/019024 patent/WO2000013146A1/en active Application Filing
Patent Citations (6)
Publication number  Priority date  Publication date  Assignee  Title 

US5255352A (en) *  19890803  19931019  Computer Design, Inc.  Mapping of twodimensional surface detail on threedimensional surfaces 
US5261029A (en) *  19920814  19931109  Sun Microsystems, Inc.  Method and apparatus for the dynamic tessellation of curved surfaces 
US5377320A (en) *  19920930  19941227  Sun Microsystems, Inc.  Method and apparatus for the rendering of trimmed nurb surfaces 
US5381521A (en) *  19930514  19950110  Microsoft Corporation  System and method of rendering curves 
US5696837A (en) *  19940505  19971209  Sri International  Method and apparatus for transforming coordinate systems in a telemanipulation system 
US5929861A (en) *  19960823  19990727  Apple Computer, Inc.  Walkthrough rendering system 
NonPatent Citations (2)
Title 

COORG S, TELLER S: "TEMPORALLY COHERENT CONSERVATIVE VISIBILITY", PROCEEDINGS OF THE 1996 ACM SIGPLAN INTERNATIONAL CONFERENCE ON FUNCTIONAL PROGRAMMING (ICFP '96). PHILADELPHIA, MAY 24  26, 1996., NEW YORK, ACM., US, vol. CONF. 1, no. CONF. 01, 1 May 1996 (19960501), US, pages 78  87, XP002934925, ISBN: 9780897917704 * 
MULMULEY K: "HIDDEN SURFACE REMOVAL WITH RESPECT TO A MOVING VIEW POINT", PROCEEDINGS OF THE ACM/IEEE DESIGN AUTOMATION CONFERENCE. SAN FRANCISCO, JUNE 17  21, 1991., NEW YORK, IEEE., US, vol. CONF. 28, 1 June 1991 (19910601), US, pages 512  522, XP002934926, ISBN: 9780897913959 * 
Cited By (3)
Publication number  Priority date  Publication date  Assignee  Title 

US7928979B2 (en)  20080201  20110419  Microsoft Corporation  Efficient geometric tessellation and displacement 
US10269176B2 (en)  20080201  20190423  Microsoft Technology Licensing, Llc  Efficient geometric tessellation and displacement 
US8487944B2 (en)  20081028  20130716  Siemens Aktiengesellschaft  System and method for processing of image data in the medical field 
Similar Documents
Publication  Publication Date  Title 

Rossignac et al.  Multiresolution 3D approximations for rendering complex scenes  
Kolb et al.  Hardwarebased simulation and collision detection for large particle systems  
CA2772030C (en)  Systems and methods for providing intermediate targets in a graphics system  
US4928247A (en)  Method and apparatus for the continuous and asynchronous traversal and processing of graphics data structures  
Wilhelms et al.  A coherent projection approach for direct volume rendering  
EP1081655B1 (en)  System and method for rendering using ray tracing  
US7280121B2 (en)  Image processing apparatus and method of same  
US7495664B2 (en)  Instant ray tracing  
US6445391B1 (en)  Visibleobject determination for interactive visualization  
US5894308A (en)  Interactively reducing polygon count in threedimensional graphic objects  
US7659894B2 (en)  Terminating spatial partition hierarchies by a priori bounding memory  
US6088044A (en)  Method for parallelizing software graphics geometry pipeline rendering  
Airey et al.  Towards image realism with interactive update rates in complex virtual building environments  
KR101231291B1 (en)  Fast reconfiguration of graphics pipeline state  
Duchaineau et al.  ROAMing terrain: realtime optimally adapting meshes  
JP3764478B2 (en)  Tessellation system  
Bischoff et al.  Automatic restoration of polygon models  
US20020191034A1 (en)  Size conditioned visibility search system and method  
US20110285723A1 (en)  Conversion of dashed strokes into quadratic bèzier segment sequences  
US6744434B2 (en)  Cuts removal system for triangulated CAD Models  
Erikson et al.  HLODs for faster display of large static and dynamic environments  
US20090189898A1 (en)  Shallow bounding volume hierarchies for accelerated ray tracing  
US20040075655A1 (en)  3D computer graphics processing apparatus and method  
Yoon et al.  Quickvdr: Interactive viewdependent rendering of massive models  
JP4643271B2 (en)  Visible surface determination system and method for computer graphics using interval analysis 
Legal Events
Date  Code  Title  Description 

AK  Designated states 
Kind code of ref document: A1 Designated state(s): CA JP MX US 

AL  Designated countries for regional patents 
Kind code of ref document: A1 Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE 

121  Ep: the epo has been informed by wipo that ep was designated in this application  
122  Ep: pct application nonentry in european phase 