A system and program product for re-meshing of a three-dimensional (3D) input model using progressive implicit approximating levels are provided. Specifically, an initial quadrilateral mesh for a 3D input model is provided. Then, an implicit approximating field is built for a first approximating level (L) of the 3D input model using an implicit surface modeling technique. An iso-contour of the implicit approximating field is then extracted, and the quadrilateral mesh is fit to the first approximating level (L). The fit between the quadrilateral mesh and the first approximating level (L) is then estimated, and it is determined whether the fit meets a predetermined quality criterion. If not, the quadrilateral mesh is refined using one or more of a sequence of topological operations are performed to improve the fit. The process is then iteratively repeated for subsequent approximation levels until one of the subsequent approximation levels is fit to the 3D input model.

Patent
   7737969
Priority
Jan 19 2006
Filed
Jun 11 2008
Issued
Jun 15 2010
Expiry
Jan 19 2026

TERM.DISCL.
Assg.orig
Entity
Large
106
7
all paid
1. A system for quadrilateral re-meshing of a three-dimensional (3D) input model using progressive implicit approximating levels, comprising:
a computer device including:
a system for providing a quadrilateral mesh for the 3D input model; a system for building an implicit approximating field for a first approximating level (L) of the 3D input model using an implicit surface modeling technique;
a system for extracting an iso-contour of the implicit approximating field;
a system for fitting the quadrilateral mesh to the first approximating level (L);
a system for estimating a fit between the quadrilateral mesh and the first approximating level (L);
a system for determining whether the fit meets a predetermined quality criterion; and
a system for refining the initial quadrilateral mesh using at least one of a sequence of topological operations to achieve an improved fit after the determining step if the fit fails to meet the predetermined quality criterion,
wherein the quadrilateral mesh is an initial quadrilateral mesh,
and wherein the sequence of topological operations comprises snapping vertices, splitting edges, extruding faces, and bridging faces of the quadrilateral mesh.
6. A program product stored on a tangible computer readable medium for quadrilateral re-meshing of a three-dimensional (3D) model using progressive implicit approximating levels, the computer readable medium comprising program code for:
providing, on a computing device, a quadrilateral mesh for the 3D input model;
building, on the computing device, an implicit approximating field for a first approximating level (L) of the 3D input model using an implicit surface modeling technique;
extracting, on the computing device, an iso-contour of the implicit approximating field;
fitting, on the computing device, the quadrilateral mesh to the first approximating level (L);
estimating, on the computing device, a fit between the quadrilateral mesh and the first approximating level (L);
determining, on the computing device, whether the fit meets a predetermined quality criterion;
iteratively repeating the building, extracting, fitting, estimating, and determining, on the computing device, for subsequent approximation levels until a predetermined stopping criterion is reached; and
refining, on the computing device, the initial quadrilateral mesh using at least one of a sequence of topological operations to achieve an improved fit after the determining step if the fit fails to meet the predetermined quality criterion,
wherein the quadrilateral mesh is an initial quadrilateral mesh, and wherein the sequence of topological operations comprises snapping vertices, splitting edges, extruding faces, and bridging faces of the quadrilateral mesh.
2. The system of claim 1, further comprising a system for outputting the quadrilateral mesh when a predetermined stopping criterion is reached, the predetermined stopping criterion comprising at least one of the following: an interpolating level being reached, or one of the subsequent approximating levels being fit to the 3D input model within a predetermined threshold.
3. The system of claim 1, the quadrilateral mesh being provided as a bounding box of the 3D input model.
4. The system of claim 1, the quadrilateral mesh being provided as a polyhedron with quadrilateral faces.
5. The system of claim 1, the implicit surface modeling technique being an implicit is Moving Least Squares (iMLS) technique.
7. The program product of claim 6, the predetermined stopping criterion comprising at least one of the following: an interpolating level being reached, or one of the subsequent approximating levels being fit to the 3D input model within a predetermined threshold, the computer useable medium further comprising program code for causing the computer system to perform the following step: outputting the quadrilateral mesh when the predetermined stopping criterion is reached.
8. The program product of claim 6, the implicit surface modeling technique being an implicit Moving Least Squares (iMLS) technique.

This patent application is a continuation of U.S. patent application Ser. No. 11/335,277, filed Jan. 19, 2006 now U.S. Pat. No. 7,443,393.

1. Field of the Invention

The present invention generally relates to geometric modeling in computer graphics (CG). Specifically, the present invention relates to a method, system and program product for re-meshing of a three-dimensional input model using progressive implicit approximating levels.

2. Related Art

Geometric modeling is a fundamental problem in computer graphics (CG). Typical CG pipelines favor triangles as the most commonly used geometric primitives since triangle meshes are easy to model, render, and animate. Recently, quadrilateral-based subdivision surfaces have been proven to offer advantages over triangle meshes for modeling and editing of complex shapes.

The conversion of a given triangle mesh into a quad-based semi-regular mesh suitable for generating a subdivision surface requires re-meshing. Automatically generating an all-quads manifold surface with a small number of quads so as to keep the complexity of subdivided meshes derived from it low, yet sufficient to capture input features, is a challenging problem. A given triangulated model might have millions of triangles that capture all surface details. A multi-resolution subdivision surface that describes the same model will have a much coarser base mesh and a sequence of detail levels that describe progressively better approximations of the input surface through offset or detail vectors with respect to the positions obtained by subdivision of control meshes on coarser levels. One challenge is to find a suitable coarse mesh, which does not have too many faces, yet optimizes the placement of these faces with respect to the input geometry so that the input can be approximated well with only few and small perturbations (i.e., offsets or details).

A good quality base mesh captures the important geometric properties of the original mesh, such as topology, symmetry and sharp features. Some efforts have been made in this field. For example, one method to achieve this goal is to first decimate then re-arrange the connectivity of the input triangle mesh to produce a quad mesh. A sequence of local re-meshing operations such as triangle pairings makes this scheme fail to preserve global properties such as symmetry of the original shape and the output heavily depends on the original connectivity. Other recent works make use of vector fields defined on the mesh surface to guide the re-meshing operations. Such methods lead to meshes that better capture symmetries, but they result in relatively fine meshes with many elements (the number of elements will be proportional to the size of the smallest feature of the object). Although this new idea offers the ability to re-mesh without dependency on the input connectivity, this strategy remains a surface-based approach that limits the manipulation over the 2D domain of the surface.

In general, the present invention provides a method, system and program product for re-meshing of a three-dimensional input model using progressive implicit approximating levels. Specifically, the present invention introduces a new strategy based on a volumetric (3D) perspective. Under the present invention, the same volume bounded by an input triangle model is captured using a sequence of implicit approximating surfaces that start with a coarse approximation and converge to the input shape. A quadrilateral mesh is built incrementally based on these implicit representations.

Under the present invention, an implicit distance field is first built by using a technique such as the implicit moving least squares (iMLS) method. Then, a quadrilateral mesh is extracted using this implicit distance field. From fine to coarse, this technique smoothes out surface details and provides a list of nested contours starting from the center of the input model and growing outward. In one embodiment, from coarse to fine, the output quadrilateral mesh is initialized as the bounding box of the input and refined to fit each contour progressively from outer layers toward the center. Each refinement is an iterative procedure. To this extent, the error between the current quadrilateral mesh and the selected contour is estimated and minimized for each vertex, edge and face through a sequence of mesh operations such as snapping vertices, splitting edges, extruding faces, and/or bridging faces.

A first aspect of the present invention provides a method for quadrilateral re-meshing of a three-dimensional (3D) input model using progressive implicit approximating levels, comprising: providing a quadrilateral mesh for the 3D input model; building an implicit approximating field for a first approximating level (L) of the 3D input model using an implicit surface modeling technique; extracting an iso-contour of the implicit approximating field; fitting the quadrilateral mesh to the first approximating level (L); estimating a fit between the quadrilateral mesh and the first approximating level (L); determining whether the fit meets a predetermined quality criterion; and iteratively repeating the building, extracting, fitting, estimating, and determining for subsequent approximation levels until a predetermined stopping criterion is reached.

A second aspect of the present invention provides a system for quadrilateral re-meshing of a three-dimensional input model using progressive implicit approximating levels, comprising: a system for providing a quadrilateral mesh for the 3D input model; a system for building an implicit approximating field for a first approximating level (L) of the 3D input model using an implicit surface modeling technique; a system for extracting an iso-contour of the implicit approximating field; a system for fitting the quadrilateral mesh to the first approximating level (L); a system for estimating a fit between the quadrilateral mesh and the first approximating level (L); and a system for determining whether the fit meets a predetermined quality criterion.

A third aspect of the present invention provides a program product stored on a computer useable medium for quadrilateral re-meshing of a three-dimensional (3D) input model using progressive implicit approximating levels, the computer useable medium comprising program code for causing a computer system to perform the following steps: providing a quadrilateral mesh for the 3D input model; building an implicit approximating field for a first approximating level (L) of the 3D input model using an implicit surface modeling technique; extracting an iso-contour of the implicit approximating field; fitting the quadrilateral mesh to the first approximating level (L); estimating a fit between the quadrilateral mesh and the first approximating level (L); determining whether the fit meets a predetermined quality criterion; and iteratively repeating the building, extracting, fitting, estimating, and determining for subsequent approximation levels until a predetermined stopping criterion is reached.

A fourth aspect of the present invention provides a method for deploying an application for quadrilateral re-meshing of a three-dimensional (3D) input model using progressive implicit approximating levels, comprising: providing a computer infrastructure being operable to: provide a quadrilateral mesh for the 3D input model; build an implicit approximating field for a first approximating level (L) of the 3D input model using an implicit surface modeling technique; extract an iso-contour of the implicit approximating field; fit the quadrilateral mesh to the first approximating level (L); estimate a fit between the quadrilateral mesh and the first approximating level (L); and determine whether the fit meets a predetermined quality criterion.

Therefore, the present invention provides a method, system and program product for re-meshing of a three-dimensional (3D) input model using progressive implicit approximating levels.

These and other features of this invention will be more readily understood from the following detailed description of the various aspects of the invention taken in conjunction with the accompanying drawings that depict various embodiments of the invention, in which:

FIG. 1A depicts elements of the re-meshing procedure (i.e., the initial quadrilateral mesh used to initialize re-meshing, the input model, and an intermediate level), according to the present invention.

FIG. 1B depicts a representation of the input model of FIG. 1A.

FIG. 1C depicts an extracted quadrilateral mesh, according to the present invention.

FIG. 2 depicts a list of nested concentric contours in a multi-level volume representation according to the present invention.

FIG. 3 depicts a method flow diagram according to the present invention.

FIG. 4 depicts a sequence of mesh operations according to the present invention.

FIG. 5 depicts an output quadrilateral mesh according to the present invention.

FIG. 6 depicts a more specific computerized implementation according to the present invention.

It is noted that the drawings of the invention are not to scale. The drawings are intended to depict only typical aspects of the invention, and therefore should not be considered as limiting the scope of the invention. In the drawings, like numbering represents like elements between the drawings.

For convenience purposes, the Detailed Description of the Invention will have the following sub-sections.

I. General Description

A. Volume Representation with Implicit Surface Modeling

B. Volume Contouring

II. Computerized Implementation

I. General Description

In general, the present invention is based on multiple observations. First, it is recognized that local re-meshing operations applied directly to the original connectivity of an input mesh fail to preserve the global structure of the geometry, and generate output that heavily depends on the original mesh connectivity. For the same geometry model with different mesh representations, this surface strategy might generate two completely different re-meshing results. Instead, it is desirable to obtain a unique subdivision base mesh that captures the basic shape information of the input. To achieve this, in contrast to prior surface-based methods, the present invention considers the geometric model not only as a two-dimensional (2D) manifold surface, but also as a three-dimensional (3D) volume bounded by the surface mesh. Regardless of the mesh connectivity, different surface meshes with the same geometric shape share the same 3D volume.

Under the present invention (and as will be further described below), the volume bounded by the surface mesh is determined, and then contoured with a quadrilateral base mesh. Working on the volume instead of the surface mesh itself provides the freedom to ignore the original connectivity and to keep only the shape information. A second observation is that converting a complicated surface mesh with many fine details is difficult. Finding the volume bounded by such a mesh hinders the re-meshing process since when looking for a good coarse base mesh it is not desirable to focus on small surface details which are not representative of the general object shape. One goal of the present invention in building a subdivision base mesh is to get rid of high-frequency surface details which will be later captured through detail vectors.

Instead, the present invention focuses on the global geometric properties such as topology and symmetry. To achieve this, several levels of details for the original shape are recorded. As mentioned, mesh simplification strategies can heavily depend on the original mesh connectivity and tend to generate connectivity-dependent results, which are what the present invention avoids. Thus, the present invention builds a multi-level volumetric representation by smoothing out small volumetric structures and increasingly refining the initial volume into different levels of volume details. Starting from a smooth volume with no fine details, a quadrilateral mesh such as a box or some other simple geometry that coarsely approximates can be fit. Referring to FIG. 1A, an example of this operation is depicted. Specifically, FIG. 1A depicts the fitting of a quadrilateral mesh to a smooth volume. In the example shown in FIG. 1A, the quadrilateral mesh is provided as a bounding box 10 of a 3D input model/volume (surface) 12. FIG. 1B depicts a representation if input model 12, while FIG. 1C depicts an extract QM 13.

Under the present invention, both the smooth volume and the fitted quad mesh maintain the global symmetry property of the original model. By refining the approximation provided by the initial volume to capture more details, the quadrilateral mesh is progressively adjusted to achieve a good subdivision base mesh.

A. Volume Representation with Implicit Surface Modeling

Under the present invention, a multi-level volume representation is built using an implicit surface modeling technique such as a Moving Least Squares (MLS) technique. The basic idea is to create an implicit function from an input original surface mesh such that the implicit function has zero values on the surface, negative values inside the volume bounded by the surface mesh and positive values outside. The gradient values of the implicit function also match with the surface normals of the geometry. Such an implicit function is a good approximation of the signed distance function to the surface mesh. By varying a single parameter of the implicit function, the level of detail kept in the volume representation can be easily controlled. A large parameter tends to smooth out volume details whereas a small parameter allows more details to be kept. Referring to FIG. 2, a list of nested concentric contours (approximating levels) 14 in a multi-level volume representation according to the present invention is shown. A parameter value of zero provides an interpolating function for the volume bounded by the original surface mesh.

B. Volume Contouring

In contrast to surface simplification based algorithms, the implicit scheme of the present invention offers a unified framework in which a user can access a level of detail randomly without a sequence of mesh operations. Most importantly, this implicit method does not depend on the input connectivity and provides a continuous functional representation. The implicit function defined over the whole 3D space accurately represents the geometry, however, only in the zero level set of this scalar function is of interest. To this extent, a novel contouring algorithm is utilized to extract the zero iso-contour from the entire implicit function in the form of a quadrilateral mesh that approximates the 2D manifold surface.

When an implicit surface modeling technique such as MLS is used, the surface details are smoothed and curvatures are minimized. As a result, the multi-level volume representation of the present invention forms a list of nested concentric contours starting from the input geometry at the center and growing outward as the smoothness increases. This concept is illustrated in the above-referenced FIG. 2. As will be further described below, the smooth surface of an outer layer can be easily approximated by a simple shape such as a box or other geometric primitives composed of quadrilaterals. Starting from this simple shape, the base mesh is progressively updated using a sequence of mesh operations such that the new base mesh better fits the current level of approximation in the multi-level volumetric representation.

Referring now to the flow diagram of FIG. 3, the quadrilateral re-meshing of a 3D model using progressive implicit approximating surfaces according to the present invention is shown. As can be seen the contouring algorithm of the present invention is iterative. In step S1, a quadrilateral mesh (QM) is initialized/provided for an input model and fit to the smoothest available level (L). In one embodiment, the QM is provided as a bounding box (or other simple geometry primitives) of the input model. In another embodiment, the QM is provided as a polyhedron with quadrilateral faces. In any event, in step S2, all the levels of detail from smooth to finely detailed are iterated through towards the original input model. In step S3, at each level, an implicit approximating field is built using an implicit surface modeling technique such as MLS, and an iso-contour of the implicit approximating field is extracted. In step S4, the QM is fit to the zero iso-contour of the implicit function with the smoothness parameter of the current approximating level, and the fit between the QM and the approximating level L is estimated. The fitting procedure is also an iterative algorithm initialized based on the QM generated from the previous level. By comparison with the previous level, the current level captures more detail. The QM initialization that fitted well to the previous level can now have a big difference with respect to the current level. Thus, in step S5, it is determined whether the fit meets a predetermined quality criterion (i.e., it is determined if the fit is good). Under the present invention, the fit is defined in terms of the distance between QM and the current approximating level L. The distance between the two is measured at vertices, along edges, and across faces according to the metrics described below. Different thresholds can be used for each. If any one of these is above the respective threshold, the fit is considered too coarse, and QM is refined accordingly using at least one of the below described topological operations. If, the fit meets the predetermined quality criterion, the process is iteratively repeated for subsequent approximating levels in step S8 until a predetermined stopping criterion is reached. The predetermined stopping criterion typically includes at least one of the following: the interpolating level being reached, or the last/most recent approximating level being considered to be an acceptable fit to the input model (i.e. fit within a predetermined threshold).

If however, it is determined in step S5 that the fit does not meet the predetermined quality criterion, the difference is iteratively minimized (i.e., the QM is refined) by selecting at least one of a sequence of topological operations in step S6. The choices of operation depend on the kind of difference trying to be resolved. The difference between the output quad mesh to the zero iso-contour is defined in terms of four different types of metrics. These are vertex, edge, face, and volume error metrics (other metrics can also be added and their processing would be similarly treated). The present invention proceeds to optimize them one by one. Hence, the sequence of topological operations shown in FIG. 3 include snapping vertices, splitting edges, extruding faces, and bridging faces of the QM.

In general, vertex error is measured in terms of the distance between a vertex of the output quad mesh and the zero iso-contour of the volumetric representation. To minimize this error, the vertex is snapped to the iso-contour in step S6a. Since the output quad mesh is embedded into the implicit function, which offers a good approximation of the signed distance to the zero iso-contour, this snapping procedure can be achieved, in a preferred implementation as a standard root-finding algorithm. Other methods for computing or estimating distance can also be used. Starting from the 3D location of a vertex, the implicit function value at this point and its gradient vector are first evaluated. From there, a step along the gradient direction is taken with a step size computed based on the implicit function value. Since the difference between two adjacent volumetric levels of detail is relatively small and the implicit function is smooth (since the volume itself is smooth), this root-finding procedure typically converges quickly. This vertex error minimization step does not change the connectivity of the output QM. Rather, it only modifies the positions of vertices. When all vertex errors have been resolved, the mesh can still be a rather poor fit for the zero iso-contour due to edge and face errors.

The present invention defines the edge error of an edge as the total distance from all points on the edge to the zero iso-contour. This can be evaluated, for example, by integrating the absolute implicit function values along the edge. For a given output QM, the edge with the largest edge error is iteratively picked, and the error is resolved by splitting the edge into two pieces in step S6b. There are various ways of picking the split point. For example, one can pick the mid-point. This choice yields a uniformly distributed quad mesh with similar quad shapes. One can also pick the point with the largest distance to the zero iso-contour and split the edge at that point. This strategy helps to keep the mesh well-aligned with the surface features. A combination of such choices can also be used. However, splitting is not a one step procedure since if we only split the picked edge, and a mesh that may have non-quadrilateral faces could result. To meet the constraint of an all-quadrilateral output mesh, we split a whole ring of edges by visiting all neighboring faces to ensure that each of them has valence four. Similarly, we define the face error as the integral of the absolute implicit function values over the entire face. To resolve all of the these, the face with the largest error is iteratively picked, and split into two or four pieces (depending on the error distribution) until all faces end up with errors below some threshold and the faces are either extrude or indent in step S6c. Similar to the edge case, we have different choices when picking split positions and the neighboring faces must also be split to obtain an all-quad mesh. Unlike in the case of vertex errors, when we split an edge or a face to solve an edge error or a face error, a change in the QM connectivity is introduced. However, none of these operations results in a change in the mesh topology. If the input geometry is a complicated shape other than a genus-0 (sphere-like) object, obtaining a correct re-meshing result can not be expected just by performing these three operations. Thus, a mechanism to create handles (i.e., modify the topology) is needed. One way in which this can be achieved is through “hole creation” by evaluating volume errors for an internal volume bounded by two selected faces. Since the implicit function is a good approximation of signed distance, it can easily be determined whether a point is inside or outside the object. Two selected faces are bridged to make a hole if the volume bounded by these two faces contains points with positive implicit function values in step S6d, which means this part of volume should be outside the object. Bridging operations provides us topological changes.

Referring to FIG. 4, a sequence of mesh operations (a)-(l) according to the above description is shown. The sequence is as follows: (a) begin with the smoothest available level and the bounding box as the output quad mesh; (b) snap the vertices of the quad mesh to the current level; (c) estimate edge errors; (d) split the edge with the largest edge error; (e) a different point of view; (f) pick the next best approximation level; (g) snap the vertices to that level; (h) perform edge error estimation; (i) split the selected edge; (j) pick the next level; (k) snap vertices and estimate edge error; (l) split the selected edge.

When four different kinds of errors all have been resolved, the current output QM is updated in step S7, and the process repeats with subsequent approximating levels (step S8). When a stopping criterion is reached, the re-meshing result is ready for output in step S9 and the iterative fitting procedure terminates. Under the present invention, the stopping criterion can include at least one of the following, the interpolating level being reached, the last/most recent approximating level is considered to be an acceptable fit to the #D input model. Referring to FIG. 4, an example of the interpolating surface being reached is shown. Specifically, FIG. 5 shows QM provided as a bounding box 10 of input model 12, and the re-meshing result 16 provided by the present invention.

II. Computerized Implementation

Referring now to FIG. 6, a system 20 for quadrilateral re-meshing of a 3D model using progressive implicit approximating levels according to the present invention is shown. As depicted, system 20 includes a computer system 22 deployed within a computer infrastructure 24. This is intended to demonstrate, among other things, that the present invention could be implemented within a network environment (e.g., the Internet, a wide area network (WAN), a local area network (LAN), a virtual private network (VPN), etc.), or on a stand-alone computer system. In the case of the former, communication throughout the network can occur via any combination of various types of communications links. For example, the communication links can comprise addressable connections that may utilize any combination of wired and/or wireless transmission methods. Where communications occur via the Internet, connectivity could be provided by conventional TCP/IP sockets-based protocol, and an Internet service provider could be used to establish connectivity to the Internet. Still yet, computer infrastructure 24 is intended to demonstrate that some or all of the components of system 20 could be deployed, managed, serviced, etc. by a service provider who offers to provide quadrilateral re-meshing of a 3D input model using progressive implicit approximating levels.

As shown, computer system 22 includes a processing unit 30, a memory 32, a bus 34, and input/output (I/O) interfaces 36. Further, computer system 22 is shown in communication with external I/O devices/resources 38 and storage system 40. In general, processing unit 30 executes computer program code, such as re-meshing system 50, which is stored in memory 32 and/or storage system 40. While executing computer program code, processing unit 30 can read and/or write data to/from memory 32, storage system 40, and/or I/O interfaces 36. Bus 34 provides a communication link between each of the components in computer system 22. External devices 38 can comprise any devices (e.g., keyboard, pointing device, display, etc.) that enable a user to interact with computer system 22 and/or any devices (e.g., network card, modem, etc.) that enable computer system 22 to communicate with one or more other computing devices.

Computer infrastructure 24 is only illustrative of various types of computer infrastructures for implementing the invention. For example, in one embodiment, computer infrastructure 24 comprises two or more computing devices (e.g., a server cluster) that communicate over a network to perform the various process steps of the invention. Moreover, computer system 22 is only representative of various possible computer systems that can include numerous combinations of hardware. To this extent, in other embodiments, computer system 22 can comprise any specific purpose computing article of manufacture comprising hardware and/or computer program code for performing specific functions, any computing article of manufacture that comprises a combination of specific purpose and general purpose hardware/software, or the like. In each case, the program code and hardware can be created using standard programming and engineering techniques, respectively. Moreover, processing unit 30 may comprise a single processing unit, or be distributed across one or more processing units in one or more locations, e.g., on a client and server. Similarly, memory 32 and/or storage system 40 can comprise any combination of various types of data storage and/or transmission media that reside at one or more physical locations. Further, I/O interfaces 36 can comprise any system for exchanging information with one or more external devices 38.

Still further, it is understood that one or more additional components (e.g., system software, math co-processing unit, etc.) not shown in FIG. 6 can be included in computer system 22. However, if computer system 22 comprises a handheld device or the like, it is understood that one or more external devices 38 (e.g., a display) and/or storage system(s) 40 could be contained within computer system 22, not externally as shown.

Storage system 40 can be any type of system (e.g., a database) capable of providing storage for information under the present invention, such existing network input models, QMs, algorithms etc. To this extent, storage system 40 could include one or more storage devices, such as a magnetic disk drive or an optical disk drive. In another embodiment, storage system 30 includes data distributed across, for example, a local area network (LAN), wide area network (WAN) or a storage area network (SAN) (not shown). Although not shown, additional components, such as cache memory, communication systems, system software, etc., may be incorporated into computer system 22.

Shown in memory 32 of computer system 22 is re-meshing system 50, which includes input system 52, quadrilateral mesh system 54, approximation system 56, extraction system 58, fitting system 60, estimation system 62, criterion system 64, topological operation system 66, and output system 68. These systems provide the functionality of the present invention as described above. It should be understood, however, that the same functionality could be provided with a different configuration of systems than is shown in FIG. 6.

In any event, input system 52 will receive 3D input model 70. Thereafter, quadrilateral mesh system 54 will provide a QM for input model 70. As indicated above, in one embodiment, the QM is provided as a bounding box of the input model. In another embodiment, the QM is provided as a polyhedron with quadrilateral faces. It should be appreciated, however, that other alternatives could be provided by quadrilateral mesh system 54.

In any event an implicit approximating field for a first approximating level (L) of the input model will be built by approximation system 56 using an implicit surface modeling technique. In a typical embodiment, the surface modeling technique is MLS. Once the implicit approximating field is built, extraction system 58 will extract an iso-contour thereof. Then, the QM will be fit to the first approximating level (L) by fitting system 60, and the fit between the QM and the first approximating level (L) will be estimated by estimation system 62.

Criterion system 64 will then determine whether this fit meets a predetermined quality criterion. If not, topological operation system 66 will perform at least one of a sequence of topological operations on the QM until the fit is satisfactory (meets the predetermined quality criterion). As described above, the sequence of topological operations typically include snapping vertices, splitting edges, extruding faces, and bridging faces of the quadrilateral mesh. This process will be iteratively repeated for subsequent approximating levels until the predetermined stopping criterion is met. When this occurs the QM 72 will be output by output system 68.

While shown and described herein as a method, system, and program product for quadrilateral re-meshing of a 3D model using progressive implicit approximating levels, it is understood that the invention further provides various alternative embodiments. For example, in one embodiment, the invention provides a computer-readable/useable medium that includes computer program code to enable a computer infrastructure to provide quadrilateral re-meshing of a 3D model using progressive implicit approximating levels. To this extent, the computer-readable/useable medium includes program code that implements each of the various process steps of the invention. It is understood that the terms computer-readable medium or computer useable medium comprises one or more of any type of physical embodiment of the program code. In particular, the computer-readable/useable medium can comprise program code embodied on one or more portable storage articles of manufacture (e.g., a compact disc, a magnetic disk, a tape, etc.), on one or more data storage portions of a computing device, such as memory 32 (FIG. 6) and/or storage system 40 (FIG. 6) (e.g., a fixed disk, a read-only memory, a random access memory, a cache memory, etc.

In another embodiment, the invention provides a business method that performs the process steps of the invention on a subscription, advertising, and/or fee basis. That is, a service provider, such as a Solution Integrator, could offer to provide quadrilateral re-meshing of a 3D model using progressive implicit approximating levels. In this case, the service provider can create, maintain, support, etc., a computer infrastructure, such as computer infrastructure 24 (FIG. 6) that performs the process steps of the invention for one or more customers. In return, the service provider can receive payment from the customer(s) under a subscription and/or fee agreement and/or the service provider can receive payment from the sale of advertising content to one or more third parties.

In still another embodiment, the invention provides a computer-implemented method for quadrilateral re-meshing of a 3D model using progressive implicit approximating levels. In this case, a computer infrastructure, such as computer infrastructure 24 (FIG. 6), can be provided and one or more systems for performing the process steps of the invention can be obtained (e.g., created, purchased, used, modified, etc.) and deployed to the computer infrastructure. To this extent, the deployment of a system can comprise one or more of (1) installing program code on a computing device, such as computer system 22 (FIG. 6), from a computer-readable medium; (2) adding one or more computing devices to the computer infrastructure; and (3) incorporating and/or modifying one or more existing systems of the computer infrastructure to enable the computer infrastructure to perform the process steps of the invention.

As used herein, it is understood that the terms “program code” and “computer program code” are synonymous and mean any expression, in any language, code or notation, of a set of instructions intended to cause a computing device having an information processing capability to perform a particular function either directly or after either or both of the following: (a) conversion to another language, code or notation; and/or (b) reproduction in a different material form. To this extent, program code can be embodied as one or more of: an application/software program, component software/a library of functions, an operating system, a basic I/O system/driver for a particular computing and/or I/O device, and the like.

The foregoing description of various aspects of the invention has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise form disclosed, and obviously, many modifications and variations are possible. Such modifications and variations that may be apparent to a person skilled in the art are intended to be included within the scope of the invention as defined by the accompanying claims.

Shen, Chen S., Boier-Martin, Ioana M.

Patent Priority Assignee Title
10055880, Dec 06 2016 ACTIVISION PUBLISHING, INC Methods and systems to modify a two dimensional facial image to increase dimensional depth and generate a facial image that appears three dimensional
10099140, Oct 08 2015 ACTIVISION PUBLISHING, INC ; Activision Publishing, Inc. System and method for generating personalized messaging campaigns for video game players
10118099, Dec 16 2014 ACTIVISION PUBLISHING, INC System and method for transparently styling non-player characters in a multiplayer video game
10137376, Dec 31 2012 ACTIVISION PUBLISHING, INC System and method for creating and streaming augmented game sessions
10179289, Jun 21 2016 Activision Publishing, Inc.; ACTIVISION PUBLISHING, INC System and method for reading graphically-encoded identifiers from physical trading cards through image-based template matching
10213682, Jun 15 2015 ACTIVISION PUBLISHING, INC System and method for uniquely identifying physical trading cards and incorporating trading card game items in a video game
10226701, Apr 29 2016 Activision Publishing, Inc. System and method for identifying spawn locations in a video game
10226703, Apr 01 2016 Activision Publishing, Inc.; ACTIVISION PUBLISHING, INC System and method of generating and providing interactive annotation items based on triggering events in a video game
10232272, Oct 21 2015 Activision Publishing, Inc. System and method for replaying video game streams
10245509, Oct 21 2015 Activision Publishing, Inc. System and method of inferring user interest in different aspects of video game streams
10284454, Nov 30 2007 Activision Publishing, Inc. Automatic increasing of capacity of a virtual space in a virtual world
10286314, May 14 2015 Activision Publishing, Inc. System and method for providing continuous gameplay in a multiplayer video game through an unbounded gameplay session
10286326, Jul 03 2014 Activision Publishing, Inc. Soft reservation system and method for multiplayer video games
10300390, Apr 01 2016 Activision Publishing, Inc.; ACTIVISION PUBLISHING, INC System and method of automatically annotating gameplay of a video game based on triggering events
10315113, May 14 2015 Activision Publishing, Inc. System and method for simulating gameplay of nonplayer characters distributed across networked end user devices
10322351, Jul 03 2014 Activision Publishing, Inc. Matchmaking system and method for multiplayer video games
10376781, Oct 21 2015 Activision Publishing, Inc. System and method of generating and distributing video game streams
10376792, Jul 03 2014 Activision Publishing, Inc. Group composition matchmaking system and method for multiplayer video games
10376793, Feb 18 2010 Activision Publishing, Inc. Videogame system and method that enables characters to earn virtual fans by completing secondary objectives
10421019, May 12 2010 Activision Publishing, Inc. System and method for enabling players to participate in asynchronous, competitive challenges
10463964, Nov 17 2016 ACTIVISION PUBLISHING, INC Systems and methods for the real-time generation of in-game, locally accessible heatmaps
10463971, Dec 06 2017 ACTIVISION PUBLISHING, INC System and method for validating video gaming data
10471348, Jul 24 2015 Activision Publishing, Inc.; ACTIVISION PUBLISHING, INC System and method for creating and sharing customized video game weapon configurations in multiplayer video games via one or more social networks
10486068, May 14 2015 Activision Publishing, Inc. System and method for providing dynamically variable maps in a video game
10500498, Nov 29 2016 Activision Publishing, Inc. System and method for optimizing virtual games
10537809, Dec 06 2017 ACTIVISION PUBLISHING, INC System and method for validating video gaming data
10561945, Sep 27 2017 Activision Publishing, Inc. Methods and systems for incentivizing team cooperation in multiplayer gaming environments
10573065, Jul 29 2016 ACTIVISION PUBLISHING, INC Systems and methods for automating the personalization of blendshape rigs based on performance capture data
10586380, Jul 29 2016 ACTIVISION PUBLISHING, INC Systems and methods for automating the animation of blendshape rigs
10596471, Dec 22 2017 Activision Publishing, Inc. Systems and methods for enabling audience participation in multi-player video game play sessions
10627983, Dec 24 2007 Activision Publishing, Inc. Generating data for managing encounters in a virtual world environment
10643384, Feb 08 2018 GOOGLE LLC Machine learning-based geometric mesh simplification
10650539, Dec 06 2016 Activision Publishing, Inc. Methods and systems to modify a two dimensional facial image to increase dimensional depth and generate a facial image that appears three dimensional
10668367, Jun 15 2015 ACTIVISION PUBLISHING, INC System and method for uniquely identifying physical trading cards and incorporating trading card game items in a video game
10668381, Dec 16 2014 Activision Publishing, Inc. System and method for transparently styling non-player characters in a multiplayer video game
10694352, Oct 28 2015 ACTIVISION PUBLISHING, INC System and method of using physical objects to control software access
10702779, Nov 17 2016 Activision Publishing, Inc. Bandwidth and processing efficient heatmaps
10709981, Nov 17 2016 ACTIVISION PUBLISHING, INC Systems and methods for the real-time generation of in-game, locally accessible barrier-aware heatmaps
10765948, Dec 22 2017 ACTIVISION PUBLISHING, INC Video game content aggregation, normalization, and publication systems and methods
10807003, Apr 29 2016 Activision Publishing, Inc. Systems and methods for determining distances required to achieve a line of site between nodes
10818060, Sep 05 2017 Activision Publishing, Inc. Systems and methods for guiding motion capture actors using a motion reference system
10835818, Jul 24 2015 Activision Publishing, Inc. Systems and methods for customizing weapons and sharing customized weapons via social networks
10857468, Jul 03 2014 Activision Publishing, Inc. Systems and methods for dynamically weighing match variables to better tune player matches
10861079, Feb 23 2017 ACTIVISION PUBLISHING, INC Flexible online pre-ordering system for media
10864443, Dec 22 2017 ACTIVISION PUBLISHING, INC Video game content aggregation, normalization, and publication systems and methods
10898813, Oct 21 2015 Activision Publishing, Inc. Methods and systems for generating and providing virtual objects and/or playable recreations of gameplay
10905963, Dec 31 2012 Activision Publishing, Inc. System and method for creating and streaming augmented game sessions
10974150, Sep 27 2017 Activision Publishing, Inc. Methods and systems for improved content customization in multiplayer gaming environments
10981051, Dec 19 2017 ACTIVISION PUBLISHING, INC Synchronized, fully programmable game controllers
10981069, Mar 07 2008 Activision Publishing, Inc. Methods and systems for determining the authenticity of copied objects in a virtual environment
10987588, Nov 29 2016 Activision Publishing, Inc. System and method for optimizing virtual games
10991110, Dec 06 2016 Activision Publishing, Inc. Methods and systems to modify a two dimensional facial image to increase dimensional depth and generate a facial image that appears three dimensional
11040286, Sep 27 2017 Activision Publishing, Inc. Methods and systems for improved content generation in multiplayer gaming environments
11097193, Sep 11 2019 ACTIVISION PUBLISHING, INC Methods and systems for increasing player engagement in multiplayer gaming environments
11115712, Dec 15 2018 ACTIVISION PUBLISHING, INC Systems and methods for indexing, searching for, and retrieving digital media
11117055, Dec 06 2017 ACTIVISION PUBLISHING, INC Systems and methods for validating leaderboard gaming data
11148063, Dec 22 2017 Activision Publishing, Inc. Systems and methods for providing a crowd advantage to one or more players in the course of a multi-player video game play session
11185784, Oct 08 2015 Activision Publishing, Inc. System and method for generating personalized messaging campaigns for video game players
11189084, Jul 29 2016 Activision Publishing, Inc. Systems and methods for executing improved iterative optimization processes to personify blendshape rigs
11192028, Nov 19 2018 ACTIVISION PUBLISHING, INC Systems and methods for the real-time customization of video game content based on player data
11207596, Nov 17 2016 Activision Publishing, Inc. Systems and methods for the real-time generation of in-game, locally accessible barrier-aware heatmaps
11213753, Nov 17 2016 Activision Publishing, Inc. Systems and methods for the generation of heatmaps
11224807, May 14 2015 Activision Publishing, Inc. System and method for providing dynamically variable maps in a video game
11263670, Nov 19 2018 ACTIVISION PUBLISHING, INC Systems and methods for dynamically modifying video game content based on non-video gaming content being concurrently experienced by a user
11278813, Dec 22 2017 ACTIVISION PUBLISHING, INC Systems and methods for enabling audience participation in bonus game play sessions
11305191, Dec 20 2018 ACTIVISION PUBLISHING, INC Systems and methods for controlling camera perspectives, movements, and displays of video game gameplay
11310346, Oct 21 2015 Activision Publishing, Inc. System and method of generating and distributing video game streams
11344808, Jun 28 2019 ACTIVISION PUBLISHING, INC Systems and methods for dynamically generating and modulating music based on gaming events, player profiles and/or player reactions
11351459, Aug 18 2020 Activision Publishing, Inc. Multiplayer video games with virtual characters having dynamically generated attribute profiles unconstrained by predefined discrete values
11351466, Dec 05 2014 ACTIVISION PUBLISHING, ING.; ACTIVISION PUBLISHING, INC System and method for customizing a replay of one or more game events in a video game
11413536, Dec 22 2017 Activision Publishing, Inc. Systems and methods for managing virtual items across multiple video game environments
11420119, May 14 2015 Activision Publishing, Inc. Systems and methods for initiating conversion between bounded gameplay sessions and unbounded gameplay sessions
11420122, Dec 23 2019 Activision Publishing, Inc.; ACTIVISION PUBLISHING, INC Systems and methods for controlling camera perspectives, movements, and displays of video game gameplay
11423556, Dec 06 2016 Activision Publishing, Inc. Methods and systems to modify two dimensional facial images in a video to generate, in real-time, facial images that appear three dimensional
11423605, Nov 01 2019 ACTIVISION PUBLISHING, INC Systems and methods for remastering a game space while maintaining the underlying game simulation
11439904, Nov 11 2020 ACTIVISION PUBLISHING, INC Systems and methods for imparting dynamic and realistic movement to player-controlled avatars in video games
11439909, Apr 01 2016 Activision Publishing, Inc. Systems and methods of generating and sharing social messages based on triggering events in a video game
11446582, Dec 31 2012 Activision Publishing, Inc. System and method for streaming game sessions to third party gaming consoles
11524234, Aug 18 2020 Activision Publishing, Inc. Multiplayer video games with virtual characters having dynamically modified fields of view
11524237, May 14 2015 Activision Publishing, Inc. Systems and methods for distributing the generation of nonplayer characters across networked end user devices for use in simulated NPC gameplay sessions
11537209, Dec 17 2019 ACTIVISION PUBLISHING, INC Systems and methods for guiding actors using a motion capture reference system
11563774, Dec 27 2019 Activision Publishing, Inc.; ACTIVISION PUBLISHING, INC Systems and methods for tracking and identifying phishing website authors
11666831, Dec 22 2017 Activision Publishing, Inc. Systems and methods for determining game events based on a crowd advantage of one or more players in the course of a multi-player video game play session
11679330, Dec 18 2018 ACTIVISION PUBLISHING, INC Systems and methods for generating improved non-player characters
11679333, Oct 21 2015 Activision Publishing, Inc. Methods and systems for generating a video game stream based on an obtained game log
11704703, Nov 19 2018 Activision Publishing, Inc. Systems and methods for dynamically modifying video game content based on non-video gaming content being concurrently experienced by a user
11709551, Dec 17 2019 Activision Publishing, Inc. Systems and methods for guiding actors using a motion capture reference system
11712627, Nov 08 2019 ACTIVISION PUBLISHING, INC System and method for providing conditional access to virtual gaming items
11717753, Sep 29 2020 ACTIVISION PUBLISHING, INC Methods and systems for generating modified level of detail visual assets in a video game
11724188, Sep 29 2020 ACTIVISION PUBLISHING, INC Methods and systems for selecting a level of detail visual asset during the execution of a video game
11741530, Feb 23 2017 Activision Publishing, Inc. Flexible online pre-ordering system for media
11794104, Nov 11 2020 Activision Publishing, Inc. Systems and methods for pivoting player-controlled avatars in video games
11794107, Dec 30 2020 ACTIVISION PUBLISHING, INC Systems and methods for improved collision detection in video games
11806626, Dec 22 2017 Activision Publishing, Inc. Systems and methods for incentivizing player participation in bonus game play sessions
11833423, Sep 29 2020 ACTIVISION PUBLISHING, INC Methods and systems for generating level of detail visual assets in a video game
11839814, Dec 23 2019 Activision Publishing, Inc. Systems and methods for controlling camera perspectives, movements, and displays of video game gameplay
11853439, Dec 30 2020 ACTIVISION PUBLISHING, INC Distributed data storage system providing enhanced security
11857876, May 14 2015 Activision Publishing, Inc. System and method for providing dynamically variable maps in a video game
11883745, Nov 19 2018 Activision Publishing, Inc. Systems and methods for providing a tailored video game based on a player defined time period
11896905, May 14 2015 Activision Publishing, Inc. Methods and systems for continuing to execute a simulation after processing resources go offline
11911689, Dec 19 2017 Activision Publishing, Inc. Synchronized, fully programmable game controllers
11957984, Mar 07 2008 Activision Publishing, Inc. Methods and systems for determining the authenticity of modified objects in a virtual environment
11972086, Nov 30 2007 Activision Publishing, Inc. Automatic increasing of capacity of a virtual space in a virtual world
11986734, Dec 22 2017 Activision Publishing, Inc. Video game content aggregation, normalization, and publication systems and methods
ER4596,
ER4703,
Patent Priority Assignee Title
6100893, May 24 1996 Washington, University of Constructing solid models using implicit functions defining connectivity relationships among layers of an object to be modeled
6795069, May 29 2002 Mitsubishi Electric Research Laboratories, Inc.; Mitsubishi Electric Research Laboratories, Inc Free-form modeling of objects with variational implicit surfaces
7158131, Oct 08 2002 Riken Implicit function rendering method of nonmanifold, direct drawing method of implicit function curved surface and programs thereof
7542036, Feb 19 2003 California Institute of Technology Level set surface editing operators
20020149585,
20040075659,
20060101103,
///////
Executed onAssignorAssigneeConveyanceFrameReelDoc
Jun 11 2008International Business Machines Corporation(assignment on the face of the patent)
Dec 31 2012International Business Machines CorporationACTIVISION PUBLISHING, INC ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0299000285 pdf
Jan 31 2014ACTIVISION PUBLISHING, INC BANK OF AMERICA, N A SECURITY AGREEMENT0322400257 pdf
Oct 14 2016BANK OF AMERICA, N A ACTIVISION BLIZZARD INC RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS 0403810487 pdf
Oct 14 2016BANK OF AMERICA, N A ACTIVISION PUBLISHING, INC RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS 0403810487 pdf
Oct 14 2016BANK OF AMERICA, N A ACTIVISION ENTERTAINMENT HOLDINGS, INC RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS 0403810487 pdf
Oct 14 2016BANK OF AMERICA, N A BLIZZARD ENTERTAINMENT, INC RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS 0403810487 pdf
Date Maintenance Fee Events
Jun 01 2010ASPN: Payor Number Assigned.
Dec 16 2013M1551: Payment of Maintenance Fee, 4th Year, Large Entity.
Dec 15 2017M1552: Payment of Maintenance Fee, 8th Year, Large Entity.
Dec 15 2021M1553: Payment of Maintenance Fee, 12th Year, Large Entity.


Date Maintenance Schedule
Jun 15 20134 years fee payment window open
Dec 15 20136 months grace period start (w surcharge)
Jun 15 2014patent expiry (for year 4)
Jun 15 20162 years to revive unintentionally abandoned end. (for year 4)
Jun 15 20178 years fee payment window open
Dec 15 20176 months grace period start (w surcharge)
Jun 15 2018patent expiry (for year 8)
Jun 15 20202 years to revive unintentionally abandoned end. (for year 8)
Jun 15 202112 years fee payment window open
Dec 15 20216 months grace period start (w surcharge)
Jun 15 2022patent expiry (for year 12)
Jun 15 20242 years to revive unintentionally abandoned end. (for year 12)