WO2015061914A1 - Methods and systems for generating polycube segmentations from input meshes of objects - Google Patents
Methods and systems for generating polycube segmentations from input meshes of objects Download PDFInfo
- Publication number
- WO2015061914A1 WO2015061914A1 PCT/CA2014/051055 CA2014051055W WO2015061914A1 WO 2015061914 A1 WO2015061914 A1 WO 2015061914A1 CA 2014051055 W CA2014051055 W CA 2014051055W WO 2015061914 A1 WO2015061914 A1 WO 2015061914A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- branch
- polycube
- segmentation
- charts
- perturbed
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T17/00—Three dimensional [3D] modelling, e.g. data description of 3D objects
- G06T17/20—Finite element generation, e.g. wire-frame surface description, tesselation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T19/00—Manipulating 3D models or images for computer graphics
- G06T19/20—Editing of 3D images, e.g. changing shapes or colours, aligning objects or positioning parts
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T11/00—2D [Two Dimensional] image generation
- G06T11/40—Filling a planar surface by adding surface attributes, e.g. colour or texture
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T15/00—3D [Three Dimensional] image rendering
- G06T15/005—General purpose rendering architectures
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T15/00—3D [Three Dimensional] image rendering
- G06T15/04—Texture mapping
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T17/00—Three dimensional [3D] modelling, e.g. data description of 3D objects
- G06T17/20—Finite element generation, e.g. wire-frame surface description, tesselation
- G06T17/205—Re-meshing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T2219/00—Indexing scheme for manipulating 3D models or images for computer graphics
- G06T2219/20—Indexing scheme for editing of 3D models
- G06T2219/2021—Shape modification
Definitions
- This invention relates generally to digital (e.g. computer) representations of objects.
- Particular embodiments provide methods and systems for generating polycube segmentations for input objects.
- Particular embodiments provide methods and systems for using polycube segmentations to generate polycube representations and/or multi-sweep representations of input objects.
- Three-dimensional models of input objects may be digitally modeled (e.g. on a computer system and/or other suitable processor(s)) in volumetric representations known as tetrahedral- meshes or "tet-meshes".
- volumetric representations known as tetrahedral- meshes or "tet-meshes".
- isotropic volumetric tet-meshes can be generated from isotropic surface meshes using known software, such as TetgenTM.
- Non-isotropic surface meshes can be re-meshed using known software such as GraphiteTM and the re-meshed surface meshes may then be used to generate suitable volumetric tet-meshes.
- a polycube is a solid formed by joining several cubes face to face.
- Polycubes may be used as base complexes for parameterizing closed surfaces and volumes.
- Non-limiting examples of uses for polycube representations include: surface texture mapping (see TARINI, M., HORMANN, K., CIGNONI, P., AND MONTANI, C. 2004. PolyCube-Maps. ACM Transactions on Graphics 23, 3 (Aug.), 853-860. Proc. of ACM SIGGRAPH 2004; and YAO, C, AND LEE, T. 2008. Adaptive geometry image.
- Polycubes are used in computer graphics applications because they may allow for efficient storage of geometry and/or texture information generally, and may specifically provide relatively regular and/or compact representations of graphical objects. Such representations can confer certain advantages in some computer-implemented graphical systems; for example, in some circumstances, such representations may be conveniently cached, allow for relatively straightforward texture filtering, and provide smooth face boundaries for texturing applications. Polycubes also find application in GPU subdivision and multiresolution representations, and can serve as intermediate primitives for quad meshing or hex meshing operations.
- a difficulty associated with generating polycube representations of input objects involves addressing the tradeoff between parametrization distortion and compactness.
- Parameterization distortion represents the distortion between the surface geometry of the input object and the surface geometry of the polycube representation.
- Compactness may be indicated by the number of polycube faces and/or the number of singularities (corners of the polycube faces) and/or the length of the boundaries between polycube faces of the polycube representation.
- a compact polycube representation i.e. correspondingly low polycube face counts and/or singularity counts and/or correspondingly short chart boundaries).
- Compact polycube representations permit relatively low element counts for applications such as hex meshing, volume fitting and/or surface fitting.
- a polycube segmentation of an input model corresponding to an input object may be used herein to describe an assignment of a polycube axis label ( ⁇ X, ⁇ Y, ⁇ Z) to each outer surface face (e.g. each triangular surface face in the case of a tet-mesh model) on a surface of the object.
- a polycube axis label ⁇ X, ⁇ Y, ⁇ Z
- contiguous groups of surface faces e.g. surface triangles
- a polycube representation (or, for brevity, a polycube) may be extracted from a polycube segmentation.
- a chart boundary of a polycube segmentation may be defined between a pair of adjacent charts to be a sequence of edges shared by triangles belonging to the two different charts.
- such a boundary maps to an axially aligned straight boundary between a pair of polycube faces corresponding to the pair of charts.
- the boundary between a pair of polycube faces having normal vectors along first and second Cartesian axes should be oriented along the third Cartesian axis. For example, if two adjacent polycube faces have normal vectors oriented in the +X and +Y directions, the boundary between the pair of polycube faces will be oriented along the Z-axis and should have either a +Z direction or a -Z direction.
- non-monotone chart boundaries are chart boundaries where the direction of the boundary switches sign with respect to the axis along which it should be oriented.
- FIG. 1 is a schematic representation of a number of views of a polycube segmentation 4 of an input object 2 showing the charts of the polycube segmentation (as differently colored regions).
- the charts of the Figure 1 segmentation comprise a number of turning points and, consequently, are non- monotone. Mapping a non-monotone chart boundary having a turning point to a corresponding polycube edge (which is straight and axis-aligned) involves introducing extreme distortion.
- One aspect of the invention provides a method for generating a polycube segmentation of an input object.
- the method comprises: providing, at a processor, an input mesh representation of the input object comprising a plurality of surface faces representing a surface of the input object; generating, by the processor, an initial polycube labeling for the surface faces, wherein generating the initial polycube labeling comprises assigning, to each surface face, a label which is one of six directions ( ⁇ X, ⁇ Y, ⁇ Z) aligned with a set of Cartesian axes, the initial polycube labeling defining a plurality of charts, each chart comprising a contiguous patch of one or more surface faces having the same label, and wherein generating the initial polycube labeling comprises effecting, by the processor, a tradeoff between competing objectives of: making the initial polycube labeling relatively compact; and making the initial polycube labeling relatively faithful to a surface geometry of the input object; and generating, by the processor, an updated polycube segmentation, wherein
- polycube segmentations may be further processed to generate three-dimensional polycube representations of the input object. In some embodiments, polycube segmentations may be further processed to generate three-dimensional multi-sweep
- Systems may comprise a processor configured to perform such methods for generating polycube segmentations, polycube representations and/or multi-sweep representations.
- Non- transitory computer- readable media may be provided with instructions, which (when executed by a suitably configured processor, cause the processor to generate such polycube segmentations, polycube representations and/or multi-sweep representations.
- the methods described herein are encoded on computer readable media and which contain instructions executable by a processor to cause the processor to perform one or more of the methods described herein.
- processors are configured to perform one or more of the methods described herein.
- Figure 1 is an example of a polycube segmentation which includes a number of non- monotone chart boundaries and highlights a number of their respective turning points.
- Figure 2 is a schematic representation of a computer-implemented method for generating an all-monotone polycube segmentation of an input object model according to a particular embodiment of the invention and an optional method for using the polycube segmentation to generate a three-dimensional polycube representation of the input object.
- Figure 2A is a graphical depiction of the application of the Figure 2 methods to an exemplary input object.
- Figure 3 is a schematic depiction of a computer-implemented method for generating an updated polycube segmentation, which may be used in the Figure 2 methods according to a particular embodiment.
- Figure 3A is a graphical depiction of the application of the Figure 3 method to an exemplary initial polycube labeling.
- Figure 4 is a schematic depiction of a computer-implemented method for generating an updated polycube segmentation, which may be used in the Figure 2 methods according to another particular embodiment.
- Figure 4A is a graphical depiction of the application of the Figure 4 method to an exemplary initial polycube labeling.
- Figure 5 is a schematic representation of a system according to a particular embodiment which may be used to implement a number of the methods described herein.
- Figure 6 is a schematic depiction of a computer-implemented method for extracting a polycube representation which may be used in the Figure 2 method according to a particular embodiment.
- Figure 7A is a schematic representation of a computer-implemented method for generating an all-monotone polycube segmentation of an input object model according to a particular embodiment of the invention and an optional method for using the polycube segmentation to generate a three-dimensional multi-sweep representation of the input object.
- Figure 7B is a schematic depiction of a computer-implemented method for extracting a multi- sweep representation which may be used in the Figure 7A method according to a particular embodiment.
- aspects of the invention provide methods for generating a polycube segmentation of an input object.
- the methods comprise: providing an input mesh of the object comprising a plurality of surface faces; generating an initial polycube labeling for the faces by assigning, to each face, a label which is one of six directions ( ⁇ X, ⁇ Y, ⁇ Z) aligned with a set of Cartesian axes, the initial polycube labeling defining a plurality of charts, and generating the initial polycube labeling comprising effecting a tradeoff between competing objectives of: making the initial polycube labeling relatively compact; and making the initial polycube labeling relatively faithful to the input object.
- the method further comprises generating an updated polycube segmentation by changing the label assigned to each of one or more surface faces and thereby modifying one or more of the charts to provide the charts with monotonic boundaries.
- polycube segmentations may be further processed to generate three-dimensional polycube representations of the input object. In some embodiments, polycube segmentations may be further processed to generate three-dimensional multi-sweep
- Systems may comprise a processor configured to perform such methods for generating polycube segmentations, polycube representations and/or multi-sweep representations.
- Non- transitory computer- readable media may be provided with instructions, which (when executed by a suitably configured processor, cause the processor to generate such polycube segmentations, polycube representations and/or multi-sweep
- processors are implemented by suitably configured computers and/or suitably configured processors (referred to herein as a "computer system").
- a processor, computer or computer readable medium may include one or more processors, computers or computer readable media in communication with each other through one or more networks or communication mediums.
- the one or more processors and/or computers may comprise any suitable processing device, such as, for example, application specific circuits, programmable logic controllers, field programmable gate arrays, microcontrollers, microprocessors, computers, virtual machines and/or electronic circuits.
- the one or more computer readable media may comprise any suitable memory devices, such as, for example, random access memory, flash memory, read only memory, hard disc drives, optical drives and optical drive media, or flash drives. Further, where a communication to a device or a direction of a device is referenced it may be communicated over any suitable electronic communication medium and in any suitable format, such as, for example, wired or wireless mediums, compressed or uncompressed formats, encrypted or unencrypted formats.
- Figure 2 is a schematic representation of a computer-implemented method 10 for generating an all-monotone polycube segmentation of an input model of an object according to a particular embodiment of the invention.
- Figure 2 also illustrates an optional method 10A, which uses the polycube segmentation output from method 10 to generate a three-dimensional polycube representation of the input model and a mapping between the polycube representation and the input model.
- Methods 10, 10A may be performed by a suitably configured computer system.
- the output of a computer system performing the Figure 2 method 10 is an all-monotone polycube segmentation 22 based on an input model 14 that represents a corresponding input object.
- a polycube segmentation comprises an assignment of a polycube axis label ( ⁇ X, ⁇ Y, ⁇ Z) to each surface face (e.g. each triangular surface face in the case of a tet- mesh) on a surface of the input model.
- polycube axis labels ⁇ X, ⁇ Y, ⁇ Z
- contiguous groups of surface faces that are assigned the same label may be referred to herein as charts.
- a chart boundary of a polycube segmentation may be defined between a pair of adjacent charts to comprise a sequence of edges shared by triangles belonging to the two different charts.
- the chart boundary of a polycube segmentation has an associated axial orientation. For example, if two adjacent charts have +X and +Y labels, the boundary between the pair of charts will be associated with the Z- axis and should have either a +Z direction or a -Z direction.
- the all-monotone polycube segmentation 22 generated by method 10 is a polycube segmentation where all of the chart boundaries are monotonic - i.e. none of the chart boundaries have turning points where the direction of the boundary switches sign with respect to the axis along which it is associated.
- the all-monotone polycube segmentation 22 generated by a computer system performing method 10 meets one or more additional criteria for a valid polycube segmentation.
- These criteria include: (i) all charts of polycube segmentation 22 have at least four neighbors; (ii) no two charts of polycube segmentation 22 with opposing label orientations along the same axis (e.g. a +Z chart and -Z chart share a chart boundary); and (iii) each chart corner (chart vertex) of polycube segmentation 22 has a valence of three - i.e. is a vertex for three charts.
- any polycube extracted by a computer system from the polycube segmentation to have relatively low parameterization distortion (e.g. to have a surface geometry that is relatively similar to the surface geometry of the input model) and to be relatively compact (e.g. to have a small number of polycube faces, a relatively small number of polycube corners and/or relatively small lengths of boundaries between polycube faces of the polycube representation).
- relatively low parameterization distortion e.g. to have a surface geometry that is relatively similar to the surface geometry of the input model
- relatively compact e.g. to have a small number of polycube faces, a relatively small number of polycube corners and/or relatively small lengths of boundaries between polycube faces of the polycube representation.
- the particular embodiments provide techniques for generating polycube segmentations, which balance the competing objectives of minimizing parameterization distortion and being relatively compact.
- this balance is achieved by performing, by a suitably configured computer system, one or more computational optimizations, which optimize cost function(s) wherein the cost function(s) assign cost based at least in part on a metric associated with parameterization distortion and based at least in part on a metric which assigns cost based at least in part on compactness.
- cost function(s) comprise a fidelity term which assigns cost based at least in part on parameterization distortion and a compactness term which assigns cost based at least in part on compactness.
- the compactness term may be based, at least in part, on the number of charts, the number of chart corners and/or the length of chart boundaries.
- the fidelity term(s) are based, for each surface face of the input model, at least in part, on an angle between the assigned label and the normal vector of the face.
- these cost functions may be locally perturbed in the vicinity of turning points in effort to achieve monotonic chart boundaries. In some embodiments, these perturbations may be applied to the fidelity term(s) of the cost functions.
- Method 10 commences in block 12, which involves a computer system receiving an input model 14 that represents an input object (not expressly shown).
- Input model 14 may comprise a digital representation implemented on a computer system which models the characteristics of the input object.
- Input model 14 may generally model any input object.
- input model 14 may comprise object model representations generated by computer systems using modelling software such as SolidWorksTM, BlenderTM, AutoCADTM, Autodesk MayaTM, and/or other suitable software.
- input model 14 may comprise a volumetric model, which comprises a plurality of surface points (i.e. points intended to be on the surface of the input object) and a plurality of interior points (i.e. points intended to be on an interior of the input object). This is not necessary, however, and in some embodiments, all-monotone polycube segmentation 22 can be generated by a computer system performing method 10 when block 12 receives only a surface model of the input object.
- input model 14 comprises a mesh-based representation of the input object.
- input model 14 may comprise an isotropic volumetric mesh, which may comprise a tetrahedral mesh (tet-mesh).
- tet-mesh tetrahedral mesh
- input model 14 comprises a plurality of notional tetrahedrons, which model the input object.
- a typical input model 14 may comprise on the order of 10 5 , 107 , or more notional tetrahedrons.
- the surface points and interior points of input model 14 may comprise the vertices of the notional tetrahedrons.
- Each notional tetrahedron may also comprise a plurality of linear edges that extended between corresponding pairs of vertices and a plurality of triangular faces defined by corresponding triplets of edges.
- input model 14 may comprise a surface triangular mesh. Isotropic volumetric tet-meshes can be generated from surface meshes or otherwise generated using known techniques.
- input model 14 may comprise other forms of surface polygonal- mesh or volumetric polyhedral-mesh representations of the input object.
- Such polygonal surface meshes may comprise notional polygons comprising a corresponding plurality of surface vertices, a plurality of surface edges that extend between corresponding pairs of vertices and a plurality of faces defined by corresponding pluralities of edges.
- Such polyhedral mesh representations may comprise notional polyhedrons comprising a corresponding plurality of vertices, a plurality of edges that extend between corresponding pairs vertices and a plurality of faces defined by corresponding pluralities of edges.
- block 12 may optionally involve a computer system selecting and/or receiving a global Cartesian coordinate system (i.e. global ( ⁇ X, ⁇ Y, ⁇ Z) axes) which will be used for the purposes of subsequent processing of input object 14.
- the block 12 selection of the global Cartesian coordinate system may be provided by a user, may be automatically assigned by the computer system or may be part of input object model 14.
- This block 12 selection of global Cartesian coordinate system may be based on the shape of the input object as represented by input model 14. For example, if the input model 14 can be interpreted to have one or more flat (i.e. planar) surfaces, then the block 12 coordinate system selection may be made such that such planar surfaces correspond to particular axes of the global coordinate system.
- the block 10 global Cartesian coordinate system may be received (e.g. as part of input model 14 or otherwise) or arbitrarily assigned.
- initial polycube labeling 18 which comprises, for each surface triangle of input model 14, assigning an initial label which is one of six directions ( ⁇ X, ⁇ Y, ⁇ Z) aligned with a set of Cartesian axes.
- initial polycube labeling 18 is a polycube segmentation, but unlike updated polycube segmentation 22 (discussed in more detail below), initial polycube labeling 18 may, in the general case, be permitted to comprise charts with non-monotone boundaries and may not satisfy all of the aforementioned criteria sufficient for a valid polycube segmentation.
- the generation of initial polycube labeling 18 may comprise effecting, by the computer system, a tradeoff between competing objectives of: making initial polycube labeling 18 relatively compact (e.g. with a relatively low number of initial charts and/or a relatively low number of chart corners and/or relatively low chart boundary lengths and/or some other suitable metric of compactness); and making initial polycube labeling 18 relatively faithful to input model 14 (e.g. by providing, for each surface triangle of input model 14, a relatively small angle between its assigned initial label and a normal vector of the surface triangle).
- the computer system effects this tradeoff between these competing objectives in block 16 by performing an initial discrete computational optimization which effects an initial balance between these competing objectives.
- the block 16 generation of initial polycube labeling 18 involves a computer system applying these objectives on a local scale.
- the resulting initial polycube labeling 18 may be said be a locally optimum labeling.
- this block 16 computational generation of initial polycube labeling 18 involves a computer system performing a discrete optimization which minimizes a cost function (also known as an energy function or an objective function).
- the computer system uses such a cost function to assign cost based at least in part on faithfulness (or fidelity) of the initial polycube labeling 18 to the surface geometry of input model 14 and to assign cost based at least in part on compactness of the initial polycube labeling 18.
- the computer system uses such a cost function to assign cost based at least in part on a metric that is associated with (or correlated with) faithfulness (or fidelity) of the initial polycube labeling 18 to the surface geometry of input model 14 and/or to assign cost based at least in part on a metric that is associated with (or correlated with) compactness of the initial polycube labeling.
- such a cost function comprises a first term (referred to herein as a fidelity term), which is based at least in part on a metric of (or models) the faithfulness (or fidelity) of initial polycube labeling 18 to the surface geometry of input model 14 and a second term (referred to herein as a compactness term), which is based at least in part on a metric of (or models) the compactness of initial poly cube labeling 18.
- Equation (1) An example of such a cost function is provided by equation (1): where: s represents a label which may be assigned to a particular surface triangle of input model 14 and s is an element of the set ⁇ +X,-X, + Y,-Y, +Z,-Z ⁇ , F t (s t ) is a fidelity term which prescribes a cost of assigning the label s t to a surface triangle t; C pq (s p ,s q ) is a compactness term which prescribes a cost associated with assigning the label s p to a surface triangle p and a label s q to a surface triangle q, where surface triangle q is adjacent surface triangle p; T represents the set of surface triangles on input model 14; E represents the set of surface edges in input model 14; and c represents a relative weight (which may be user-configurable) between the fidelity term and the compactness term. It will be appreciated that the higher the value of the relative weight c, the greater the influence
- One local proxy (i.e. metric) associated with parameterization distortion which can be used by the computer system as a basis for the fidelity term is the angle between the normal vector of each surface triangle (of input model 14) and the oriented axis of the label assigned to the face by the block 16 initial labeling.
- the fidelity term may prescribe relatively high cost when the angle between the normal vector of a surface triangle and the oriented axis of its block 16 assigned label is relatively high and may prescribe a relatively low cost when the angle between the normal vector of a surface triangle and the oriented axis of its block 16 assigned label is relatively low.
- the compactness term may prescribe relatively high cost when the labels applied to charts change frequently (corresponding to a relatively large number of charts or relatively short chart boundary lengths) and relatively low cost when the labels applied to charts are relatively constant (corresponding to a small number of charts or relatively long chart boundary lengths). Accordingly, in some embodiments, the computer system sets the compactness term C pq (s p , s q ) to 0 when adjacent triangles p and q share the same label.
- the computer system may base the compactness term C pq (s p , s q ) at least in part on the dihedral angle between the normal vectors (n p , n q ) of the adjacent triangles.
- the adjacent triangles p and q may be immediately adjacent faces (i.e. triangles that share a common edge).
- other suitable metrics of adjacency may be used for the purposes of evaluating the compactness term
- C pq (s p , s q ) the compactness term for adjacent triangles p and q is given by:
- the compactness term C pq (s p , s q ) for adjacent triangles p and q is given by:
- the computer system may perform a discrete optimization to minimize (or otherwise optimize) the cost function at block 16.
- the outputs of the computer system after performing the block 16 optimization are the initial surface labels ( ⁇ X, ⁇ Y, ⁇ Z) for the surface triangles of input model 14 which make up initial polycube labeling 18.
- Any suitable discrete optimization or labeling technique may be used by the computer system to perform the block 16 computational optimization.
- the fidelity costs are determinable by the computer system independently of the compactness cost (e.g. in the case of the cost functions of equations (1), (2), (3a) and (3b).
- the fidelity costs are determinable by the computer system on a per-triangle basis (i.e.
- the computer system may, for each triangle, compute the fidelity costs associated with assigning each of the six surface labels ( ⁇ X, ⁇ Y, ⁇ Z) as part of the block 16 discrete optimization.
- the computer system may output the initial fidelity costs associated with each of the six surface labels ( ⁇ X, ⁇ Y, ⁇ Z) for each triangle at block 16 (e.g. as a part of initial polycube labeling 18 or as separate data related to initial polycube labeling 18).
- the computer system need not output the fidelity costs at block 16, as (with some cost functions) it may not be possible to determine fidelity costs independently.
- the computer system uses a graph-cut multi-label optimization framework at block 16 as described at: http://vision.csd.uwo.ca/code/gco-v3.0.zip; BOYKOV, Y., AND KOLMOGOROV, V. 2001.
- the computer system uses an iterative min-cut
- the computer system may also be configured to account for one or more of the criteria described above for a valid polycube segmentation at the block 16 computational optimization.
- one of the aforementioned criteria for a valid polycube segmentation (which happens to be a locally evaluable criterion) is that no two charts of a valid polycube segmentation which share a chart boundary may have opposing label orientations along the same axis (e.g. +Z and -Z).
- the computer system prevents two adjacent surface triangles p and q which share an edge or a vertex from being assigned opposite direction labels (i.e. +X and -X; +Y and -Y; or +Z and -Z) at block 16. This criteria may be accounted for by the computer system in block 16 by adding an additional term to the cost function which assigns a cost to this type of labeling which is effectively infinity (e.g.
- the computer system may be configured to be a constrained optimization in which preventing this type of labeling is a constraint to the block 16 optimization problem.
- the computer system may allow adjacent surface triangles p and q which share an edge or a vertex to be initially assigned opposite direction labels, and, in response to detecting such an arrangement, the computer system may relabel one of the charts to which p and q belong so that the relabeled chart does not oppose the other (non-relabeled) chart containing either p or q.
- the relabeled chart may be assigned the label of one of its neighbouring charts.
- the computer system may select between the charts of p and q arbitrarily, based on the relative sizes of the charts (e.g. by preferring to relabel the smaller chart), pseudo- randomly, based on user selection, and/or based on other factors.
- the computer system may perform such relabeling steps, if necessary, when generating an initial polycube labelling 18 at block 16 and/or when generating updated polycube segmentations 22 at block 20.
- a second locally evaluable criteria for a valid polycube segmentation is that each chart corner (chart vertex) of polycube segmentation 22 has a valence of three - i.e. is a vertex for three charts. This criterion may be accounted for after initial polycube labeling 18 is generated in block 16.
- the computer system may examine initial polycube labeling 18 and, if corners having a valence greater than three are detected in initial polycube labeling 18, the computer system may reject the initial polycube labeling 18 and the computer system may repeat block 16 with additional constraints that, for each offending corner, the surface triangles in the one-ring surrounding the offending corner (i.e. the faces in contact with the corner) are assigned a particular label.
- the computer system may select the particular label using a number of suitable techniques.
- the particular label may be selected to be the label initially assigned to the surface triangle in the one ring having the largest area.
- the particular label may be selected to be the label initially assigned to the greatest number of surface triangles in the one ring.
- two initially assigned labels in the one ring have opposing sings on the same axis, then another one of the labels initially assigned to the one ring may be selected to the particular label. Combinations of these techniques may also be used to select the particular label.
- the particular label may also be arbitrarily selected. The assignment of the particular label may be accomplished by setting the cost of the particular label to be zero for these surface triangles and effectively infinity for all other labels.
- block 16 has generated an initial polycube labeling 18 which assigns initial surface labels ( ⁇ X, ⁇ Y, ⁇ Z) to the surface triangles of input model 14.
- block 16 may also comprise generating the initial fidelity costs associated with each of the six surface labels ( ⁇ X, ⁇ Y, ⁇ Z) and these fidelity costs may also be output from the computer system at block 16 (e.g. as a part of initial polycube labeling 18 or as separate data related to initial polycube labeling 18).
- initial polycube labeling 18 will satisfy the polycube segmentation criteria that: no two charts in initial polycube labeling 18 which share a chart boundary will have opposing labels along the same axis and/or all chart corners in initial polycube labeling 18 will have a valence of three.
- Figure 2A shows an example of an initial polycube labeling 18 for an exemplary input object. Different colors of the Figure 2A initial polycube labeling represent different labels. An outstanding issue with initial polycube labeling 18 is that it includes non-monotone chart boundaries. The turning points of the chart boundaries of the Figure 2A initial polycube labeling 18 are shown as highlighted circles.
- the computer system performing method 10 proceeds to block 20, which involves generating an updated polycube segmentation 22 with all-monotone chart boundaries.
- Generating updated polycube segmentation 22 may comprise, for each of one or more surface triangles, the computer system changing the assigned initial label of initial polycube labeling 18 to an updated label and thereby modifying one or more of the initial charts of initial polycube labeling 18 to provide updated polycube segmentation 22 with updated charts, where the boundaries of the updated charts are all monotonic. While performing the block 20 update, it may be desirable for the computer system to maintain (to the extent possible) the balance achieved in block 16 with respect to the tradeoff between compactness and fidelity.
- block 20 involves: identifying one or more turning points in initial polycube labeling 18; and performing one or more perturbed discrete computational optimizations, wherein the perturbed computational optimizations re-label the surface triangles of non-monotone charts (i.e. charts whose boundaries are non-monotone or whose boundaries have turning points).
- Such perturbed computational optimizations may comprise using one or more perturbed cost functions in the vicinities of the turning points (e.g. in corresponding regions around the turning points).
- each iteration may also comprise determining the perturbed fidelity costs for various triangles and updating the segmentation using a computational discrete optimization process.
- the perturbed fidelity costs and/or the updated segmentation may be carried forward to the next iteration, to thereby implement a so-called hill climbing process.
- the perturbed discrete computational optimizations performed by the computer system in block 20 may be similar to the computational optimization performed in block 16 in the sense that they may be based at least in part on cost functions which assign cost based at least in part on faithfulness (or fidelity) of updated polycube segmentation 22 to the surface geometry of input model 14 and assign cost based at least in part on compactness of updated polycube labeling 22.
- the cost functions used in the perturbed computational optimizations performed in block 20 may be referred to herein as perturbed cost functions.
- such perturbed cost functions assign cost based at least in part on metrics associated with (or correlated with) faithfulness (or fidelity) of updated polycube segmentation 22 to the surface geometry of input model 14 and assign cost based at least in part on metrics associated with (or correlated with) compactness of updated polycube segmentation 22.
- such perturbed cost functions comprise first term (referred to herein as a fidelity term), which is based at least in part on a metric of (or models) the faithfulness (or fidelity) of updated polycube labeling 22 to the surface geometry of input model 14 and a second term (referred to herein as a compactness term), which is based at least in part on a metric of (or models) the compactness of updated polycube labeling 22.
- the compactness term of the perturbed cost functions used by the computer system in block 20 may be based at least in part on the number of updated charts in updated polycube representation 22 and/or the number of corners in updated polycube representation 22 and/or the length of the chart boundaries in updated polycube representation 22 and/or some other suitable metric of compactness.
- the fidelity term of the perturbed cost functions used by the computer system in block 20 may be based at least in part on, for each surface triangle, the angle between its assigned updated label (in updated segmentation 22) and the normal vector of the surface triangle of input model 14.
- the perturbed computational optimizations performed by the computer system in block 20 may differ from the block 16 computational optimization in that the block 20 discrete perturbed computational optimizations may introduce various perturbations into the cost functions in effort to resolve non- monotonicities (turning points) in the segmentation.
- the perturbed computational optimizations performed by the computer system in block 20 may involve an iterative ("hill climbing") approach, which iteratively introduces small incremental perturbations (and carries forward the updated segmentations and/or perturbed fidelity costs) in effort to resolve turning points with a minimal amount of perturbation.
- FIG. 3 is a schematic depiction of a method 100 which may be performed by the computer system to implement the procedures of block 20 according to a particular embodiment.
- Method 100 commences in block 102, in which the computer system considers initial polycube labeling 18 and "freezes" the labels for all charts having monotonic boundaries.
- charts with all-monotone or monotonic chart boundaries may be referred to herein as monotonic charts, all-monotone charts or valid charts.
- the block 102 chart freezing may involve, for each monotonic chart to be frozen: removing the chart's triangles from subsequent labeling operations (e.g.
- method 100 proceeds to block 104, which involves the computer system evaluating whether there are any charts with turning points on their boundaries (i.e. non-monotonic charts). If the answer to the block 104 evaluation is that all charts are monotonic (the YES branch of block 104), then method 100 proceeds to block 106 where the computer system outputs the initial polycube labeling 18 segmentation as updated polycube segmentation 22 and then ends. If there are any charts with turning points on their boundaries (the NO branch of block 104), method 100 proceeds to block 108.
- block 104 involves the computer system evaluating whether there are any charts with turning points on their boundaries (i.e. non-monotonic charts). If the answer to the block 104 evaluation is that all charts are monotonic (the YES branch of block 104), then method 100 proceeds to block 106 where the computer system outputs the initial polycube labeling 18 segmentation as updated polycube segmentation 22 and then ends. If there are any charts with turning points on their boundaries (the NO branch of block 104), method 100 proceeds to block
- One or both of blocks 102 and 104 may involve the computer system searching for turning points along chart boundaries of initial polycube labeling 18. As discussed above, a boundary between a pair of immediately adjacent charts will have a known axial orientation in the final polycube representation based on the labels applied to its adjacent charts.
- One technique for searching for turning points involves examining the directional vectors on the edges of each surface triangle that makes up a chart boundary and computing their dot products with the expected axial direction of the boundary. A change in the sign of this dot product may be indicative of a turning point. The inventors have determined that performing this examination on each surface triangle is sensitive to local mesh connectivity and can be undesirably noisy.
- This turning point search technique may comprise a computation optimization, which assigns either a positive or negative label to each triangle edge on the chart boundaries.
- the cost function for this optimization may comprise, for each triangle edge on a chart boundary, the sum of a unary term (which depends on the particular triangle edge in consideration) and a binary term (which depends on the relationship between the particular triangle edge and its neighboring triangle edge(s)).
- the unary term comprises a Gaussian fall-off function similar to equation (2) described above where the dot product in the exponent involves the orientation vector of the particular triangle edge in consideration and the vector describing the expected axial direction of its chart boundary.
- the binary term is similar to equations (3a) and (3b) described above and is zero when consecutive triangle edges have the same direction and is otherwise a Gaussian function where the dot product in the exponent is the dot product of the orientation vectors of the consecutive triangle edges.
- the binary term is zero when consecutive triangle edges have the same direction and is unity otherwise.
- the optimization may be performed serially over the set of surface boundaries.
- the computer system may use the above-discussed graph-cut technique as part of the inquiry into whether boundaries are monotonic and corresponding charts are valid. For example, the computer system may solve a graph-cut problem on the edges of the boundary.
- the computer system may use dynamic programming to determine whether a boundary is monotonic or non-monotonic. For example, the computer system may implement a Viterbi algorithm or some other technique making use of probabilistic Markov chains to determine (non-)monotonicity.
- this labeling optimization determines that the labels assigned to the triangle edges on that boundary switch signs (i.e. from positive to negative or from negative to positive), then the vertex of the triangle edge where this sign change occurs is determined to be a turning point. That is, if this labeling optimization assigns more than one label to the set of all triangle edges on a particular chart boundary, then any vertex along the boundary where there is a label change (between adjacent triangle edges) may be determined to be a turning point.
- Figure 3 if any chart boundaries are determined to have turning points (block 104 NO branch), then method 100 proceeds to block 108.
- the computer system may perform a perturbed computational optimization at block 20 (and hence during method 100).
- Block 108 involves dividing this perturbed optimization into a plurality of perturbation branches.
- perturbations are applied to the fidelity term of the cost function used in block 16 ( Figure 2) - e.g. perturbations may be applied to the fidelity term F t (s) of the equation (1) cost function.
- the computer system may, while performing method 100, otherwise introduce perturbations into the cost function used in block 16 and/or may involve the use of perturbed cost functions that are different altogether from the cost function used in block 16.
- the applied perturbations assign relatively higher cost (or relatively lower cost) to assigning one or more particular label(s) ( ⁇ X, ⁇ Y, ⁇ Z) to particular surface triangles.
- one convenient way to divide the perturbed optimization is into six branches, which include:
- the computer system may using these six branches to effectively reduce the search space from 0(6 Hl ) to 0( ⁇ t ⁇ ), or from exponential to linear time, which may substantially improve performance of the computing system during method 100.
- block 108 branches A, B, ...n other criteria could be used by the computer system to define the block 108 branches A, B, ...n.
- six branches could be created which apply perturbations which favor (i.e. provide lower cost for) +X labeling, -X labeling, +Y labeling, -Y labeling, +Z labeling and -Z labeling.
- the number of block 108 branches A, B ... n may additionally or alternatively be changed.
- n could be changed to three by dropping the X more , Y more and Z more branches or could be changed to twelve by expanding each of the above-listed branches to perturb only one direction on its corresponding axis - e.g. X more could be divided into +X m0 re (which perturbs the cost function to assign greater cost to the +X labeling only) and - X more (which perturbs the cost function to assign greater cost to the -X labeling only).
- initial polycube labeling 18 may be propagated (e.g. made available to) each of branches A, B, n and becomes that starting segmentation for each of branches A, B, . . . n.
- block 110 may also involve the computer system propagating the various fidelity costs associated with each label for each triangle determined in block 16 ( Figure 2). These fidelity costs may become the starting fidelity costs for each of branches A, B, ... n. As discussed above, these block 16 fidelity costs may comprise a part of initial polycube labeling 18.
- initial polycube labeling 18 may provide the initial branch segmentation and branch fidelity costs for each of branches A, B, ... n.
- the computer system may then proceed in method 100 to block 112, which involves setting up a looping procedure, wherein the steps of each branch A, B ... n (e.g.
- steps 114A-114n, 116A-116n and 120A-120n in the case of the illustrated embodiment) are performed either serially or in parallel and then, when the steps of each branch A, B ... n are performed, the loop iterates for a subsequent iteration of the steps for all branches A, B ... n.
- the computer system may iteratively update the individual branch segmentations and branch fidelity costs as described in more detail below.
- block 114A In the first branch, the computer system proceeds to block 114A in method 100, which involves updating the branch cost function (and/or the branch fidelity costs) with the current branch perturbation.
- block 114A involves the computer system applying a branch perturbation to the initial cost function (and/or the initial branch fidelity costs) to obtain the branch cost function.
- the initial (unperturbed) cost function is the same cost function used in block 16 to generate initial polycube labeling 18 (and the initial branch fidelity costs (where used) are the same costs generated in block 16 to determine initial polycube labeling 18), although this is not necessary and other cost functions may be used for the initial (unperturbed) cost function and associated initial branch fidelity costs (where used) in the first iteration of block 114A.
- the branch perturbation may be applied to one or more particular triangles (e.g. triangles in the vicinities of the turning points of the current branch segmentation).
- the branch segmentation may be initial polycube labeling 18 (which may be propagated to branches A, B, ... n in block 110, as described above).
- the cost function which is perturbed in block 114A is the perturbed branch cost function of the previous iteration of branch A.
- the branch fidelity costs which are perturbed in block 114A are the branch fidelity costs determined in the previous iteration of branch A.
- the branch perturbation applied in block 114A is an additive perturbation applied to the fidelity term of the perturbed branch cost function of the previous iteration of branch A for particular triangles (e.g. triangles in the vicinities of the turning points of the current branch segmentation). In other embodiments, the branch perturbation applied in block 114A otherwise perturbs the perturbed branch cost function of the previous iteration of branch A for particular triangles (e.g. triangles in the vicinities of the turning points of the current branch segmentation).
- the branch perturbation applied in block 114A is an additive perturbation that adds to the branch fidelity costs determined in the previous branch A iteration (or reduces the branch fidelity costs determined in the previous branch A iteration) of assigning one or more particular labels to particular triangles (e.g. to triangles in the vicinities of the turning points of the current branch segmentation).
- block 114A may involve searching for turning points in the current branch segmentation.
- the computer system may use a procedure similar to that described above for blocks 102, 104 in block 114A to locate turning points in the current branch segmentation.
- the computer system applies the block 114A perturbations to particular triangles in the vicinities of the turning points in the current branch segmentation. Any suitable technique could be used in block 114A to determine the size of these vicinities of (e.g. local regions around) the turning points in the current branch segmentation.
- the regions around the turning points in the current branch segmentation may comprise constant or user-configurable sized regions.
- the radii, or some other metric of the sizes, of the regions around the turning points in the current branch segmentation may be determined by some suitable percentage (e.g. 2%, 5% or 10%) or some other suitable function of the diagonal length of a bounding box (e.g. an axis-aligned box) or bounding sphere that contains input model 14.
- other criteria may be used to determine the size of the corresponding regions around the turning points in the current branch segmentation.
- the branch perturbation applied in block 114A is particular to the branch A defined in block 108.
- branch A corresponds to X mor e (as described above)
- updating the branch cost function with the branch perturbation in block 114A will involve perturbing the cost function to provide greater cost to assigning the labels +X and -X to particular surface triangles (e.g. to triangles in the vicinities of the turning points of the current branch segmentation).
- perturbing the branch fidelity costs may involve increasing the branch fidelity costs associated with the labels +X and -X for particular surface triangles (e.g.
- branch A corresponds to X[ ess (as described above)
- updating the branch cost function with the branch perturbation in block 114A will involve the computer system perturbing the cost function to provide lower cost to assigning the labels +X and -X to particular surface triangles (e.g. to triangles in the vicinities of the turning points of the current branch segmentation) and/or perturbing the branch fidelity costs (in embodiments where such branch fidelity costs are used) may involve decreasing the branch fidelity costs associated with the labels +X and -X for particular surface triangles (e.g. for triangles in the vicinities of the turning points of the current branch segmentation).
- the amplitude of the branch perturbation applied in block 114A may be configured to implement a suitable tradeoff between lower computational expense (achieved with relatively high amplitude branch perturbation) and a relatively high degree of fidelity to input model 14 or relatively low degree of parameterization distortion (achieved with relatively low amplitude branch perturbation).
- the amplitude of the block 114A branch perturbations may be increased after each iteration branch A (or after a plurality of iterations of branch A)to help resolve turning points, although increasing the amplitude of the block 114A branch perturbations is not necessary.
- the computer system After updating the perturbed branch cost function (and/or the perturbed branch fidelity costs) in block 114A, the computer system proceeds to block 116A in method 100, which comprises performing a discrete computational optimization over all of the triangles in charts that have not been frozen in the current branch segmentation (i.e. over all non-monotonic charts or over all charts that have turning points in the current branch segmentation).
- the block 116A optimization may be similar to the computational optimization performed in block 16 ( Figure 2), except that: the re-labelings prescribed by the block 116A optimization may be applied to the triangles in non-monotone charts only (i.e.
- monotone charts are frozen as described above (block 102) or as described below (block 124)); the computer system uses the block 114A perturbed branch cost function (and/or the block 114A perturbed branch fidelity costs) in the vicinities of any turning points in the current branch segmentation in the block 116A optimization; and the triangles adjacent to the edges of frozen charts may be subject to additional constraints in the block 116A optimization (see above discussion of freezing charts (block 102)).
- the computer system may use the same cost function (and/or the same branch fidelity costs) as the previous iteration of branch A in the block 116A optimization.
- the cost function used in block 116A for triangles in non- monotone charts, but outside of the vicinities of the turning points of the current branch segmentation may be referred to herein as the unperturbed branch cost function and the branch fidelity costs used in block 116A for triangles in non- monotone charts, but outside of the vicinities of the turning points of the current branch segmentation, may be referred to as unperturbed branch fidelity costs.
- the computer system relabels the surface triangles in the non-monotone charts of the branch segmentation based on the block 116A optimization.
- the labels prescribed by the block 116A provide the new branch segmentation for branch A.
- the computer system may use the block 114A perturbed branch cost function (and/or the block 114A perturbed branch fidelity costs) in the vicinities of the outstanding turning points in the block 116A optimization, the updated labelings prescribed by block 116A may resolve one or more turning points in the new branch segmentation - i.e.
- chart boundaries that may have had one or more turning points in the branch segmentation of the previous iteration may no longer have turning points or may have fewer turning points in the new branch segmentation.
- the block 116A relabeling can also result in the creation of new turning points in the new branch segmentation and movement of turning points as between the previous branch segmentation and the new branch segmentation.
- branch fidelity costs for assigning the various labels to the various triangles in branch A may also be saved or otherwise maintained (as a part of the new branch segmentation or otherwise) so that they may be used as the starting point for the next iteration of blocks 114A and 116 A.
- block 120A inquiry is negative, then the computer system proceeds to block 122A in method 100, which involves resuming the looping procedure set up in block 112. For example, in the case where the procedures for each of the branches are performed serially, block 122A may involve the computer system looping back to block 114B of branch B. If, however, the block 120A inquiry is positive (i.e. one or more turning points are resolved by the block 116A optimization to produce one or more
- Block 124 is discussed in more detail below.
- the looping procedure set up by block 112 may loop through the procedures of blocks 114A- 11 An, 116 A- 116n and 120 A- 120n in a serial manner or a parallel manner until one of the block 120A-120n inquiries is positive (i.e. there is a newly monotonic chart in any of the branch segmentations produced by any of the block 116A-1 ⁇ 6n optimizations), whereupon the computer system proceeds to block 124 in method 100.
- the computer system freezes any newly monotonic charts created in a particular branch segmentation (i.e. by a relabeling in one of blocks 116A-1 ⁇ 6n) across the branch segmentations of all branches A, B, ...n.
- the chart freezing in block 124 may be similar to the freezing described above in block 102.
- the block 124 frozen charts are propagated to the current branch segmentations of all branches A, B, ... n of method 100. Where branches A, B, ... n are executed in parallel (which may be the case in some embodiments), it is possible that one or more turning points can be resolved to produce one or more newly monotonic charts in more than one branch.
- block 124 may involve arbitrarily selecting the resolution of one of the branches by freezing each newly monotonic chart in accordance with the labeling prescribed by one of the block 116A-116n optimization.
- the computer system may uses suitable criteria to choose one branch's labeling of the newly monotonic chart over the labeling prescribed by the other branch(es) in block 124.
- block 124 may involve selecting the branch where the labeling of the newly monotonic chart changes the block 16 ( Figure 2) initial labeling 18 the least over the labeling prescribed by other branches.
- the computer system updates each branch segmentation with any newly monotonic chart(s) and these newly monotonic chart(s) are frozen for subsequent iterations of the procedures of branches A, , ... n.
- the computer system proceeds to block 126 in method 100, which involves an inquiry as to whether all of the charts are valid. Since all monotonic charts are common to the branch segmentations of all branches A, B, ... n (i.e. as a result of either the freezing and propagation of blocks 102 and 110 or as a result of the freezing and propagation of block 124), the computer system may consider at block 126 any one of the branch segmentations generated in blocks 116A-1 ⁇ 6n. If the block 126 inquiry is negative (i.e. there remain turning points in the segmentation under consideration), then the computer system proceeds to block 130 in method 100 which involves resuming the block 112 looping procedure in a manner similar to that discussed above for block 122 A.
- the computer system performing method 100 continues to loop iteratively through the block 112 looping procedure by performing blocks 114A-1 ⁇ 4n, 116A-1 ⁇ 6n and 120A-120n for each of branches A, B, ... n.
- the procedures of each branch A, B, ... n may be performed serially or in parallel. Once these procedures are performed for each branch (e.g. where the computer system reaches block 122n or reaches block 130 in method 100 after a positive inquiry in block ⁇ 20n), then the computer system performing method 100 may implement a subsequent iteration across all of the branches again at block 114A (in the serial case) or at blocks 114A-1 ⁇ 4n (in the parallel case).
- the number and locations of turning points in the various branch segmentations may change after each application of the block 116A-1 ⁇ 6n branch optimizations. Accordingly, the regions (around the turning points) in which the block 114A-114n perturbations are applied may also vary. This variation as between the locations of perturbations as between iterations may help to generate newly monotonic charts over one or more iterations.
- the amplitude of the branch perturbations applied in blocks 114A-1 ⁇ 4n may be increased after each iteration of branches A, B, ... n or after a plurality of iterations of branches A, B, ... n to help resolve turning points, although increasing the amplitude of the branch perturbations in blocks 114A- 1 ⁇ 4n is not necessary.
- step 126 once the block 126 inquiry is positive (i.e. all of the charts in the segmentation under consideration are monotonic), then the computer system proceeds to block 128 in method 100 where the all-monotone segmentation is output as updated polycube segmentation 22 ( Figure 2).
- the iterative aspect of method 100 may be described as a hill climbing process, because a small amount of perturbation is applied to the branch cost function (and/or branch fidelity costs) in each iteration. This hill climbing process helps to achieve updated (all-monotone) segmentation 22 with minimal perturbation.
- the amplitude of the perturbations applied in blocks 114A-1 ⁇ 4n may be configured to implement a suitable tradeoff between lower computational expense (achieved with relatively high perturbation) and a relatively high degree of fidelity to input model 14 or relatively low degree of parameterization distortion (achieved with relatively low branch perturbation).
- Figure 3 A is a graphical depiction of the application of the Figure 3 method 100 to an exemplary initial polycube labeling.
- Figure 3 A shows an initial polycube labeling 18 in the upper left corner with the labels shown as different colors and the turning points shown as circles. Proceeding in a clockwise manner, Figure 3 A then shows a branch segmentation 140, which resolves a pair of turning points by applying an X[ ess perturbation and thereby creates a newly monotonic chart.
- the newly monotonic chart in branch segmentation 140 is shown with a light outline and is propagated to all branches of method 100.
- branch segmentation 142 another pair of turning points is resolved by applying a Z more perturbation, resulting in a newly monotonic chart shown in light outline and propagated to all branches.
- branch segmentation 144 another turning point is resolved by applying a Z more perturbation, resulting in a pair of newly monotonic charts shown in light outline. Both of these charts are propagated across all branches.
- branch segmentation 146 another turning point is resolved by applying an X[ ess perturbation, resulting in a newly monotone chart shown in light outline which is propagated across all of the method 100 branches.
- the final (all-monotone) segmentation 22 shown in Figure 3A is obtained by application of a Y[ ess perturbation to resolve the final turning point, resulting in three new monotone charts shown in light outline. It will be appreciated that Figure 3A is schematic in nature and may take place over multiple iterations of method 100.
- Figure 3 is suitable for use in block 20 ( Figure 2) for most input models 14, method 100 may not be suitable for some input models 14, where it is desirable to have finer control over the perturbation applied in each iteration.
- An example of such a circumstance occurs where it is desirable to resolve a chart by applying one perturbation direction along one boundary and an opposite perturbation direction along another boundary of the same chart.
- Figure 4 is a schematic depiction of a method 200 which may be used by a computer system to implement the procedures of block 20 according to another particular embodiment. While method 200 involves greater computational cost, method 200 permits more refined perturbation control and can therefore be used in circumstances where method 100 is not suitable or results in undesirably large distortion.
- method 200 Many aspects of method 200 are similar to those described above for method 100.
- blocks 202, 204, 206, 208, 210 and 212 of method 200 may be substantially similar to corresponding blocks 102, 104, 106, 108, 110 and 112 of method 100.
- the procedures of blocks 214A, 216A, 214B, 216B, ...2 ⁇ 4n, 2 ⁇ 6n may be substantially similar to the procedures of blocks 114A, 116A, 114B, 116B, ... l Un, U6n.
- Each branch of method 200 also includes an inquiry by the computer system in block 232A-232n into whether a "restart event" has occurred as a result of the block 216A-216n relabeling.
- a restart event may comprise one or both of: detecting one or more newly monotonic charts (i.e. one or more charts that had one or more turning points in the branch segmentation of the previous iteration prior to the block 216A-216n optimization, but have become monotonic in the new branch segmentation after the block 216A-216n
- block 232A-232n inquiry is positive (i.e. there has been a restart event)
- the computer system proceeds to block 234 in method 200, which comprises: (i) propagating the perturbed branch cost function (and/or the perturbed branch fidelity costs) that resulted in the restart event to all of the other branches A, B, ...
- the perturbed branch cost function (and/or perturbed branch fidelity costs) propagated in block 234 will be the block 214B perturbed branch cost function (and/or block 214B perturbed branch fidelity costs).
- the block 214B perturbed branch cost function (and/or perturbed branch fidelity costs) are propagated in block 234, the block 214B perturbed branch cost function (and/or perturbed branch fidelity costs) will become the initial (unperturbed) cost function for each subsequent iteration of blocks 214A-214n and 216A-216n.
- the initial (unperturbed) branch cost function (and/or unperturbed branch fidelity costs) used in block 214A will be the block 234 propagated cost function and the block 214A branch perturbation will be applied to the block 234 propagated cost function.
- the block 234 propagated cost function will be used for the branch optimization in regions that are inside of non-monotone charts but outside of the vicinities of the turning points.
- propagating the perturbed branch cost function (and/or the perturbed branch fidelity costs) in block 234 will also effectively propagate the corresponding branch segmentation (absent frozen charts) of the branch A, B, ...n which resulted in the restart event.
- the computer system proceeds to block 224 in method 200 where newly valid charts are frozen across all branches.
- one reason for a restart event in one of blocks 232A-232n is because of one or more newly monotonic charts in one of the new branch segmentations generated in block 216A- 216n.
- a restart event in one of blocks 232A-232n could have occurred because of the creation of one or more new charts, which themselves could be monotonic. If either of these events occurred, then there are one or more newly monotonic charts, which are frozen in block 224 and propagated to all branches of method 200.
- the freezing and propagation of such newly monotonic charts in block 224 may be substantially similar to that described above for block 124. It is the case, however, that block 224 could be reached where there are no newly monotonic charts.
- block 226 in method 200 which is substantially similar to block 126 and involves an inquiry as to whether all of the charts in any of the branch segmentations are monotonic. If the block 226 inquiry is positive (i.e. all charts are monotonic), the computer system outputs the all-monotonic segmentation in block 228 as updated (all-monotone) segmentation 22 ( Figure 2). If there are still turning points in the segmentation evaluated in block 226, the computer system proceeds to block 230 in method 200 which resumes the block 212 loop.
- the block 234 propagated cost function may involve selecting and propagating the perturbed branch cost function (and/or branch fidelity costs) of one branch over the perturbed branch cost function(s) (and/or perturbed branch fidelity costs) of the other branch(es) either arbitrarily or in accordance with some suitable criteria.
- the branch that results in the segmentation closest to initial polycube labeling 18 ( Figure 2) may be selected to have its perturbed cost function propagated in block 234.
- Figure 4A is a graphical depiction of the application of the Figure 4 method 200 by a computer system to an exemplary initial polycube labeling 18.
- Figure 4A shows an initial polycube labeling 18 on the left hand side with the labels shown as different colors and the turning points shown as circles.
- the complex charts shown in initial polycube labeling 18 of Figure 4A are better resolved by applying different perturbation directions to the same charts - a task that is better suited for method 200 than method 100.
- Applying method 200 to initial polycube labeling 18 yields updated (all-monotone) segmentation 22 shown at the right of Figure 4A.
- the particular choice between method 100 and method 200 may be based on any suitable criteria, such as for example, available the computational resources of the computer system, known information about the complexity of input model 14 and/or the like. In some examples of the complexity of input model 14 and/or the like.
- updated polycube segmentation 22 generated by method 100 comprises fidelity that is unacceptably low or compactness that is unacceptably high. If the segmentation generated by method 100 is unacceptable, then method 200 may be employed.
- the output of a computer system performing method 10 is an updated segmentation 22 having all-monotone chart boundaries. Because of the computational optimization performed in blocks 16 and 20 (e.g. using a cost functions that have fidelity terms and compactness terms as described above), updated polycube segmentation 22 will comprise a balance between the competing objectives of fidelity and compactness. Further, because of the iterative hill-climbing approach used in block 20, updated polycube segmentation maintains the computationally optimum balance while relabeling triangles in initially non-monotonic charts to resolve non-monotonic chart boundaries with minimal perturbation.
- the computational optimizations performed in blocks 16 and 20 may also ensure that updated segmentation 22 meets at least two of the criteria for generating a valid polycube - i.e. that: no two charts updated polycube segmentation 22 which share a chart boundary will have opposing labels along the same axis and/or all chart corners in updated polycube segmentation 22 will have a valence of three.
- method 10 may comprise an additional step (not shown) where the offending chart is deleted from updated polycube segmentation 22 and merged with one (or more) of its neighbors.
- Updated polycube segmentation 22 is the output of a computer system performing method 10.
- Updated polycube segmentation 22 output from the computer system performing method 10 may be used, for example, to generate a polycube representation of input model 14, although this is not necessary.
- Updated polycube segmentation 22 output from the computer system performing method 10 may be used for other purposes, including (by way of non- limiting example) generating a multi-sweep representation of input model 14.
- Figure 2 shows an optional method 10A, which uses updated polycube segmentation 22 to generate a polycube
- a computer system performing method 10A proceeds from block 20 to block 24, which involves extracting a polycube representation 26 using updated polycube segmentation 22 and input model 14.
- input model 14 may comprise a volumetric mesh of the input object (or a surface mesh from which a volumetric mesh is generated using one or more suitable techniques known in the art). As was the case with the discussion of method 10 above, it is assumed (without loss of generality) that input model 14 comprises a volumetric tet-mesh of the input object.
- Figure 6 is a schematic depiction of a method 300 which may be performed by a computer system to implement the procedures of block 24 of method 10A according to a particular embodiment.
- Method 300 commences in block 302, in which the computer system takes input model 14 and updated (all-monotone) segmentation 22 as inputs and begins to deform the input model toward the desired polycube geometry.
- the computer system may rotate the normal vectors of the surface triangles of input model 14 toward the normal vectors assigned by polycube segmentation 22 in block 302.
- the block 302 deformation process may be similar to the Gregson et al. technique described in US patent application No. 13/948016 filed 22 July 2013, which is hereby incorporated herein by reference.
- the computer system may, in block 302, assign desired normal vectors to surface vertices of input model 14 based on polycube segmentation 22. Since any interior vertex in a chart has a one-ring consisting of triangles with the same labeling in polycube segmentation 22, the interior vertex has a known target orientation.
- the computer system may, in block 302, determine the minimum rotation that aligns the vertex normal vectors of each of these interior surface vertices in input model 14 with is target orientation as prescribed by polycube segmentation 22. Following the determination of these "anchor rotations" at the interior surface vertices, the computer system propagates these anchor rotations to the other vertices of input model 14 to define a volumetric rotation field in block 302.
- the anchor rotations are permitted to vary to balance the desirability of providing a low-distortion rotation field and the desirability of having surface triangles which have normal vectors aligned with their labels as prescribed by polycube segmentation 22. Balancing these competing objectives may be formulated as a computational optimization, as described in the Gregson et al. technique, and/or according to other techniques, such as (for example) an as-rigid- as -possible (ARAP) deformation.
- ARAP as-rigid- as -possible
- the computer system applies these rotations to determine new vertex positions in a deformed mesh in block 302, attempting to orient each edge in the deformed mesh with its new preferred direction while maintaining the length of the edge.
- the new vertex coordinates v t , v may be determined by minimizing: over all mesh edges (i, j). This is referred to herein as a Poisson deformation.
- the computer system may apply an as-rigid-as-possible (ARAP) deformation or some other type of deformation that prefers purely rotational deformation over translational deformation (e.g. minimizes translational deformation).
- ARAP as-rigid-as-possible
- the new vertex coordinates v*, v may be determined by minimizing:
- Weight factor ⁇ ⁇ ; - may be applied uniformly (e.g. ⁇ ⁇ ; - may equal 1 for all edges (i,j)) or non-uniformly (e.g. ⁇ ⁇ ; - may be based on the cotangent for each edge (i, j)).
- this computation of rotations and propagation of rotations may be referred to as a soft deformation and may be iteratively repeated a number of times in block 302.
- the output of the computer system at block 302 is a deformed model 306 corresponding input model 14 but which is deformed to have characteristics that are more similar to the desired polycube shape.
- the computer system then proceeds to optional block 304 in method 300, which involves a number of procedures that attempt to optimize chart boundaries by improving their alignment.
- the block 304 boundary optimization procedures may involve: applying updated segmentation 22 to deformed model 306 output by the computer system at block 302 (if not already applied at block 302); and then iteratively applying a relabeling to small portions of the deformed model 306 while preserving the chart-level topology of updated segmentation 22.
- this chart- level topology is preserved by permitting local edge and vertex positions to vary, while not allowing the creation of new charts, the removal of existing charts or charts that were not previously neighbors to become neighbors.
- the block 304 relabeling may be applied to two types of regions of deformed model 306: pairs of charts that share boundaries; and triplets of charts that share corners. In some embodiments, other types of regions may be considered for boundary optimization block 304.
- the labels on the triangles along the non-shared boundaries of the pair of charts may be fixed and the cost of assigning any label other than the ones corresponding to the pair of charts may be set to some effective infinity.
- the cost of assigning any label other than the labels of the three participating charts may be set to some effective infinity and the labels for triangles away from the corner may be fixed.
- the labels for triangles that are further (from the corner) than a fraction of the smallest incident chart boundary's length may be fixed. In some embodiments, this fraction may be 1/3, but may generally be a configurable parameter. While these constraints significantly reduce the likelihood of chart-level topological changes, they do not necessarily prevent them in all circumstances. If a block 304 relabeling results in a chart-level topological change, then block 304 may involve rolling back the relabeling result - i.e. leaving the boundary as is without implementing the relabeling.
- the block 304 relabeling may involve the use of a cost function having the form of equation (1), except that it is applied to deformed model 306 output by the computer system at block 302 with the updated polycube segmentation 22 applied thereto.
- the fidelity term F t (s) of the block 304 cost function may have the form of equation (2).
- the compactness term used in block 304 may be updated to take into account how well a given triangle edge (on a chart boundary) is aligned with its target orientation.
- the compactness term used in block 304 may be given by:
- d is given by the axis direction closest to the vector from the starting vertex of the boundary in question to its end vertex (selected such that the triangle p is to the left of the boundary with respect to the path from the start to the end and the triangle q is to the right of the boundary using counterclockwise orientation with respect to the outward pointing normals along the boundary); and e pq is a unit vector representing an edge direction between triangle p and triangle q which is oriented such that triangle p is to the left and triangle q is to the right; and ⁇ is a user-configurable term which is associated with the spread of the Gaussian function.
- the computer system may, when performing the block 304 boundary optimization, iteratively cycle more than once through pairs of charts that share boundaries and the triplets of charts that share corners in effort to perform re-labelings which optimize the boundaries without changing the chart- level topology prescribed by updated polycube segmentation 22.
- the number of iterations performed in block 304 may be determined heuristically.
- the number of block 304 iterations may be user configurable or block 304 may be configured to iterate for a user-configurable period of time or block 304 may be configured to iterate until the changes between iterations are below some suitable threshold.
- the output of the computer system at block 304 is a further updated segmentation 308 of deformed input model 306, where the boundaries of further updated segmentation 308 have been optimized in accordance with the procedures of block 304.
- block 304 is not necessary and further updated segmentation 308 may comprise the block 302 deformed object with the updated polycube segmentation 22 applied thereto.
- the computer system then proceeds to block 310 in method 300, which comprises extracting polycube representation 26 from further updated segmentation 308.
- the computer system may generate a parameterization between input model 14 and polycube representation 26 at block 310. Extracting the polycube geometry from further updated segmentation 308 may involve using a deformation process similar to that of 302 described above.
- the computer system may further repeat the iterative process of block 302 at block 310 with planarity constraints added to equation (4a) or (4b) to minimize, for every surface edge, the difference between its end point values along the relevant axis. These constraints may be effected by relatively heavily weighting equation (4a) or (4b) to conform the surface vertices to their polycube geometries.
- the computer system may, at block 310, use gradual deformation with soft constraints/weights that minimize distortion while further deforming further updated segmentation 308 towards its final polycube shape. Once this process converges, the computer system may, at block 310, compute a final polycube geometry by forcing the vertices in each chart to have the same coordinate value along their relevant axes.
- the block 302 deformations may cause opposing charts to reverse order. That is, for two edges (z ' j) and (k, l) along interiors or boundaries of a first chart labelled with one direction along an axis and a second chart labelled with an opposing direction along the same axis, respectively, may have a particular order along an axis.
- the charts in question are labelled with +X and -X, respectively, and are ordered so that (z ' j) precedes (k, l) along the X-axis.
- the computer system may maintain a record of chart orientations and orders and check for reversals after deformations (e.g. after deformation in block 302). If a reversal is detected, then the computer system may increase the weighting of Equations (4a) or (4b) and re-run the block 302 deformation to reduce distortion of one or both of the reversed edges.
- This block 310 deformation results in a polycube 28 having corner vertices in their correct positions; however, the positions computed for the rest of the vertices are not guaranteed to be on polycube 28 defined by these corners. Accordingly, the computer system may compute a parameterization between input model 14 and polycube representation 28 at block 310.
- Computing a low-distortion parameterization from input mesh 14 to polycube 28 may comprise parameterizing each chart into a fixed, possibly concave, planar polygon which is a well-known open problem in mesh processing.
- this challenge is sidestepped at block 310 by first computing a bijective (but possibly poor quality) map from input model 14 to polycube 28 and then improving this mapping by operating from polycube 28 to input model 14 (i.e. in the opposite direction).
- the computer system generates the initial polycube map by first mapping each chart boundary to its corresponding polycube edge using arc-length
- the computer system may, at block 310, use the method described in Xu et al. 2011 (XU, Y., CHEN, R., GOTSMAN, C, AND LIU, L. 2011. Embedding a triangular graph within a given boundary. Computer Aided Geometric Design 28, 6, 349-356.) with mean value coordinates to position the interior chart vertices. If a volumetric parameterization is desired in block 310, then the above-described deformation framework may be used, keeping surface vertex positions fixed and specifying surface rotations using a coordinate frame given by the new normal and one of the edges.
- the corners of the polycube be placed at vertices of a fixed size grid.
- some embodiments of the computer system may place corner vertices in the quantized locations and then relocate the polycube surface vertices using mean-value coordinates at block 310, as described by Hormann and Floater 2006 (HORMAN, K. AND FLOATER, M.S. 2006. Coordinates for Arbitrary Planar Polygons. ACM Transactions on Graphics, 25(4), 1424-1441), with respect to the corners of its corresponding polycube face.
- the computer system may similarly relocate interior vertices using the surface mesh as a cage for 3D mean- value coordinates in accordance with the technique of Ju et al. 2005 (JU, T., SCHAEFER, S., AND WARREN, J. 2005. Mean value coordinates for closed triangular meshes. SIGGRAPH, 561-566.) at block 310.
- a computer system performing method 10A has two models (input model 14 and polycube 26) and a basic mapping between them. In some embodiments, it may be desirably to further process the mapping between input model 14 and polycube 26, which minimizes (or at least reduces) cross-parameterization distortion.
- determining a low distortion polycube to input map in block 310 may comprise re-meshing polycube 28 using known techniques, such as those disclosed by the Alice Project- team (ALICE PROJECT-TEAM. Graphite, http://alice.loria.fr/software/graphite/) and using the block 310 mapping to project the polycube 28 mesh to input model 14.
- block 310 may then involve sliding the projected vertices along the input model surface in order to minimize the mapping distortion between the two meshes, measured using mean-value coordinates (T. Popa, I. South-Dickinson, A. Sheffer, D. Bradley, W.
- polycube 28 generated by a computer system performing method 10A may be used to generate a tetrahedral mesh, which may be mapped to project a new (tetrahedral) mesh onto input object 14.
- tetrahedral mesh which may be mapped to project a new (tetrahedral) mesh onto input object 14. Examples of techniques which may be used to generate such tet-meshes and corresponding mappings are described in US patent application No. 13/948016 filed 22 July 2013 and by GREGSON, J., SHEFFER, A., AND ZHANG, E. 2011. All -hex mesh generation via volumetric polycube deformation. Computer Graphics Forum (Proc. SGP) 30, 5, both of which are hereby incorporated by reference.
- Figure 7A shows a method 10B for generating a multi-sweep representation 52 based on input model 14.
- Method 10B comprises method 10 (as described above) for generating all-monotone polycube segmentation 22 and then using all-monotone polycube segmentation 22 for extracting multi-sweep representation 52 in block 50.
- Figure 7B is a schematic depiction of a method 400 for extracting a multi-sweep representation 52 which may be used by a computer system to implement the procedures of block 50 according to a particular embodiment.
- block 402 and optional block 404 are substantially similar to blocks 302 and 304 of method 300 described above.
- the computer system begins to deform deformed object 406 into a multi-sweep geometry.
- the computer system may select of one of the Cartesian axes (X, Y,X) to be the sweep axis in block 410.
- the particular axis chosen to be the block 410 sweep axis may be selected by a user or may be pre-selected.
- the procedures of method 400 may be performed by the computer system for each of the three Cartesian axes to generate three corresponding multi-sweep representations 52.
- input model 14 may be divided into a plurality of portions and a corresponding sweep axis may be chosen for each portion of input model 14.
- the computer system determines, at block 410, the minimum rotation that aligns the vertex normal vectors of the interior surface vertices in deformed object 406 with charts labeled (as prescribed by further updated polycube
- the computer system determines the minimum rotations that would align the vertex normal vectors of the interior surface vertices of the +X and -X labeled charts (from the labels prescribed by further updated polycube segmentation 408) with the X-axis at block 410.
- rotations may be determined such that the normal vectors of these non-sweep axis vertices are orthogonal to the sweep axis, but are not strictly required to align with their corresponding axis.
- the computer system determines rotations that would align the vertex normal vectors of the interior surface vertices of the +Y, -Y, +Z and -Z labeled charts (from the labels of further updated polycube segmentation 408) to be orthogonal to the X-axis without strictly requiring these rotations to be aligned with their corresponding label axes.
- These rotations of the interior surface vertices may be referred to as “anchor rotations”.
- the computer system propagates these anchor rotations to the other vertices of deformed object 406 to define a volumetric rotation field at block 410.
- the anchor rotations are permitted to vary to balance the desirability of providing a low-distortion rotation field and the desirability of having surface triangles with normal vectors, which, for the sweep axis, are aligned with their labels; and, for the non-principal axes, satisfy their orthogonality criteria. Balancing these competing objectives may be formulated as a computational optimization in a manner similar to that of the Gregson et al. technique.
- the computer system applyies these rotations to determine new vertex positions in a deformed mesh at block 410, attempting to orient each edge in the deformed mesh with its new preferred direction while maintaining the length of the edge.
- the new vertex coordinates v*, v can be determined by minimizing :
- block 410 may involve increasing weighting (e.g. in equation (4)) the need to conform with the multi-sweep constraints - i.e. to have surface triangles with labels along the sweep axis to have normal vectors which are aligned with the sweep axis and for other surface triangles to have normal vectors that are orthogonal to the sweep axis.
- these multi-sweep constraints/weights may be rigidly applied to provide a multi- sweep representation 52 that conforms with the desired multi-sweep geometry.
- Generating a mapping which minimizes cross-parameterization distortion may then be accomplished using any of a wide variety of suitable techniques, including, for example, any of the techniques described above in the polycube context.
- the computer system may, at block 402 (in a manner similar to block 410 described above), use updated polycube segmentation 22 to cause deformation that begins to deform input model 14 into a deformed object 406 which looks more like a multi-sweep representation (rather than a polycube representation, as would be the case if block 402 was identical to block 302).
- the anchor rotations for such a deformation would be based on the minimum rotation that aligns the vertex normal vectors of the interior surface vertices in input model with charts labeled (as prescribed by updated polycube segmentation 22) along the sweep axis with the sweep axis.
- the computer system may, at block 402, determine the minimum rotations that would align the vertex normal vectors of the interior surface vertices of the +X and -X labeled charts (from the labels prescribed by updated polycube segmentation 22) with the X-axis. For the interior surface vertices corresponding to non-principal axes, rotations may be determined such that the normal vectors of these non-sweep axis vertices are orthogonal to the sweep axis, but are not strictly required to align with their corresponding axis.
- Block 402 the computer system may, at block 402, involve determining rotations that would align the vertex normal vectors of the interior surface vertices of the +Y, -Y, +Z and -Z labeled charts (from the labels of updated polycube segmentation 22) to be orthogonal to the X-axis without strictly requiring these rotations to be aligned with their corresponding label axes.
- block 402 would be similar to block 302 described above.
- Block 404 may also differ from block 304 of the previously discussed environment, as block 404 may involve boundary optimization in accordance with the multi-sweep criteria. In some embodiments, block 404 may only involve boundary optimization for boundaries surrounding charts aligned with the sweep axis and any corners along this boundary.
- FIG. 5 shows a schematic diagram of a system 500 which may be configured to implement all or part of any of the methods described herein according to an example embodiment.
- System 500 comprises a display 502, user input devices 504 and a computer system 506 comprising a processor 508.
- Processor 508 may have access to software 510, which may be used to configure processor 508 to perfume all or part of any of the methods described herein.
- processor 508 may be configured to perform all or part of any of the methods described herein using a combination of hardware and software 510.
- processor 510 may have access to computer-readable medium 512 which may comprise suitable codified instructions which, when executed by processor 510, cause processor 510 to perform any all or part of the methods described herein.
- Computer system 506, processor 510 and components thereof may comprise hardware, software, firmware or any combination thereof.
- Processor 510 may comprise one or more microprocessors, digital signal processors, graphics processors, field programmable gate arrays, and/or the like.
- Components of system 500 may be combined or subdivided, and components of system 500 may comprise sub-components shared with other components of system 500.
- processor 510 may be instantiated in a programmed server computer, which communicates with display 502 via the internet or another network.
- block 226 could be performed before blocks 234 and 236.
- any of a wide variety of cross-parameterization techniques could be used in blocks 310, 410 of methods 300, 400.
- weightings could be applied to particular triangles (e.g. based on triangle size) and/or to particular triangle edges (e.g. based on edge length) and/or to particular boundaries (e.g. based on boundary length).
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Computer Graphics (AREA)
- Software Systems (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Architecture (AREA)
- Computer Hardware Design (AREA)
- General Engineering & Computer Science (AREA)
- Geometry (AREA)
- Image Processing (AREA)
Abstract
Description
Claims
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/024,848 US9922458B2 (en) | 2013-11-04 | 2014-11-03 | Methods and systems for generating polycube segmentations from input meshes of objects |
EP14858869.2A EP3066645A4 (en) | 2013-11-04 | 2014-11-03 | Methods and systems for generating polycube segmentations from input meshes of objects |
CA2925435A CA2925435A1 (en) | 2013-11-04 | 2014-11-03 | Methods and systems for generating polycube segmentations from input meshes of objects |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201361899765P | 2013-11-04 | 2013-11-04 | |
US61/899,765 | 2013-11-04 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2015061914A1 true WO2015061914A1 (en) | 2015-05-07 |
Family
ID=53003060
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/CA2014/051055 WO2015061914A1 (en) | 2013-11-04 | 2014-11-03 | Methods and systems for generating polycube segmentations from input meshes of objects |
Country Status (4)
Country | Link |
---|---|
US (1) | US9922458B2 (en) |
EP (1) | EP3066645A4 (en) |
CA (1) | CA2925435A1 (en) |
WO (1) | WO2015061914A1 (en) |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10169909B2 (en) * | 2014-08-07 | 2019-01-01 | Pixar | Generating a volumetric projection for an object |
CN105957151B (en) * | 2016-04-27 | 2018-11-02 | 浙江大学 | It is a kind of based on the hexahedral mesh generation method for closing form Polycube |
WO2017203528A1 (en) | 2016-05-24 | 2017-11-30 | Technion Research & Development Foundation Limited | Systems and methods for generating volumetric models |
US10217231B2 (en) * | 2016-05-31 | 2019-02-26 | Microsoft Technology Licensing, Llc | Systems and methods for utilizing anchor graphs in mixed reality environments |
US10740509B2 (en) * | 2017-08-14 | 2020-08-11 | Autodesk, Inc. | Machine learning three-dimensional fluid flows for interactive aerodynamic design |
KR102528516B1 (en) * | 2018-05-07 | 2023-05-04 | 구글 엘엘씨 | Face PD (perspective distortion) correction |
EP3671660A1 (en) * | 2018-12-20 | 2020-06-24 | Dassault Systèmes | Designing a 3d modeled object via user-interaction |
WO2021145888A1 (en) * | 2020-01-17 | 2021-07-22 | Hewlett-Packard Development Company, L.P. | Object deformation determination |
WO2022236449A1 (en) * | 2021-05-08 | 2022-11-17 | 大连理工大学 | Three-dimensional model topology-preserving deformation method based on multiple body harmonic fields |
CN113656851B (en) * | 2021-10-20 | 2022-03-15 | 广州中望龙腾软件股份有限公司 | Method for generating gradient functional material based on Wang cubes method, terminal and storage medium |
Family Cites Families (45)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS62179084A (en) | 1986-01-31 | 1987-08-06 | Tokyo Tatsuno Co Ltd | Reading/writing device for plate like memory medium |
KR900001017B1 (en) | 1987-07-29 | 1990-02-24 | 김광식 | Ore dressing shovel |
JPH0897215A (en) | 1994-09-29 | 1996-04-12 | Sony Corp | Simulation method of electric characteristic of semiconductor device and input data forming equipment for the simulation method |
US5731817A (en) | 1995-10-11 | 1998-03-24 | Motorola, Inc. | Method and apparatus for generating a hexahedron mesh of a modeled structure |
US5768156A (en) | 1995-10-25 | 1998-06-16 | Sandia Corporation | Connectivity-based, all-hexahedral mesh generation method and apparatus |
US5729670A (en) | 1996-01-16 | 1998-03-17 | Ford Global Technologies, Inc. | Method for producing a mesh of quadrilateral/hexahedral elements for a body to be analyzed using finite element analysis |
JP3963334B2 (en) | 1997-10-14 | 2007-08-22 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Meshing method and apparatus |
JP3037665B2 (en) | 1997-11-06 | 2000-04-24 | 株式会社浅井鉄工所 | Small deformed object gripping device |
US6600487B1 (en) | 1998-07-22 | 2003-07-29 | Silicon Graphics, Inc. | Method and apparatus for representing, manipulating and rendering solid shapes using volumetric primitives |
US6124857A (en) | 1998-08-12 | 2000-09-26 | International Business Machines Corporation | Meshing method and apparatus |
EP1077431A1 (en) | 1999-08-16 | 2001-02-21 | Mtu Motoren- Und Turbinen-Union MàNchen Gmbh | Generating a three-dimensional mesh for finite element analysis |
KR100351674B1 (en) | 1999-10-29 | 2002-09-10 | 한국과학기술원 | Surface element layer formation method for improving hexahedral mesh shape in finite element method |
FR2800881B1 (en) | 1999-11-05 | 2001-11-30 | Inst Francais Du Petrole | METHOD FOR REALIZING IN 3D A KINEMATIC MODEL OF DEFORMATION OF A SEDIMENTARY BASIN |
US6611736B1 (en) | 2000-07-01 | 2003-08-26 | Aemp Corporation | Equal order method for fluid flow simulation |
US6904395B1 (en) | 2000-08-16 | 2005-06-07 | Ford Global Technologies, Llc | System and method of generating a finite element mesh for a threaded fastener and joining structure assembly |
JP2002245098A (en) * | 2001-02-16 | 2002-08-30 | Hitachi Ltd | Method and device for generating hexahedral mesh |
KR100428066B1 (en) | 2001-02-23 | 2004-04-27 | 한국과학기술원 | Hexahedral Finite Element Mesh To Control The Element Size Modelling Method And Storage Medium Thereof |
US6625938B1 (en) | 2001-06-08 | 2003-09-30 | Carnegie Mellon University | System and method for converting a hex-dominant mesh to an all-hexahedral mesh |
US20030056733A1 (en) | 2001-09-25 | 2003-03-27 | Atsushi Kidachi | Changeable-floor type rearing cage |
KR100450820B1 (en) | 2002-04-23 | 2004-10-01 | 삼성에스디아이 주식회사 | Air breathing direct methanol fuel cell pack |
US7181377B1 (en) | 2002-06-24 | 2007-02-20 | Sandia Corporation | Method of modifying a volume mesh using sheet extraction |
US7098912B1 (en) | 2002-06-24 | 2006-08-29 | Sandia Corporation | Method of modifying a volume mesh using sheet insertion |
DE60214696T2 (en) | 2002-07-23 | 2007-09-06 | Simcon Kunststofftechnische Software Gmbh | Simulation of liquid flow and structure analysis in thin-walled geometries |
AU2004211184A1 (en) | 2003-02-05 | 2004-08-26 | Moldflow Ireland Ltd. | Apparatus and methods for performing process simulation using a hybrid model |
CA2568892A1 (en) | 2004-06-02 | 2005-12-15 | Earth Decision Sciences | Method for building a three dimensional cellular partition of a geological domain |
KR100632535B1 (en) | 2004-12-29 | 2006-10-11 | 엘지전자 주식회사 | 3-Dimension graphic engine for mobile device and offering method of 3D graphic |
JP2008546078A (en) | 2005-05-23 | 2008-12-18 | スリーエム イノベイティブ プロパティズ カンパニー | Manifold for discharging liquid having desired mass-weight characteristics and design method thereof |
US7671858B1 (en) | 2005-09-06 | 2010-03-02 | Sandia Corporation | Unconstrained paving and plastering method for generating finite element meshes |
TWI317893B (en) | 2006-10-25 | 2009-12-01 | Coretech Sys Co Ltd | Method for generating meshes and computer-readable article for executing the method |
ATE487894T1 (en) | 2006-12-29 | 2010-11-15 | Skf Ab | SEALING AND GUIDE UNIT FOR THE PISTON ROD OF A ONE-TUBE SHOCK ABSORBER |
WO2008094520A2 (en) | 2007-02-01 | 2008-08-07 | Continental Automotive Systems Us, Inc. | Impact simulation of fuel delivery module |
US8150663B2 (en) | 2007-03-30 | 2012-04-03 | Paradigm Geophysical (Luxembourg) S.A.R.L. | Partitioning algorithm for building a stratigraphic grid |
JP4999522B2 (en) | 2007-04-06 | 2012-08-15 | 株式会社日立製作所 | Analysis mesh generator |
JP4468409B2 (en) | 2007-06-11 | 2010-05-26 | 株式会社日立製作所 | Analysis mesh generator |
KR20090005638A (en) * | 2007-07-09 | 2009-01-14 | 한국과학기술원 | Method and system for variable-node finite-elemtnt modeling for application to non-matching meshes |
KR101025005B1 (en) | 2007-07-26 | 2011-03-24 | 주식회사 쎄코 | Multipurpose carrier of vacuum vapor deposition material and method thereof |
US8194068B1 (en) | 2007-10-17 | 2012-06-05 | Sandia Corporation | Hexahedral finite element mesh coarsening using pillowing technique |
WO2009049681A1 (en) | 2007-10-19 | 2009-04-23 | Vascops | Automatic geometrical and mechanical analyzing method and system for tubular structures |
ES2341065B1 (en) | 2007-10-25 | 2011-06-13 | Airbus España, S.L. | METHODS AND SYSTEMS FOR IMPROVING BADS USED IN COMPUTATIONAL FLUID DYNAMICS. |
US8243071B2 (en) * | 2008-02-29 | 2012-08-14 | Microsoft Corporation | Modeling and rendering of heterogeneous translucent materials using the diffusion equation |
US8126234B1 (en) | 2008-07-25 | 2012-02-28 | O.N.Diagnostics, LLC | Automated patient-specific bone-implant biomechanical analysis |
US8200464B2 (en) | 2009-04-01 | 2012-06-12 | Livermore Software Technology Corporation | Explosion simulation in finite element analysis |
US20100288204A1 (en) | 2009-05-12 | 2010-11-18 | Tk Holdings Inc. | Vehicle pet restraint system |
ES2640986T3 (en) | 2010-11-19 | 2017-11-07 | European Space Agency | Lightweight compact drop-down support structure |
JP5678756B2 (en) | 2011-03-23 | 2015-03-04 | 学校法人近畿大学 | Hexahedral mesh generation method |
-
2014
- 2014-11-03 EP EP14858869.2A patent/EP3066645A4/en not_active Withdrawn
- 2014-11-03 US US15/024,848 patent/US9922458B2/en active Active
- 2014-11-03 CA CA2925435A patent/CA2925435A1/en not_active Abandoned
- 2014-11-03 WO PCT/CA2014/051055 patent/WO2015061914A1/en active Application Filing
Non-Patent Citations (4)
Title |
---|
GREGSON ET AL.: "All-Hex Mesh Generation via Volumetric PolyCube Deformation", EUROGRAPHICS SYMPOSIUM ON GEOMETRY PROCESSING 2011, COMPUTER GRAPHICS FORUM, SPECIAL ISSUE OF SYMPOSIUM ON GEOMETRY PROCESSING 2011, vol. 30, no. ISSUE, pages 1407 - 1416, XP055337187, Retrieved from the Internet <URL:http://www.cs.ubc.ca/nest/imager/tr/2011/HexMeshingPolycubeDeformation/HexMeshing_files/HexMeshSGP2011.pdf> [retrieved on 20150218] * |
HAN ET AL.: "Hexahedral Shell Mesh Construction via Volumetric Polycube Map", PROCEEDINGS OF THE 14TH ACM SYMPOSIUM ON SOLID AND PHYSICAL MODELING, SPM'10, 1 September 2010 (2010-09-01), pages 127 - 136, XP055337188, Retrieved from the Internet <URL:http://dl.acm.org/citation.cfm?id=1839796> [retrieved on 20150218] * |
HE ET AL.: "A Divide-And-Conquer Approach For Automatic Polycube Map Construction", COMPUTERS & GRAPHICS, vol. 33, no. ISSUE, 1 June 2009 (2009-06-01), pages 369 - 380, XP026448492, Retrieved from the Internet <URL:http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.228.3545&rep=rep1&type=pdf> [retrieved on 20150218] * |
See also references of EP3066645A4 * |
Also Published As
Publication number | Publication date |
---|---|
EP3066645A4 (en) | 2017-08-30 |
US20160240001A1 (en) | 2016-08-18 |
CA2925435A1 (en) | 2015-05-07 |
US9922458B2 (en) | 2018-03-20 |
EP3066645A1 (en) | 2016-09-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9922458B2 (en) | Methods and systems for generating polycube segmentations from input meshes of objects | |
CN107123164B (en) | Three-dimensional reconstruction method and system for keeping sharp features | |
CN105993034B (en) | Contour completion for enhanced surface reconstruction | |
CN110136072B (en) | Point cloud noise removing method, denoising system, computer device and storage medium | |
US9972128B2 (en) | Methods and systems for generating polycubes and all-hexahedral meshes of an object | |
Whelan et al. | Incremental and batch planar simplification of dense point cloud maps | |
US20210142478A1 (en) | Multi-dimensional model merge for style transfer | |
CN113781667B (en) | Three-dimensional structure simplified reconstruction method and device, computer equipment and storage medium | |
US7876322B2 (en) | Method and apparatus for fast and efficient mesh simplification | |
WO2013123636A1 (en) | Method and apparatus for mesh simplification | |
US20120154397A1 (en) | Method and system for generating mesh from images | |
CN111581776A (en) | Geometric reconstruction model-based isogeometric analysis method | |
CN111710023B (en) | Three-dimensional point cloud data feature point extraction method and application | |
Pound et al. | A patch-based approach to 3D plant shoot phenotyping | |
CN114494641B (en) | Three-dimensional model light weight method and device | |
Liu et al. | An edge-sensitive simplification method for scanned point clouds | |
US11380058B2 (en) | Method and apparatus for continuity based smoothing | |
Li | A voxel graph-based resampling approach for the aerial laser scanning of urban buildings | |
CN104036552B (en) | Method for generating blue noise meshes on basis of farthest point optimization | |
WO2023144676A1 (en) | Computer-implemented method for the simplification of a mesh of a three-dimensional graphical object | |
CN118541730A (en) | Low polygon mesh generation for three-dimensional models | |
Nurunnabi et al. | Robust outlier detection and saliency features estimation in point cloud data | |
Georgiadis et al. | Indirect all-quadrilateral meshing based on bipartite topological labeling | |
Zint et al. | Feature‐Preserving Offset Mesh Generation from Topology‐Adapted Octrees | |
Wang et al. | Segmentation-driven feature-preserving mesh denoising |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 14858869 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2925435 Country of ref document: CA |
|
WWE | Wipo information: entry into national phase |
Ref document number: 15024848 Country of ref document: US |
|
REEP | Request for entry into the european phase |
Ref document number: 2014858869 Country of ref document: EP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2014858869 Country of ref document: EP |
|
NENP | Non-entry into the national phase |
Ref country code: DE |