METHODS AND SYSTEMS FOR HEX-MESH OPTIMIZATION VIA EDGE-CONE RECTIFICATION

Information

  • Patent Application
  • 20170024931
  • Publication Number
    20170024931
  • Date Filed
    July 22, 2016
    8 years ago
  • Date Published
    January 26, 2017
    7 years ago
Abstract
Methods and systems improve quality of a hex-mesh by: performing a first iterative procedure which starts with the input hex-mesh and which outputs an output hex-mesh having improved quality. Performing the first iterative procedure comprises: initializing a current hex-mesh to be equal to the input hex mesh; for each iteration of the first iterative procedure: performing an optimization of an energy function over a plurality of directed-edges in the current hex-mesh to determine updated vertex positions for vertices in the current hex-mesh, wherein for each directed edge, the energy function comprises a term that expresses a preference for the directed edge to be aligned with normal vectors of base triangles of an edge-cone corresponding to the directed edge; and updating the current hex-mesh with the updated vertex positions; and after one or more iterations, setting the output hex-mesh to be equal to the current hex-mesh.
Description
TECHNICAL FIELD

The invention relates to computer-based hexahedral mesh (hex-mesh) modeling of three-dimensional objects. Particular embodiments provide methods and systems for optimizing hex-meshes via edge-cone rectification.


BACKGROUND

Many computer-based engineering models use finite element discretization based models to model and simulate the behavior of three-dimensional objects. A popular choice for many such engineering models involves the use of hexahedral meshes (hex-meshes) as the finite element discretization of choice. Typical, but non-limiting examples of input objects which may be modelled using hex-meshes include: parts of mechanical systems; fluid conduits for fluid simulation; biological elements, such as human bones and/or organs. There is a general desire to provide high quality hex-meshes, since the quality of such hex-meshes can influence the accuracy and/or reliability of the corresponding engineering models. The generation of hex-meshes is typically a two-step process which involves: (i) generating an initial hex-mesh whose connectivity is designed to fit the input object; and (ii) modifying the positions of vertices to optimize the shapes of the mesh elements while keeping the connectivity fixed.


A challenge that is faced by automated (computer-based) hex-mesh generation techniques is that the generated hex-meshes typically contain poorly shaped hexahedrons. For example, poorly shaped hexahedrons may comprise hexahedrons that are relatively far from cuboid in shape and/or hexahedrons that are inverted or concave in shape. Even a single inverted (concave) hexahedral element can render an entire hex-mesh representation unusable for simulation. Hex-meshes comprising such poorly shaped hexahedrons may be referred to as low quality hex-meshes and individual poorly shaped hexahedrons within such hex-meshes may be referred to as low quality hexahedrons or low quality elements. There is a general desire for automated computer-based techniques for improving the quality of hex-meshes (e.g. hex-mesh representations of input objects). Such hex-mesh improvement techniques may improve the average quality of the hex-mesh elements and/or the minimum quality of the hex-mesh elements and may be referred to as hex-mesh optimization techniques.


The foregoing examples of the related art and limitations related thereto are intended to be illustrative and not exclusive. Other limitations of the related art will become apparent to those of skill in the art upon a reading of the description and a study of the drawings.





BRIEF DESCRIPTION OF DRAWINGS

Exemplary embodiments are illustrated in referenced figures of the drawings. It is intended that the embodiments and figures disclosed herein are to be considered illustrative rather than restrictive.



FIG. 1 schematically illustrates an automated (computer-implemented) method for optimizing (i.e. improving the quality of) an input hex-mesh to generate an improved quality output hex-mesh according to a particular embodiment.



FIG. 2A shows an exemplary hex-segment of a hex-mesh and its corresponding corner tetrahedrals. FIG. 2B shows an exemplary directed edge in a hex-mesh and the hexahedrons surrounding the directed edge. FIG. 2C shows an exemplary directed edge in a hex-mesh, its corresponding edge-cone, the hexahedra and corresponding base triangles of its corresponding edge-cone and the normal vectors of its base triangles. FIG. 2D schematically depicts a directed edge eij, the base triangles t0, t1, t2, t3 of its edge-cone and the normal vectors of the base triangles.



FIG. 3 is a schematic illustration of an automated (computer-implemented) method which may be used to implement the FIG. 1 optimization procedure according to an example embodiment.



FIG. 4 schematically illustrates an automated (computer-implemented) method for optimizing (i.e. improving the quality of) an input hex-mesh to generate an improved quality output hex-mesh according to a particular embodiment.



FIG. 5 is a schematic illustration of an automated (computer-implemented) method which may be used to implement the FIG. 4 local procedure according to an example embodiment.



FIG. 6 schematically illustrates an automated (computer-implemented) method which may be used to implement the FIG. 4 global procedure according to an example embodiment.



FIG. 7A shows an example of a number of topologically parallel edges of a hexahedron. FIG. 7B shows a number of examples of topologically consecutive edges of neighboring hexahedra.



FIG. 8 is a schematic depiction of a system which may be used to perform any of the methods described herein according to a particular embodiment.





SUMMARY

The following embodiments and aspects thereof are described and illustrated in conjunction with systems, tools and methods which are meant to be exemplary and illustrative, not limiting in scope. In various embodiments, one or more of the above-described problems have been reduced or eliminated, while other embodiments are directed to other improvements.


The invention provides a number of non-limiting aspects. Non-limiting aspects of the invention comprise the following:

  • 1. A method, performed by a computer, for improving quality of a hex-mesh, the method comprising:


obtaining an input hex-mesh;


performing a first iterative procedure which starts with the input hex-mesh and which outputs an output hex-mesh having improved quality relative to the input hex-mesh;


wherein performing the first iterative procedure comprises:

    • initializing a current hex-mesh to be equal to the input hex mesh;
    • for each iteration of the first iterative procedure:
      • performing an optimization (e g minimization) of an energy function over a plurality of directed-edges in the current hex-mesh to determine updated vertex positions for vertices in the current hex-mesh, wherein for each directed edge, the energy function comprises a term that expresses a preference for the directed edge to be aligned with normal vectors of base triangles of an edge-cone corresponding to the directed edge; and
      • updating the current hex-mesh with the updated vertex
    • positions; and after one or more iterations, setting the output hex-mesh to be equal to the current hex-mesh.
  • 2. A method according to aspect 1 or any other aspect herein wherein, for each directed edge extending from a base vertex vi to an end vertex vj:


the edge-cone corresponding to the directed edge comprises a plurality of tetrahedra surrounding the directed edge, each of the plurality of tetrahedra bounded by the directed edge and by a pair of distinct edges of a hexahedron in the current hex-mesh mesh, each of the pair of distinct edges emanating from the base vertex vi and not including the end vertex vj;


the base triangles of the edge-cone corresponding to the directed edge comprise, for each tetrahedron of the plurality of tetrahedra, the triangular surface of the tetrahedron which includes the base vertex vi but does not include the end vertex vj.

  • 3. A method according to any one of aspects 1 and 2 or any other aspect herein wherein, for each directed edge, the term of the energy function that expresses the preference for the directed edge to be aligned with normal vectors of base triangles of the edge-cone corresponding to the directed edge has the form of











t
k



T


(

e
ij

)







(



e
ij




e
ij




-

n
k


)

2


,




as described above in connection with equation (2).

  • 4. A method according to any one of aspects 1 to 3 or any other aspect herein comprising, for each directed edge, at least one of:


determining the normal vectors of the base triangles corresponding to the directed edge according to an equation having the form of equation (4) described above; and


obtaining target edge lengths for the output hex-mesh and determining the normal vectors of the base triangles corresponding to the directed edge according to an equation having the form of equation (6) described above.

  • 5. A method according to aspect 4 or any other aspect herein wherein obtaining target edge lengths for the output hex-mesh comprises one or more of: receiving the target edge lengths for the output hex-mesh; using the edge-lengths of the input hex-mesh as the target edge lengths for the output hex-mesh; and estimating the target edge lengths for the output hex-mesh.
  • 6. A method according to aspect 5 or any other aspect herein wherein obtaining target edge lengths for the output hex-mesh comprises estimating the target edge lengths for the output hex-mesh and estimating the target edge lengths for the output hex-mesh comprises performing an edge-length optimization which optimizes (e.g. minimizes) an edge-length energy function over a plurality of edges in either the input hex-mesh or the current hex-mesh.
  • 7. A method according to aspect 6 or any other aspect herein wherein the edge-length energy function comprises a first term which expresses a preference for at least some of the plurality of edges to have target edge lengths that are similar to the average edge length of the plurality of edges.
  • 8. A method according to any one of aspects 6 to 7 or any other aspect herein where the edge-length energy function comprises a surface term which expresses a preference for at least some of the plurality of edges on a boundary surface to have target edge lengths that are similar to their original edge lengths.
  • 9. A method according to any one of aspects 6 to 8 or any other aspect herein where the edge-length energy function comprises a topologically parallel term which expresses a preference for at least some topologically parallel edges to have target edge lengths that are similar to one another.
  • 10. A method according to any one of aspects 6 to 9 or any other aspect herein where the edge-length energy function comprises a topologically consecutive term which expresses a preference for at least some topologically consecutive edges to have target edge lengths that are similar to one another.
  • 11. A method according to any one of aspects 6 to 10 or any other aspect herein where the edge-length energy function has the form of equation (22) described herein.
  • 12. A method according to any one of aspects 1 to 11 or any other aspect herein wherein performing the optimization of the energy function is subject to non-inversion constraints which require at least one of: the hexahedra in the current hex-mesh to be non-inverted and the tetrahedra corresponding to each directed edge to be non-inverted.
  • 13. A method according to aspect 12 or any other aspect herein wherein the non-inversion constraints have the form of equation (3) described herein.
  • 14. A method according to any one of aspects 1 to 11 or any other aspect herein wherein performing the optimization of the energy function comprises performing an iterative optimization and wherein, for each iteration of the iterative optimization, the energy function comprises, for each directed edge, a weighted penalty term which expresses a preference for the directed edge to be aligned with a target edge direction {circumflex over (n)}ij.
  • 15. A method according to aspect 14 or any other aspect herein wherein, for each iteration of the iterative optimization, updating the weighted penalty term for each directed edge.
  • 16. A method according to any one of aspect 14 to 15 or any other aspect herein wherein performing the first iterative procedure comprises, for each iteration of the first iterative procedure and for each directed edge, determining the target edge direction {circumflex over (n)}ij.
  • 17. A method according to aspect 16 or any other aspect herein wherein, for each directed edge, determining the target edge direction {circumflex over (n)}ij is based on characteristics of the current hex-mesh local to the edge-cone corresponding to the directed edge.
  • 18. A method according to aspect 17 or any other aspect herein wherein, for each directed edge, determining the target edge direction {circumflex over (n)}ij is based only on characteristics of the current hex-mesh local to the edge-cone corresponding to the directed edge.
  • 19. A method according to any one of aspects 17 to 18 or any other aspect herein wherein, for each directed edge, the characteristics of the current hex-mesh local to the edge-cone corresponding to the directed edge are the normal vectors of the base triangles of the edge-cone corresponding to the directed edge and the positions of the vertices which define the directed edge.
  • 20. A method according to any one of aspects 16 to 19 or any other aspect herein wherein, for each directed edge, determining the target edge direction {circumflex over (n)}ij comprises performing a local optimization which optimizes (e g minimizes) a local energy function comprising a plurality of local terms, each local term expressing a preference for the target edge direction {circumflex over (n)}ij to be aligned with a normal vector of a corresponding one of the base triangles of the edge-cone corresponding to the directed edge.
  • 21. A method according to aspect 20 or any other aspect herein wherein, for each directed edge, performing the local optimization comprises determining the target edge direction {circumflex over (n)}ij in accordance with equation having the form of (9) described above.
  • 22. A method according to any one of aspects 20 to 21 or any other aspect herein wherein, for each directed edge, the local optimization is subject to non-inversion constraints.
  • 23. A method according to aspect 22 or any other aspect herein wherein, for each directed edge, the non-inversion constraints have the form of at least one of: equation (3) described herein; equations (10) and (11) described herein; or equations (26) and (11) described herein.
  • 24. A method according to any one of aspects 16 to 19 or any other aspect herein wherein, for each directed edge, determining the target edge direction {circumflex over (n)}ij comprises:


initially setting an initial target edge direction {circumflex over (n)}ij to correspond to the direction of an average of the normal vectors of the base triangles of the edge-cone corresponding to the directed edge;


evaluating whether the initial target edge direction {circumflex over (n)}ij satisfies non-inversion constraints; and


if the initial target edge direction {circumflex over (n)}ij satisfies non-inversion constraints, then determining the target edge direction {circumflex over (n)}ij to be the initial target edge direction {circumflex over (n)}ij and, otherwise, performing a local optimization which minimizes a local energy function which comprising a plurality of local terms, each local term expressing a preference for the target edge direction {circumflex over (n)}ij to be aligned with a normal vector of a corresponding one of the base triangles of the edge-cone corresponding to the directed edge.

  • 25. A method according to aspect 24 or any other aspect herein wherein, for each directed edge, performing the local optimization comprises determining the target edge direction {circumflex over (n)}ij in accordance with equation (9) described above.
  • 26. A method according to any one of aspects 24 to 25 or any other aspect herein wherein, for each directed edge, the local optimization is subject to the non-inversion constraints.
  • 27. A method according to any one of aspects 24 to 26 or any other aspect herein wherein, for each directed edge, the non-inversion constraints have the form of at least one of: equation (3) described herein; equations (10) and (11) described herein; or equations (26) and (11) described herein.
  • 28. A method according to any one of aspects 16 to 27 or any other aspect herein wherein, for each iteration of the iterative optimization, the weighted penalty term is based on the target edge direction {circumflex over (n)}ij.
  • 29. A method according to aspect 28 or any other aspect herein wherein, for each directed edge, the weighted penalty term comprises a penalty function Eijp which is optimized as part of the energy function and a penalty weight wijp that is updated between iterations of the second iterative optimization.
  • 30. A method according to aspect 29 or any other aspect herein wherein, for each directed edge, the penalty function Eijp expresses the preference for the directed edge to be aligned with a target edge direction {circumflex over (n)}ij.
  • 31. A method according to any one of aspects 29 to 30 or any other aspect herein wherein, for each directed edge, the penalty function Eijp is a quadratic function of the target edge direction {circumflex over (n)}ij.
  • 32. A method according to any one of aspects 29 to 31 or any other aspect herein wherein, for each directed edge, the penalty function Eijp has the form of equation (14) described above.
  • 33. A method according to any one of aspects 29 to 32 or any other aspect herein wherein, for each directed edge, the penalty weight wijp does not decrease between iterations of the iterative optimization.
  • 34. A method according to any one of aspects 29 to 33 or any other aspect herein wherein, for each directed edge, the penalty weight wijp is relatively low when the directed edge is relatively more aligned with a target edge direction {circumflex over (n)}ij and relatively high when the directed edge is relatively less aligned with the edge direction {circumflex over (n)}ij.
  • 35. A method according to any one of aspects 29 to 34 or any other aspect herein wherein the penalty weight wijp has the form of equation (16) described above.
  • 36. A method according to any one of aspects 28 to 35 or any other aspect herein wherein, for each directed edge, the weighted penalty term comprises a geometry factor W(αij) based at least in part on a largest angle αij between the target direction {circumflex over (n)}ij and the normal vectors of base triangles of the edge-cone corresponding to the directed edge.
  • 37. A method according to aspect 36 or any other aspect herein wherein the geometry factor W(au) increases as the largest angle au grows.
  • 38. A method according to any one of aspects 36 to 37 or any other aspect herein wherein the geometry factor W(au) has the form of either: equation (17) described above; or equation (27) described above.
  • 39. A method according to any one of aspects 14 to 38 or any other aspect herein wherein, for each iteration of the iterative optimization, the energy function comprises a parallel-edges regularization term Eregularize_parallel, which expresses a preference for directions of topologically parallel edges of the same hexahedron to be the same.
  • 40. A method according to aspect 39 or any other aspect herein wherein the parallel-edges regularization term Eregularize_parallel, has the form of the left-most expression on the right-hand side of equation (19) described herein.
  • 41. A method according to any one of aspects 14 to 40 or any other aspect herein wherein, for each iteration of the iterative optimization, the energy function comprises a consecutive-edges regularization term Eregularize_consecutive, which expresses a preference for directions of topologically consecutive edges of face-adjacent hexahedra to be the same.
  • 42. A method according to aspect 41 or any other aspect herein wherein the consecutive-edges regularization term Eregularize_consecutive has the form of the right-most expression on the right-hand side of equation (19) described herein.
  • 43. A method according to any one of aspects 20 to 27 or any other aspect herein wherein, for each surface directed edge having both of its vertices on a surface boundary of the input mesh, performing the local optimization comprises optimizing (e.g. minimizing) a boundary-edge energy function which expresses a preference for the surface directed edge to remain on the surface boundary.
  • 44. A method according to aspect 43 or any other aspect herein wherein optimizing the boundary-edge energy function comprises solving an equation having the form of equation (20) described herein.
  • 45. A method according to any one of aspects 1 to 44 or any other aspect herein wherein the energy function comprises a boundary preservation term Eboundary which expresses a preference for vertices which are on a surface boundary of the input hex mesh to remain on the boundary surface.
  • 46. A method according to any one of aspects 14 to 44 or any other aspect herein wherein, for each iteration of the iterative optimization, the energy function comprises a boundary preservation term Eboundary which expresses a preference for vertices which are on a surface boundary of the input hex mesh to remain on the boundary surface.
  • 47. A method according to any one of aspects 45 to 46 or any other aspect herein wherein the boundary preservation term Eboundary depends, for each surface vertex, whether the surface vertex is a feature vertex of an object underlying the input mesh, a corner vertex of the object underlying the input mesh or a regular surface vertex of the object underlying the input mesh.
  • 48. A method according to aspect 47 or any other aspect herein wherein the boundary preservation term Eboundary has a form of equation (21) described above.
  • 49. A method according to any one of aspects 45 to 47 or any other aspect herein wherein the boundary preservation term Eboundary has a form of at least one of the terms on the right hand side of equation (21) described above.
  • 50. A method according to any one of aspects 20 to 27 or any other aspect herein wherein, for each directed edge, performing the location optimization comprises performing the local optimization with first non-inversion constraints until the current mesh is free from inverted hexahedra and then switching the first non-inversion constraints to first quality-improvement constraints which require improved quality relative to previous iterations of the local optimization.
  • 51. A method according to aspect 50 or any other aspect herein wherein the first non-inversion constraints have the form of equation (9) described above and the first quality improvement constraints have the form of equation 26) described above.
  • 52. A method according to any one of aspect 36 to 38 or any other aspect herein comprising, for each iteration of the first iterative process, determining a worst angle w from among the largest angles αij across the plurality of edge-cones corresponding to the plurality of directed edges in the current mesh, and if w is less than 90°, changing the geometry factor W(αij) from a first geometry factor to a second geometry factor for subsequent iterations of the first iterative process, the second geometry factor different from the first geometry factor.
  • 53. A method according to aspect 52 or any other aspect herein wherein the first geometry factor has the form of equation (17) described above.
  • 54. A method according to any one of aspects 52 to 53 or any other aspect herein wherein the second geometry factor has the form of equation (27) described above.
  • 55. A system for improving quality of a hex-mesh, the system comprising:


one or more processors configured to:


obtain an input hex-mesh;


perform a first iterative procedure which starts with the input hex-mesh and which outputs an output hex-mesh having improved quality relative to the input hex-mesh;


wherein the one or more processors are configured to perform the first iterative procedure by:

    • initializing a current hex-mesh to be equal to the input hex mesh;
    • for each iteration of the first iterative procedure:
      • performing an optimization (e g minimization) of an energy function over a plurality of directed-edges in the current hex-mesh to determine updated vertex positions for vertices in the current hex-mesh, wherein for each directed edge, the energy function comprises a term that expresses a preference for the directed edge to be aligned with normal vectors of base triangles of an edge-cone corresponding to the directed edge; and
      • updating the current hex-mesh with the updated vertex positions; and
    • after one or more iterations, setting the output hex-mesh to be equal to the current hex-mesh.
  • 56. A system according to aspect 55 which comprises any feature, combination or features or sub-combination of features analogous to any of aspects 1 to 54.
  • 57. A non-transitory computer-readable medium comprising computer executable code that, when executed by a computer system comprising one computer or a plurality of computers operatively connected using a data communications network, causes the computer system to perform the method of aspect 1.
  • 58. A non-transitory computer-readable medium according to aspect 57 or any other aspect herein that, when executed by a computer system comprising one computer or a plurality of computers operatively connected using a data communications network, causes the computer system to perform any feature, combination or features or sub-combination of features analogous to any of aspects 1 to 54.


In addition to the exemplary aspects and embodiments described above, further aspects and embodiments will become apparent by reference to the drawings and by study of the following detailed descriptions.


Description

Throughout the following description specific details are set forth in order to provide a more thorough understanding to persons skilled in the art. However, well known elements may not have been shown or described in detail to avoid unnecessarily obscuring the disclosure. Accordingly, the description and drawings are to be regarded in an illustrative, rather than a restrictive, sense.


One aspect of the invention provides a computer-based automated method for improving the quality of (optimizing) an input hexahedral mesh (hex-mesh). The output of the method may be an output hex-mesh having improved average hexahedral element quality and/or improved minimum hexahedral element quality. As used herein, the relative quality of a hex-mesh element (i.e. a hexahedral element) may refer to how close the shape of the hex-mesh element is to a perfect cubic shape. Where a first hex-mesh element has a shape that is relatively close to a cubic shape (as compared to the shape of a second hex-mesh element), the first hex-mesh element may be referred to as having a higher quality (a better quality, an improved quality and/or the like) relative to the second hex-mesh element. Concave or inverted hex-mesh elements may be understood to have low quality relative to convex hex-mesh elements. For brevity, as used herein, the term mesh should be understood to refer to a hex-mesh, unless the context dictates otherwise.



FIG. 1 schematically illustrates an automated (computer-implemented) method 100 for optimizing (i.e. improving the quality of) an input hex-mesh 102 to generate an output hex-mesh 158 having an improved quality relative to input mesh 102, according to a particular embodiment. Method 100 (and its individual functional blocks) may be performed by a suitably configured computer or computer system (referred to herein as a computer). Such a computer may comprise hardware, software, firmware or any combination thereof, and may be implemented using any of a wide variety of components. By way of non-limiting example, such a computer may comprise a programmed computer system comprising one or more processors, user input apparatus, displays and/or the like. Such a computer may be implemented as an embedded system and may share components (e.g. a processor) with other apparatus/devices. Such a computer may comprise one or more microprocessors, digital signal processors, graphics processors, field programmable gate arrays, signal conditioning circuitry and/or hardware (e.g. amplifier circuits and/or the like) and/or the like. Components of the computer may be combined or subdivided, and components of the computer may comprise sub-components shared with other components of the computer.


Method 100 commences in block 110 which comprises obtaining an input hex-mesh 102. In general, input hex-mesh 102 can be obtained in block 110 using any suitable technique. In some embodiments, block 110 comprises receiving input hex-mesh 102 from an external system (e.g. via a suitable hardware and/or software input interface, such as a USB interface, a network interface and/or the like). In some embodiments, block 110 comprises obtaining input hex-mesh 102 from local memory and/or from a different software application running on the same computer. In some embodiments, input hex-mesh 102 obtained in block 110 comprises an automatically generated hex-mesh (e.g. a hex-mesh generated by an automated (computer-based) hex-mesh generation technique). Non-limiting examples of suitable automated hex-mesh generation techniques are disclosed, for example, in: SHEPHERD, J. F., AND JOHNSON, C. R. 2008. Hexahedral mesh generation constraints. Engineering with Computers 24, 3, 195-213; SCHNEIDERS, R. 1996. A grid-based algorithm for the generation of hexahedral element meshes. Engineering with Computers 12, 168-177; MARECHAL, L. 2009. Advances in octree-based all-hexahedral mesh generation: handling sharp features. In Proc. International Meshing Roundtable; TAUTGES, T. J., BLACKER, T., AND MITCHELL, S. A. 1996. The whisker weaving algorithm: a connectivity-based method for constructing all-hexahedral finite element meshes. Intl. Journal for Numerical Methods in Engineering 39, 19, 3327-3349; MIYOSHI, K., AND BLACKER, T. 2000. Hexahedral mesh generation using multi-axis cooper algorithm. In Proc. International Meshing Roundtable, 89-97; LI, Y., LIU, Y., XU, W., WANG, W., AND GUO, B. 2012. All-hex meshing using singularity-restricted field. ACM Trans. Graph. 31, 6; GREGSON, J., SHEFFER, A., AND ZHANG, E. 2011. All-hex mesh generation via volumetric polycube deformation. Computer Graphics Forum (Proc. SGP 2011); LIVESU, M., VINING, N., SHEFFER, A., GREGSON, J., AND SCATENI, R. 2013. Polycut: monotone graph-cuts for polycube base-complex construction. ACM Trans. Graph. 32,6; and HUANG, J., JIANG, T., SHI, Z., TONG, Y., BAO, H., AND DESBRUN, M. 2014. L1 based construction of polycube maps from complex shapes. ACM Trans. Graph. 33, 3 (June), 25:1-25:11.


In the illustrated embodiment of FIG. 1, block 110 also comprises initializing a current hex-mesh 112 to be the input hex-mesh 102. Subsequent operations in method 100 are then performed on current mesh 112 which may be updated during the course of method 100.


Once input hex mesh 102 is obtained in block 110, method 100 proceeds to optional block 120 which involves determining target edge lengths for the hex elements of current hex-mesh 112. Optional block 120 is not necessary. In some embodiments, block 120 is not present. Optional block 120 is described in more detail below. Method 100 then proceeds to block 150 which comprises a mesh optimization procedure based on an edge-cone formulation described in more detail below. The block 150 mesh optimization comprises improving the quality of input mesh 102 (or the initialized version of current hex-mesh 112) to generate output mesh 158, wherein the quality of output mesh 158 is improved relative to that of input mesh 102.


In block 150, method 100 comprises performing an optimization procedure which involves determining new vertex positions for each directed edge in current hex-mesh 112 and outputting output hex-mesh 158 based on these new vertex positions. The block 150 procedure may depend on a mesh quality assessment based on evaluation of so-called edge cones. The concept of edge-cones and their relationship to hex-mesh quality is now described.



FIG. 2A shows an ideal (i.e. cubic) hexahedral element 200 and the eight tetrahedrals 202A-202H (collectively, tetrahedrals 202) defined by the outgoing edges of the eight corner vertices 204A-204H (collectively, corners 204) of hex-element 200. In ideal hex-element 200, for each corner 204, each directed edge (not specifically enumerated) extending from the corner 204 is parallel to the normal vector (or, for brevity, the normal) of the planar face that is bounded by the other edges emanating from the corner 204. A hex-element is inverted if the angle between even one directed edge and its corresponding face normal (i.e. the normal of the planar face that is bounded by the other edges emanating from the same corner) is over 90°. It can be observed from FIG. 2A that the tetrahedrals 202 are formed by pairs of directed edges and corresponding triangular faces, with each such pair comprising: one directed edge that emanates from a comer; and one corresponding triangular face (i.e. the planar triangular face which is bounded by the other edges emanating from the same corner).



FIGS. 2B and 2C schematically depict the formation of an edge-cone 212 which may be used to evaluate mesh quality in accordance with particular embodiments. Each edge-cone 212 corresponds to (or has a one-to-one relationship) with a directed edge 214. As shown best in FIG. 2C, directed edge 214 may extend from vertex vi to vertex vj and may be referred to as directed edge (vi,vj). As shown in FIG. 2B, directed edge 214 is a part of (i.e. an edge of) a number of hexahedrons 210A-210E (collectively, hexahedrons 210). As shown in FIG. 2C, for each such hexahedron 210, directed edge 214 may be part of (i.e. an edge of) a corresponding tetrahedron 216A-216E (collectively, tetrahedrons 216) formed by directed edge 214 and a corresponding face (i.e. the planar face which is bounded by the other edges of the same hexahedron 210 which emanate from the same vertex vi. It should be noted that only tetrahedrons 216A, 216B, 216E are visible in FIG. 2C. The union of tetrahedrons 216 corresponding to directed edge 214, (vi, vj) may be referred to as the edge-cone 212 corresponding to directed edge 214, (vi,vj).


In some embodiments, the quality of a hex-mesh that includes a plurality of directed edges may be expressed in terms of the differences between the directions of: the directed edges which form the axes of corresponding edge-cones and the normal vectors of the triangular faces at their bases. For the particular edge-cone 212 shown in FIG. 2C, the quality of the edge cone may be expressed in terms of the differences between the direction of directed edge directed edge 214, (vi, vj) and the normal vectors of the triangles at the bases of tetrahedrons 216. By way of example, for tetrahedron 216A shown in FIG. 2C, the angular difference which goes into the quality evaluation may be the angular difference between the direction of directed edge 214, (vi, vj) and the normal vector corresponding to the triangle formed by vertices vi, uk and uk+1. FIG. 12D illustrates an exemplary directed edge 218 and the normal vectors 220A-220D (collectively, normal vectors 220) for the triangles 222A-222D (collectively, triangles 222) at the bases of corresponding tetrahedrons (not shown in FIG. 2D). If these angles are less than 90° for all the triangular faces, for all of the edge cones in a hex-mesh, then the hex-mesh is inversion free.


Referring back to FIG. 1, the block 150 optimization procedure may comprise determining new vertices for each directed edge in current mesh 112. Instead of directly assessing the quality of each hex-element in current mesh 112 and instead of assessing the quality of each hex-element of current mesh 112 using the eight tetrahedra associated with the eight corners of the hex-element, the block 150 optimization procedure may involve evaluating the quality of current mesh 112 by traversing the edge-cones in current mesh 112 and evaluating the quality of each edge-cone.


A particular embodiment of block 150 is now described. For the purposes of this explanation, we define custom-character to be a general hex-mesh with vertices custom-charactercustom-character and edges custom-charactercustom-character) respectively. For each directed edge (vi, vj), we define eij to correspond to the vector vi-vj. While the variables expressed in the description that follows may be expressed in terms of eij, in some embodiments, the variables actually optimized may comprise the underlying vertex positions. If we consider a directed edge eij from among the edges custom-charactercustom-character and the collection of all hexahedra H that contain eij, then we may define a set Q={qk} to be the set (e.g. the umbrella) of quadrilaterals belonging to H and containing the vertex vi but not the vertex vj we may further define T={tk} to be the set (e.g. the fan) of triangles that are connected to the vertex vi, with the understanding that T has a winding order consistent with the winding order of the quads of Q and that t|T|=t0 (i.e. the indices of tk reach a finite number and then return to zero). FIG. 2D schematically illustrates examples of such quadrilaterals Q={q0. . . q3} and triangles T={t0 . . . t3} for the particular example directed edge 218 shown in FIG. 2D.


Typically, an input hexahedral mesh may be assumed to have (or may be assigned) a consistent ordering of vertices, such that the vertices of any quadrilateral forming an individual hexahedral element, when viewed from the center of the hexahedral element, has a counterclockwise orientation. This in turn infers a counterclockwise orientation on the tetrahedral decomposition of the hexahedral elements of the mesh, and therefore on the vertices of any triangle on the tetrahedron. Denoting the vertices of an arbitrary triangle tk as uk; vi; uk+1 (as shown for a particular example triangle in FIG. 2C), it follows that for the tetrahedron having vertices vi; vj; uk; uk+1 to have a positive volume, the vertex vj must lie on the positive side of the supporting plane of the triangle tk (i.e. the triangle having vertices uk; vi; uk+1). This positive tetrahedral volume and corresponding condition on the vertices may be imposed for each triangle in the set T. The shape of each tetrahedron (e.g. its scaled Jacobian) is optimized if directed edge eij is aligned with the normal vectors nk corresponding to the triangles tk in the set T and, when the shape of a tetrahedron is optimized, the shape of the corresponding portion of its hexahedron is also optimized.


The block 150 optimization procedure may comprise determining the directions of each normalized directed edge êij(e.g.








e
ij




e
ij




)




and/or corresponding positions of vertices vi for current mesh 112, which minimize an energy function Eglobal comprising an energy term Econe, where Econe depends on the difference in orientation between the direction of edge eij and the normal vectors nk of its corresponding triangles over each directed edge in the current mesh 112. In one particular example embodiment, the energy function Eglobal includes only the energy term Econe—i.e.:





Eglobal=Econe   (1a)


In another example embodiment, the energy function Eglobal is given by:






E
global
=E
cone
+E
boundary   (1b)


where Eboundary represents a term that aims to preserve the boundary of input hex-mesh 102 and which is explained in more detail below.


In one particular example embodiment, the energy term Econe may be given by:










E
cone

=





e
ij


E








t
k



T


(

e
ij

)







(



e
ij




e
ij




-

n
k


)

2







(
2
)







where the left summation operator is over all of the directed edges eij in current hex-mesh 112 and the right summation operator is over all of the base triangles tk in an edge-cone corresponding to a particular directed edge eij.


The block 150 optimization and the corresponding minimization of the energy function Eglobal (of equation (1a) or (1b)) may be subject to non-inversion constraints which prevent the solutions of the block 150 optimization (i.e. the vertex positions vi) from corresponding to inverted hex-elements and/or inverted tetrahedra. In one particular embodiment, these block 150 non-inversion constraints may have the form, for each directed edge eij:






e
ij
·n
k>0 ∀eij ∈ε, tk ∈T(eij)   (3)


where the normal nk may be explicitly defined as a function of vertex positions:












n
k

-



(


u
k

-

v
i


)

×

(


u

k
+
1


-

v
i


)






(


u
k

-

v
i


)

×

(


u

k
+
1


-

v
i


)






=

0









e
ij


ɛ




,


t
k



T


(

e
ij

)







(
4
)







It may be observed that the energy term Econe of equation (2) expressly accounts for the opposite directions of each directed edge eij separately, as the tightness of the constraints on these directions may significantly differ.


Given the typical size of real-world meshes, optimizing the formulation of equations (1)-(4) directly using standard non-linear optimization methods may be impractical. In particular, the normalization by edge length in this formulation may present optimization challenges. Consequently, in some embodiments, the block 150 optimization involves the use of pre-estimated edge lengths Lij, where Lij represents the pre-estimated length of the edge between the vertices vi and vj. Pre-estimated edge lengths Lij may be determined in block 120, which is discussed in more detail below. Substituting such pre-estimated edge lengths Lij into equation (2) reduces equation (2) to the quadratic function:










E
cone

=


E
Qcone

=





e
ij


E








t
k



T


(

e
ij

)







(



e
ij


L
ij


-

n
k


)

2








(
5
)







and reduces equation (4) to:












n
k

-



(


u
k

-

v
i


)

×

(


u

k
+
1


-

v
i


)






L

k
,
i


×

L


k
+
1

,
i







=

0









e
ij


ɛ




,


t
k



T


(

e
ij

)







(
6
)








FIG. 3 is a schematic illustration of a method 150A which may be used to implement the block 150 optimization procedure according to an example embodiment. Method 150A comprises

    • (i) determining triangle normals nk (in block 152) for each triangle in the edge-cone corresponding to each directed edge eij. The block 152 triangle normal determination may be performed using current hex-mesh 112 and may comprise using equations having a form of either equation (4) or equation (6);
    • (ii) determining new vertex positions v1 (in block 153) by minimizing an energy function E global having a form of either equation (1a) or equation (1b) subject to the constraints of equation (3). The block 153 optimization may be performed on the basis of current hex-mesh 112. Where the approximate normals nk of equation (6) are used for step (i) (block 152), then step (ii) (block 153) may comprise a quadratic minimization problem with linear inequalities, solvable with standard quadratic programming methods. The step (ii) (block 153) quadratic minimization problem is convex and has a unique minimum;
    • (iii) updating current hex-mesh 112 (in block 154) to have the new vertex positions vi determined in step (ii) (block 153); and
    • (iv) repeating steps (i), (ii) and (iii) (blocks 152, 153 and 154) until satisfying a convergence criteria in block 155. Assessing convergence in block 155 may involve evaluating one or more convergence criteria. By way of non-limiting example, such block 155 convergence criteria may comprise: iteration-to-iteration changes in vertex positions that are below a convergence threshold; iteration-to-iteration changes in the energy function value that are below a convergence threshold; temporal thresholds; thresholds based on a number of iterations; until the quality of the hex mesh is above a minimum threshold for all hexahedral elements in the hex mesh; until the average quality of the hexahedral elements of the hex mesh is above a certain threshold; some combination of the above; and/or the like.
    • (v) outputting the updated current hex-mesh 112 as output hex mesh 158 once the block 155 convergence criteria are satisfied.


With the FIG. 3 embodiment (method 150A) of the block 150 optimization procedure, the resultant output hex-mesh 158 at the conclusion of method 150A has no inverted hex-elements. In some embodiments, when convergence occurs (block 155 YES branch) and the method 150A procedure terminates by outputting the vertex positions vi of current hex-mesh 112 as output hex-mesh 158 (block 156), the vertex positions vi, and hence the corresponding triangle normal nk, no longer change and, accordingly, the non-inversion constraints (equation (3) hold for the normals nk of output hex-mesh 158. In some circumstances, method 150A may terminate prematurely without finding a set of vertex positions vi that satisfies all of the non-equation (3) inversion constraints at the same time. Such a situation can arise in a number of scenarios including, without limitation, the case of degenerate base triangles, whose normals computed using equation (6) have zero length. Such scenarios can and do occur in practice if input mesh 102 is badly tangled (e.g. has a relatively large number of inverted hex-elements). However, since triangle normals can and do change as mesh vertices move, the fact that a current set of normals does not allow for a solution does not necessarily imply that a solution does not exist for a given mesh topology.



FIG. 4 schematically illustrates an automated (computer-implemented) method 300 for optimizing (i.e. improving the quality of) an input hex-mesh 102 to generate an improved quality output hex-mesh 158 according to a particular embodiment. Method 300 (and its individual functional blocks) may be performed by a suitably configured computer which may have any of the above-described characteristics of the computer that performs method 100. Method 300 commences in block 310 which comprises obtaining an input hex-mesh 102. In general, block 310 of method 300 may be substantially similar to block 110 of method 100 discussed above. Like block 110 described above, block 310 may comprise initializing a current hex-mesh 112 to be the input hex-mesh 102. Subsequent operations in method 300 are then performed on current mesh 112 which may be updated during the course of method 300.


Once input hex mesh 102 is obtained and current hex-mesh 112 is initialized in block 110, method 300 proceeds to optional block 320 which involves determining target edge lengths for the hex elements of current hex-mesh 112. Optional block 320 may be substantially similar to block 120 described elsewhere herein. In some embodiments, block 320 is not present. Method 300 then proceeds to block 330 which comprises a combined local/global mesh optimization loop (or for brevity, a mesh optimization loop 330). Mesh optimization loop 330 comprises improving the quality of input hex-mesh 102 to generate output hex-mesh 158, wherein the quality of output hex-mesh 158 is improved relative to that of input hex-mesh 102. In the illustrated FIG. 4 embodiment, mesh optimization loop 330 starts in block 360.


In block 360 of the illustrated FIG. 4 embodiment, method 300 comprises performing a local procedure (e.g. local to each directed edge eij and its corresponding edge-cone). Block 360 may involve determining target directions {circumflex over (n)}ij for each directed edge eij based only on parameters associated with the edge-cone corresponding to the directed edge eij (e.g. based on the base triangle normals nk of the edge-cone corresponding to the particular directed edge eij). In some embodiments, block 360 may comprise performing a local constrained optimization for each directed edge eij, where the constraints comprise local non-inversion constraints based on the edge-cone corresponding to the particular directed edge eij (e.g. non-inversion constraints based on the base triangle normals nk of the edge cone corresponding to the particular directed edge eij).


In one particular embodiment, block 360 comprises, for each directed edge eij, determining a target direction {circumflex over (n)}ij based on a local optimization having the form:






ñ
ij=arg min Σk=0T(ñij−nk)2   (9)


subject to the local non-inversion constraints having the form:






{circumflex over (n)}
ij
·n
k<ε<0 ∀tk ∈T   (10)





ñij2≦1   (11)


It may be observed that equations (9)-(11) form a constrained optimization problem whose solution {circumflex over (n)}ij minimizes equation (9) subject to the constraints of equations (10) and (11). It may also be observed that equation (9) and (10) are only evaluated over the local edge-cone that corresponds to the directed edge eij and the base triangles of the local edge-cone. The convex constraint of equation (11) replaces the explicit, but non-convex, requirement for the target direction {circumflex over (n)}ij to have unit length. In some embodiments, the equation (11) constraint could be replaced by an equality (e.g. ∥{circumflex over (n)}ij2=1). In block 360, the base triangle normals nk may be determined based on current hex mesh 112. The current hex mesh 112 used in block 360 may be based on: the initialized value of current hex mesh 112 (applied in block 310); or the update to current hex mesh 112 after the last iteration of mesh optimization loop 330 (e.g. after the block 370 global procedure, as described in more detail below). The base triangle normals nk may be determined on the basis of an equation having the form of equation (4) or equation (6) and, in some embodiments, may be normalized to have unit length. The resulting target directions ñij may be similarly normalized. It should be noted that if all that was required was for the dot product {circumflex over (n)}ij·nk to be positive, the equation (11) constraint could be eliminated. However, in some embodiments, a greater than zero threshold ε is used in the equation (10) constraint (for reasons discussed in more detail below). Accordingly, the equation (11) constraint is explicitly included in this description to prevent the resulting target directions {circumflex over (n)}ij from satisfying the equation (10) constraint by scaling.


The block 360 local optimization (as characterized by the formulation of equations (9), (10) and (11) or otherwise) may comprise, for each directed edge eij, a quadratic convex optimization problem with linear and quadratic inequality constraints on the three coordinates of target direction {circumflex over (n)}ij. The block 360 optimization can be solved efficiently and robustly using standard quadratic programming tools such as, by way of non-limiting example, those disclosed by GUROBI OPTIMIZATION, 2013 at http://www.gurobi.com/. In some circumstances (e.g. with some directed edges of particular input meshes 102), equation (9) is minimized by a target direction {circumflex over (n)}ij that is the conventional average of the base triangle normal nk and satisfies the non-inversion constraints (e.g. constraints of the form of equations (10) and (11)) as-is. Consequently, in some embodiments, to speed-up computation, block 360 may first attempt to determine a base solution target direction {circumflex over (n)}ij (e.g. a target direction {circumflex over (n)}ij that is the conventional average of the base triangle normal nk) and evaluate whether the base solution target direction {circumflex over (n)}ij satisfies the non-inversion constraints. If it is determined that the base solution target direction {circumflex over (n)}ij does not satisfy the non-inversion constraints, block 360 may revert to using a quadratic programming solver.


Where the block 360 local optimization is a quadratic convex optimization problem with linear and quadratic inequality constraints, a target direction ñij that satisfies all the non-inversion constraints may not always exist. However, an advantage of a localized solution is that method 300 can still proceed with the block 370 global procedure (or the remaining portion of an iteration of mesh optimization loop 330) in a meaningful way, even without a block 360 solution. Where, for a particular directed edge eu, the block 360 local optimization does not yield an inversion-free solution, block 360 may, in some embodiments, return the target direction {circumflex over (n)}ij to be either the current edge direction (e.g. the direction of eij in current hex-mesh 112) or the average of the base triangle normals nk (e.g. the unconstrained minimizer of equation (9)). In some embodiments, the decision between these two output target directions {circumflex over (n)}ij may be based on the largest angle αij between the direction of the proposed output target direction {circumflex over (n)}ij and the base triangle normals nk. In some embodiments, where this circumstance arises for a particular directed edge eij in block 360, block 360 comprises selecting the output target directions {circumflex over (n)}ij to be the direction for which this largest angle au is the smallest. In some embodiments, block 360 may make this same election of output target directions {circumflex over (n)}ij if one of the base triangle normals nk has zero length. Since, in some embodiments, the block 360 local optimization seeks for all directed edges eij to have a known target length (e.g. Lij) and indirectly optimizes the base triangle angles αij, such degenerate configurations are typically resolved during the first iteration of mesh-optimization loop 330.


In some embodiments, the above discussed implementation of block 360 is used for interior edges eij (i.e. edges eij other than surface edge). In some embodiments, block 360 may use a modified formulation for surface edges. This modified formulation is described in more detail below.



FIG. 5 schematically illustrates a method 400 which may be used to implement the block 360 local procedure according to an example embodiment. Method 400 shown in FIG. 5 is implemented once for each directed edge eij in current hex-mesh 112 and may be based on the characteristics of the edge-cone corresponding to the directed edge eij. Method 400 commences with block 401 which involves determining the triangle normals nk for each base triangle of the current directed edge based on current hex mesh 112. The determination of the base triangle normals nk for the current directed edge in block 401 may be similar to block 152 of method 150A described above and may be based on equation (4) or equation (6) suitably modified for application to a single directed edge. Method 400 then proceeds to the block 402 inquiry as to whether any of the base triangle normals nk corresponding to the current directed edge have zero length. If there are base triangle normals with zero length, then the block 402 inquiry is positive, and method 400 proceeds via the block 402 YES branch to block 416 discussed further below. Otherwise, method 400 proceeds via the block 402 NO branch to block 404, where the target direction {circumflex over (n)}ij is set to be the average of the base triangle normals (e.g. the unconstrained solution to equation (9)). Method 400 then proceeds to block 406 which involves an inquiry into whether the block 404 target direction {circumflex over (n)}ij satisfies the applicable non-inversion constraints (e.g. constraints having the form of equations (10) and (11)). If the block 406 inquiry is positive, then the block 404 target direction {circumflex over (n)}ij is output in block 408. If, on the other hand, the block 406 inquiry is negative, then method 400 proceeds to block 410 which involves implementing a quadratic programming solver to attempt to solve the constrained optimization problem (e.g. having the form of equations (9), (10) and (11)) to obtain a target direction {circumflex over (n)}ij. Method 400 then proceeds to block 412 which involves an inquiry into whether the block 410 quadratic programming solver obtained a target direction {circumflex over (n)}ij that satisfies the non-inversion constraints. If the block 412 inquiry is positive, then the block 420 target direction {circumflex over (n)}ij is output in block 414. If, on the other hand, the block 412 inquiry is negative, then method 400 proceeds to block 416. Block 416 can be reached via the block 402 YES branch or the block 412 NO branch. Block 416 may involve selecting the output target direction {circumflex over (n)}ij to be one of: the current edge direction (e.g. the direction of eu in current hex-mesh 112) or the average of the base triangle normals nk (e.g. the unconstrained minimizer of equation (9) or the block 404 target direction {circumflex over (n)}ij). As discussed above, in some embodiments, the particular one of the target directions {circumflex over (n)}ij chosen in block 416 may be based on the largest angle αij between the direction of the proposed output target direction {circumflex over (n)}ij and the base triangle normals nk. In some embodiments, block 416 comprises selecting the output target directions {circumflex over (n)}ij to be the direction for which this angle αij is the smallest.


Referring back to FIG. 4, the block 360 local procedure outputs target edge directions {circumflex over (n)}ij, 362 for each directed edge eij in current hex-mesh 112. Method 360 then proceeds to the global procedure in block 370. In some embodiments, the block 370 global procedure may comprise an iterative optimization procedure which determines new vertex positions vi (e.g. globally for current mesh 112) that attempt to align the directed edges eij of current mesh 112 with the block 360 target directions {circumflex over (n)}ij. Rather than using hard non-inversion constraints (which may result in a premature termination of the optimization procedure similar to that discussed above in connection with method 100), the block 370 global procedure may use penalty functions between successive iterations which may keep the block 370 vertex positions (in each iteration) relatively close to the block 360 target directions {circumflex over (n)}ij. The use of penalty functions in block 370 may permit the block 370 optimization to proceed to the next iteration in cases where the non-inversion constraints cannot be immediately satisfied.


Block 370 may use an energy function Eglobal based on one of equations (1a) or (1b) describe above and may be augmented by a penalty term as discussed in more detail below. In some embodiments, the block 370 energy function may have the form:






E
global
=Ê+Σ
i
W
i
p
E
i
p   (13)


Where: Ê is the desired energy function, but for the penalty term (e.g. the right hand side of one of equations (1a) or (1b), with the possible addition of other terms as described in more detail below); Wip are individual penalty weights; and Eip are weighted penalty terms. Block 370 may apply per-edge-cone (or per directed edge) penalty terms aimed to keep the edge directions determined in each iteration of the block 370 global procedure sufficiently close to the bock 360 target directions {circumflex over (n)}ij. In some embodiments, the block 370 penalty formulation is based on the observation that the norm of the difference between unit-length vectors is above unity when the angle between the unit length vectors is obtuse, and less than one, when the two unit-length vectors are relatively close (under 60°). Thus for larger angles, a high order monomial of this norm may serve as a penalty whose cost increases dramatically as the angle increases, strongly discouraging any solution where the new edge directions deviate far enough from the target to the point where a tetrahedron in an edge-cone becomes inverted. At the same time, the maximal distance between unit-length vectors is 2, providing a natural upper bound on the size of the penalty. With this formulation, the block 370 penalty scheme will terminate, as the penalties may not increase indefinitely.


In some embodiments, to keep the optimized energy function Eglobal quadratic, block 370 may comprise separating a penalty monomial into a quadratic term, which we treat as a penalty function










E
ij
P

=






e
ij



L
^

ij


-


n
^

ij




2





(
14
)







and a higher order higher-order weight term wijp which is updated between penalty iterations within block 370 and which, in some embodiments, is never decreased. Determination of the normalization factors {circumflex over (L)}ij is described in more detail below. In some embodiments, the weights wijp are initially set to 1. After a solution to a particular iteration within block 370 is obtained, block 370 may comprise updating the penalty weights wijp by setting










w
ij
P

=

max


(


w
ij
P

,






e
ij



L
^

ij


-


n
^

ij




6


)






(
16
)







The choice of the exponent being six in equation (16) is empirical and not mandatory. The inventors have found that lower values for this exponent did not sufficiently penalize large angular deviations from the block 360 desired directions {circumflex over (n)}ij, leading to decreases in solution quality, while larger exponents reduced numeric stability (e.g. because increasing the exponent increases the ratio between the largest and smallest elements of the gradient matrix of the block 370 energy function, which in turn increases its condition number).


When selecting the normalization factors {circumflex over (L)}ij, focusing on angle only involves considering a pure directional difference—e.g. normalizing each directed edge of current hex-mesh 112 by its length at the beginning of the block 370 global procedure. In some circumstances, this choice may be sub-optimal (e.g. if the edge-length of a directed edge in current hex-mesh 112 is significantly different from its estimated target edge length (e.g. its block 320 target edge length), as the edge-length of current hex-mesh 112 may be a poor predictor of the edge-length after the block 370 optimization which is expected to get closer to its target edge length. In some embodiments, block 370 comprises anticipating this change in edge-length by, for each edge, setting









L
^

ij

=





e
ij



+

L
ij


2


,




where ∥eij∥ is the edge-length of the edge in current hex-mesh 112 and Lij is the block 320 estimated target edge length discussed elsewhere in this description.


In some embodiments, block 370 also involves recognizing that the degree to which an edge eij and its block 360 target direction {circumflex over (n)}ij should be aligned may depend on the geometry of the edge-cones determined in the block 360 local procedure. Specifically, block 370 may comprise considering the largest angle αij between the block 360 target direction {circumflex over (n)}ij and the corresponding edge-cone's base triangle normal nk used in block 360. To minimize (or reduce) the likelihood of inversion in block 370, when αij is below 90°, the edge eij determined in each iteration of block 370 and the block 360 target direction {circumflex over (n)}ij should be more aligned as the angle αij grows. In some embodiments, therefore, block 370 comprises multiplying the weights wijp by a function that penalizes deviation between the edge eij determined in each iteration of block 370 and the block 360 target direction {circumflex over (n)}ij more significantly as the angle αij grows. In some embodiment, block 370 comprises multiplying the weights wijp by a function of the angle αij. In one particular embodiment, block 370 comprising multiplying the weights wijp by a function having the form










W


(

α
ij

)


=

1
+

10





-

cosα
ij
2



2


σ
2










(
17
)







In some embodiments, σ is set at σ=0.3 using the three sigma rule for the weight to drop to 1 when the angle αij is zero, allowing for larger deviation.


In some embodiments, the block 370 global procedure may comprise iterative optimizing a quadratic energy function having the form:






E
global
=Ê+Σ
ij
Wij)wijpEijp   (18)


where: Ê is the desired energy function, but for the penalty term (e.g. the right hand side of one of equations (1a) or (1b), with the possible addition of other terms as described in more detail below); W(αij)wijp are individual penalty weights; and Eip are weighted penalty terms. Block 370 may comprise iteratively repeating the optimization (e g minimizing equation (18)) with the current penalty weights and then updating the penalty weights W (αij)wijp until the vertex positions vi and/or the combined energy function (e.g. equation (18)) no longer change or change less than a suitable threshold amount. Note that, as expected from penalty terms, the weights W(αij)wijp do not decrease between iterations. It will also be appreciated that, in some embodiments, the block 370 penalties are applied to a particular edge eij only if the block 360 target directions {circumflex over (n)}ij satisfy the non-inversion inequalities in block 360 (corresponding to αij=90°). If the non-inversion constraints are not satisfied for a particular edge eij, then that particular edge may be omitted from penalties (e.g. omitted from the summation term of equation (18)). This can be appreciated on the basis that block 370 should only penalize changes from target directions corresponding to non-inverted conditions, and changes from inverted conditions should be welcomed.



FIG. 6 schematically illustrates a method 440 which may be used to implement the block 370 global procedure according to an example embodiment. Method 440 shown in FIG. 6 is implemented globally, which may be, but need not necessarily be, performed over the entire current mesh 112 and/or which may be performed over a suitable portion of current mesh 112 comprising a plurality of edge-cones. Method 440 commences in block 442 which comprises determining the base triangle normal vectors nk for each directed edge eij in current mesh 112. In some embodiments, these base triangle normals may already be known (e.g. from procedures performed in block 360). Method 440 then proceeds to block 444 which comprises performing an iteration of the optimization using the current penalty weights (e.g. W(αij)wijp). As discussed above, in some embodiments, the initial penalties may be set to unity on the first iteration of method 440 and may be updated in each successive iteration of method 440. The block 444 optimization may comprise minimizing an energy function Eglobal (which may have the form of equation (18)) to determine new vertex positions vi. Method 440 may then proceed to block 446 which comprises determining new penalty weights (e.g. W(aij)wijp). In some embodiments, the block 446 terms wijp may be determined using the block 444 new vertex positions and an equation having the form of equation (16). In some embodiments, the block 446 terms W (αij) may be determined using the block 444 new vertex positions and an equation having the form of equation (17). Method 440 then proceeds to block 448 which involves updating the current hex-mesh 112 based on block 444 new vertex positions. This block 448 updated current mesh 112 (together with the block 446 updated weights) may be used for successive iterations of method 440. Method 440 then proceeds to block 450 which involves the evaluation of one or more loop-exit (convergence) criteria. In some embodiments, such block 450 convergence criteria may comprise, without limitation, evaluating whether the changes in the block 444 vertex positions vi (or equivalently changes in current mesh 112) between successive iterations are less than a suitable threshold, evaluating whether the changes in the combined energy function (e.g. equation (18)) between successive iterations are less than a suitable threshold, evaluating a threshold based on the number of iterations, evaluating a threshold based on some temporal criteria and/or the like. If the block 450 convergence criteria is not met, then method 440 loops back to block 442 with the block 448 updated current hex mesh 112 and the block 446 updated weights. If the block 450 convergence criteria is met, then method 440 proceeds to block 452, where current hex-mesh 112 is output as a result of method 440.


Returning back to FIG. 4, it can be seen that the current hex-mesh 112 is the output of block 370 prior to an evaluation of loop exit criteria in block 380. Block 380 involves evaluation of an overall loop exit criteria. The block 380 loop exit criteria may comprise, by way of non-limiting example, evaluating whether the changes in the vertex positions vi (or equivalently changes in current mesh 112) between successive iterations of mesh-optimization loop 330 are less than a suitable threshold, evaluating hard constraints (e.g. of the form of equation (8)), evaluating a threshold based on the number of iterations of mesh-optimization loop 330, evaluating a threshold based on some temporal criteria and/or the like. If the block 380 loop-exit criteria are not met, then method 300 loops again through the local/global optimizations of blocks 360, 370. If, however, the block 380 loop-exit criteria are met, then method outputs current hex-mesh 112 as output hex-mesh 158. Output hex-mesh 158 may have improved quality relative to input hex-mesh 102.


A number of optional procedures are now described which may be used in various embodiments and/or in various blocks of methods 100, 300.


In some embodiments, the energy function Eglobal described above may be augmented with a regularization term Eregularize which may be aimed at generating more unified edge directions for adjacent mesh edges which leverages the structure of the hexahedral mesh. The regularization term Eregularize may be added, for example, to the right hand side of equation (1a), (1b) and/or (18). The regularization term Eregularize may form part of the term Ê in equation (18). It may be observed that for high quality hex-meshes, the directions of topologically parallel edges within the same hex (FIG. 7A) and of consecutive edges on face-adjacent hexes (FIG. 7B) are expected to be quite similar. Optimizing for direction similarity of such edges may help to guide the target edge directions across the mesh toward a more uniform solution, thereby improving the stability of the optimization process of methods 100, 300. Some embodiments employ a regularization term of the form:










E
regularize

=





e

E





1



P


(
e
)











e
p



P


(
e
)










e

L
e


-


e
p


L
p





2




+




e

E





1



C


(
e
)











e
c



C


(
e
)










e

L
e


-


e
p


L
p





2









(
19
)







where ep ∈ P(e) are the edges topologically parallel to a given edge e and ec ∈ C (e) are its consecutive edges. In the equation (19) formulation, all vectors are normalized by target edge lengths |Le|, |Lp|, |Lc| to optimize for the desired length proportion.


A desirable feature in some mesh optimization applications and/or embodiments involves the preservation of the outer surface of the mesh (which may correspond to the outer surface of an object, for example). Some embodiments of methods 100, 300 may achieve this desirable feature by fixing the positions of the surface vertices. However, in some applications and/or embodiments, such strict positional constraints are too restrictive, as often mesh quality can be improved by allowing the surface vertices to slide along the boundary surface but without moving away from the boundary surface. Moreover, in some applications and/or embodiments, one cannot obtain an inversion-free mesh without allowing the mesh vertices to deviate from the boundary surface. Thus, in some embodiments, methods 100, 300 use a boundary formulation that balances surface preservation against mesh quality.


To optimize the quality of hexahedra along the boundary surface, some embodiments include partial cones around each surface edge. As the aim may be for surface edges to remain on the surface, the local step (e.g. block 360 of method 300) equation (9) may be modified for surface edges:











n
^

ij

=


argmin






k
=
1





T


(

e
ij

)








(



n
^

ij

-

n
k


)

2



+

β







n
ij

·

n









(
20
)







where: {hacek over (n)} is the average of the original surface normals at vi and vj; and β is a configurable constant (e.g. β=10). The treatment of boundary edges in the global step (e.g. step 370 of method 300) may be similar to that of interior edges.


Expressing exact or approximate surface preservation in closed form (instead of just preserving the current locations) may involve the use of an analytic surface definition, which is typically rarely available. Thus to constrain vertices to remain on or close to the surface, some embodiments may employ a local surface approximation. Some embodiments may distinguish between regular surface vertices v ∈ S, feature vertices v ∈ F and corners (vertices at the junction of multiple features) v ∈ C. To preserve the surface, some embodiments may use three types of per-vertex energy terms, selected by vertex type. Some embodiments may use a boundary energy term having the form:










E
boundary

=





v

S





β


(



n
^

·
v

+

d
^


)


2


+




v

F




(



α


(

v
-

(


v
^

+

a


t
^



)


)


2

+

a
2


)


+




v

C





α


(

v
-

v
^


)


2







(
21
)







where: {circumflex over (v)} is the reference, or closest, surface position for each vertex; <{circumflex over (n)}, {circumflex over (d)}> is the implicit equation of the plane passing through {circumflex over (v)} and orthogonal to the input surface normal {circumflex over (n)} at that point; {circumflex over (t)} is the feature tangent at {circumflex over (v)}; a is an auxiliary variable added to the system to enable feature constraints; and α is a configurable constant for feature and corner weight. In some embodiments, α is set to α=20. The equation (21) boundary term Eboundary may be added, for example, to the right hand side of equation (1a), (1b) and/or (18). The equation (21) boundary term Eboundary may form part of the term Ê in equation (18). It may be observed that the equation (21) boundary term Eboundary is quadratic, thus augmenting the combined energy function Eglobal with the equation (21) boundary term Eboundary does not affect the convexity of the global optimization performed in methods 100, 300.


As discussed above, methods 100, 300 may make use of target, or optimal, edge lengths in a number of places in the formulation described above. Such target edge lengths may be determined in block 120 of method 100 and/or block 320 of method 300, for example. Such target edge lengths may be used in the remainder of method 100 and/or method 300. In many meshing frameworks, such target edge lengths are provided by users and may be based on simulation needs. Absent this high-level knowledge, when the mesh density is by design (or otherwise) non-uniform (e.g. for meshes created with octree-based methods), the input edge lengths provide a plausible estimation of the target edge length. If the mesh density is expected to be uniform, some embodiments may provide a better initial length estimate by leveraging the existing surface mesh sizing. In general, one expects mesh size changes to be gradual, indicating a preference for similar lengths on both topologically parallel and consecutive edges. Further, as a uniformly sized mesh is sought, the average edge length LA in the current mesh (which may be the input mesh) may serve as a good initial approximation of target interior mesh edge lengths. Some embodiments involve combining these observations to motivate an optimization having an edge-length energy function Elength having the following formulation for obtaining target edge lengths Le:






E
length=Σe∈Sr(L

e

−∥e∥
2)2e∈E/Sr(Le−LA)2+Σep∈p(e)(Le−Lp)2ec∈c(e)(Le−Lc)2   (22)


where: e ∈ S′ are the surface edges having both vertices on a boundary surface; e ∈ E/S′ are non-surface edges having at least one vertex that is not on a boundary surface; ep ∈ P(e) are the edges topologically parallel to e; ec EC (e) are the edges topologically consecutive to e; ∥e∥ are original edge lengths; LA is the average edge length in the mesh; Lp is the length of a a topologically parallel edge ep; and Lc is the length of a topologically consecutive edge ec. Blocks 120 and/or 320 described above, may comprise optimizing (e.g. minimizing) an equation having the form of equation (22). The resulting edge lengths Le balance the expectation of uniformity against the desire to preserve the current surface edge lengths. The resulting set of edge lengths Le determined in accordance with this edge-length optimization may be used as the target edge lengths Lij described at other locations herein.


In some embodiments, the overall hex-mesh optimization (e.g. of method 100 and/or method 300) can start with these target edge-lengths (e.g. by estimating same in blocks 120 and/or 320). In some embodiments, these target lengths can be updated selectively, reflecting the local mesh element quality, by linearly interpolating between the target edge lengths Le and current edge lengths ∥e∥,






L
e=(1−wLe+w∥e∥  (23)


where w is a Gaussian function of the smallest hex element minimal scaled jacobian (MSJ) q of any hex connected to the target edge:









w
=




-
0.5

·


(

q
σ

)

2







(
24
)







where σ is a configurable constant (set, in some embodiments, to σ=0:15). This selective update aims to preserve the original target lengths in areas where the mesh quality is sufficiently high, so as to preserve the mesh in these areas as is, while updating edge lengths in areas where the quality is poor.


As discussed above, in some embodiments, the global energy function Eglobal optimized in method 100 or in the global procedure 370 of method 300 may comprise a sum of some of the optional energy terms discussed above. In some embodiments, the global energy function Eglobal optimized is given by equation (18), where the Ê term is given by:






Ê=E
cone
+E
regularize
+E
boundary   (25a)


where: Econe has a form of equation (2) or equation (5), where Eregularize has a form of equation (19) and Eboundary has a form of equation (21). This yields a global energy function Eglobal having the form:






E
global
=E
cone
+E
penalty
+E
regularize
+E
boundary   (25b)


where Epenalty is the summation in the right hand side of equation (18). Since the minimized functional (the global energy function Eglobal) is quadratic, some embodiments make use of a standard linear solver (GMRES or SuperLU, for example) to compute the minimizer of equation (25). Once the iterations of the global procedure converge (e.g. iterative changes to the vertex positions vi or the energy value Eglobal are less that a suitable threshold), some embodiments may optionally comprise repeating the hex-mesh optimization process (e.g. method 100 or method 300) with updated target edge lengths (as discussed above e.g. repeating method 100 and/or 300 with updates to the target edge lengths determined in optional block 120 and/or 320).


The framework described above is designed to obtain inversion-free meshes with high average element quality. However, some simulations have minimal, or worst, element quality restrictions that are more stringent than mere convexity. In some embodiments, the formulation described above aims for minimal angle between each directed edge and the base triangle normals of its associated edge-cone to be some configurable constant θ close to 90° (e.g. θ=85°, in some embodiments) and uses ε=cos(θ) in equation (10). In some embodiments, to achieve an improved minimum quality, a variation of the above-described techniques may be used to progressively improve the minimal quality of the resultant hex-mesh. In particular, some embodiments may comprise changes to equations (10) and (16) to achieve this result. Once all local solution spaces are not empty (i.e. all cone angles αij are below 90°, the default minimal angle threshold ε (in equation (10)) may be replaced with a local threshold whose goal is to further improve the local cone-quality:






{circumflex over (n)}
ij·>cos(αij+ε) for all tk ∈T(eij)   (26)


where αij is the worst current angle between the directed edge eij and the normals of the base triangles of its corresponding edge-cone and ε is some configurable constant (e.g. ε=0.01, in some embodiments). This change imposes a requirement that all directed edge target directions {circumflex over (n)}ij determined by the local procedure (block 360) be better aligned with respect to the normals of the base triangles of its corresponding edge-cone than they are using the above-described equation (10). In some embodiments, the above-described target direction {circumflex over (n)}ij may be kept if and when the equation (26) requirement results in an empty solution space. In some embodiments, no effort is made to improve the local cones if cos(au) is above a suitably high-quality threshold (e.g. cos(αij)>0.5).


Some embodiments also comprise determining the current worst angle w across all edge-cones. If this current worst angle value w is under 90°, the angle-based weight W(αeij) in the penalty function (equation (16)) may be updated to be maximized at this worst angle,










W


(

α
eij

)


=

1
+

10





-


(


cos


(

α
ij

)


-

cos


(
ω
)



)

2



2


σ
2










(
27
)







Mesh-optimization loop 330 (with these updates for maximizing minimal quality (e.g. equations (26) and (27))) may be performed, re-determining αij and w each time the process converges (e.g. for each iteration of mesh-optimization loop 330) and may be concluded when further improvement is no longer possible (e.g. w no longer increases) or once the minimal quality reaches a user-configurable minimal quality value.



FIG. 8 is a schematic depiction of a system 500 which may be used to perform any of the methods described herein and the steps of any of the methods described herein according to a particular embodiment. System 500 of the illustrated embodiment comprises one or more computers 502 which may comprise one or more processors 504 which may in turn execute suitable software (not expressly enumerated) accessible to processor(s) 504. When such software is executed by computer 502 (and in particular processor(s) 504), computer 502 and/or processor(s) 504 may perform any of the methods described herein and the steps of any of the methods described herein. In the illustrated embodiment, computer 502 provides a user interface 510 for interaction with a user 506. From a hardware perspective, user interface 510 comprises one or more input devices 508 by which user 506 can input information to computer 502 and one or more output devices 512 by which information can be output to user 506. In general, input devices 508 and output devices 512 are not limited to those shown in the illustrated embodiment of FIG. 6. In general, input device 508 and output device 512 may comprise any suitable input and/or output devices suitable for interacting with computer 502. User interface 510 may also be provided in part by software when such software is executed by computer 502 and/or its processor(s) 504. In the illustrated embodiment, computer 502 is also connected to access data (and/or to store data) on accessible memory device 518. In the illustrated embodiment, computer 502 is also connected by communication interface 514 to a LAN and/or WAN network 516, to enable accessing data from networked devices (not shown) and/or communication of data to networked devices.


Input (e.g. input hex-mesh 102) may be obtained by computer 502 via any of its input mechanisms, including, without limitation, by any input device 508, from accessible memory 518, from network 516 or by any other suitable input mechanism. The outputs (e.g. output hex-mesh 158) may be output from computer 502 via any of its output mechanisms, including, without limitation, by any output device 512, to accessible memory 518, to network 516 or to any other suitable output mechanism. As discussed above, FIG. 8 is merely a schematic depiction of a particular embodiment of a computer-based system 500 suitable for implementing the methods described herein. Suitable systems are not limited to the particular type shown in the schematic depiction of FIG. 8 and suitable components (e.g. input and output devices) are not limited to those shown in the schematic depiction of FIG. 8.


The methods described herein may be implemented by computers comprising one or more processors and/or by one or more suitable processors, which may, in some embodiments, comprise components of suitable computer systems. By way of non-limiting example, such processors could comprise part of a computer-based automated contract valuation system. In general, such processors may comprise any suitable processor, such as, for example, a suitably configured computer, microprocessor, microcontroller, digital signal processor, field-programmable gate array (FPGA), other type of programmable logic device, pluralities of the foregoing, combinations of the foregoing, and/or the like. Such a processor may have access to software which may be stored in computer-readable memory accessible to the processor and/or in computer-readable memory that is integral to the processor. The processor may be configured to read and execute such software instructions and, when executed by the processor, such software may cause the processor to implement some of the functionalities described herein.


Certain implementations of the invention comprise computer processors which execute software instructions which cause the processors to perform a method of the invention. For example, one or more processors in a computer system may implement data processing steps in the methods described herein by executing software instructions retrieved from a program memory accessible to the processors. The invention may also be provided in the form of a program product. The program product may comprise any medium which carries a set of computer-readable signals comprising instructions which, when executed by a data processor, cause the data processor to execute a method of the invention. Program products according to the invention may be in any of a wide variety of forms. The program product may comprise, for example, physical (non-transitory) media such as magnetic data storage media including floppy diskettes, hard disk drives, optical data storage media including CD ROMs, DVDs, electronic data storage media including ROMs, flash RAM, or the like. The instructions may be present on the program product in encrypted and/or compressed formats.


Where a component (e.g. a software module, controller, processor, assembly, device, component, circuit, etc.) is referred to above, unless otherwise indicated, reference to that component (including a reference to a “means”) should be interpreted as including as equivalents of that component any component which performs the function of the described component (i.e., that is functionally equivalent), including components which are not structurally equivalent to the disclosed structure which performs the function in the illustrated exemplary embodiments of the invention.


As will be apparent to those skilled in the art in the light of the foregoing disclosure, many alterations and modifications are possible in the practice of this invention without departing from the spirit or scope thereof. For example:

    • This description uses the terms “global”, “globally” as a matter of convenience to distinguish from operations that are “local” or performed “locally”. Unless the context dictates otherwise, the terms “global” or “globally” should not be interpreted strictly to require that an operation performed globally is performed for every vertex and/or for every edge of a mesh. For example, in some cases, operations performed globally could include operations performed on an entirety of current mesh 112 or input mesh 102 (e.g. for every vertex and/or edge of the mesh), but this is not strictly necessary. In some embodiments, or applications, operations performed “globally” may be performed on a portion or portion(s) of current mesh 112 or input mesh 102 that includes a plurality of directed edges or a plurality of edge-cones. Similarly, in some embodiments, an object represented by an input mesh 102, an input mesh 102 and/or a current mesh 112 could be parsed into several portions, each of which could be treated as an input mesh 102 or a current mesh 112 on which operations could be performed globally. By way of non-limiting example, the methods described herein may be applied to problem portions of the mesh, while leaving non-problematic portions of the mesh unchanged.
    • The above-described penalty terms represent only one form of penalty term that could be used in particular embodiments (e.g. with energy function of equation (18) and/or equation (25)). In other embodiments, other penalty terms/functions could be used. Such penalty functions may express a preference for directed edges being similar to the target directed edges determined in the local procedure.
    • In some embodiments, block 120 or block 320 target edge lengths may be selected to be current edge lengths. Such embodiments may involve the use of a non-linear solver.


While a number of exemplary aspects and embodiments have been discussed above, those of skill in the art will recognize certain modifications, permutations, additions and sub-combinations thereof. It is therefore intended that the following appended aspects or claims and aspects or claims hereafter introduced are interpreted to include all such modifications, permutations, additions and sub-combinations.

Claims
  • 1. A method, performed by a computer, for improving quality of a hex-mesh, the method comprising: obtaining an input hex-mesh;performing a first iterative procedure which starts with the input hex-mesh and which outputs an output hex-mesh having improved quality relative to the input hex-mesh;wherein performing the first iterative procedure comprises: initializing a current hex-mesh to be equal to the input hex mesh;for each iteration of the first iterative procedure: performing an optimization of an energy function over a plurality of directed-edges in the current hex-mesh to determine updated vertex positions for vertices in the current hex-mesh, wherein for each directed edge, the energy function comprises a term that expresses a preference for the directed edge to be aligned with normal vectors of base triangles of an edge-cone corresponding to the directed edge; andupdating the current hex-mesh with the updated vertex positions; andafter one or more iterations, setting the output hex-mesh to be equal to the current hex-mesh.
  • 2. A method according to claim 1 wherein, for each directed edge extending from a base vertex vi to an end vertex vj: the edge-cone corresponding to the directed edge comprises a plurality of tetrahedra surrounding the directed edge, each of the plurality of tetrahedra bounded by the directed edge and by a pair of distinct edges of a hexahedron in the current hex-mesh mesh, each of the pair of distinct edges emanating from the base vertex vi and not including the end vertex vj;the base triangles of the edge-cone corresponding to the directed edge comprise, for each tetrahedron of the plurality of tetrahedra, the triangular surface of the tetrahedron which includes the base vertex vi but does not include the end vertex vi.
  • 3. A method according to claim 1 wherein, for each directed edge, the term of the energy function that expresses the preference for the directed edge to be aligned with normal vectors of base triangles of the edge-cone corresponding to the directed edge has the form of
  • 4. A method according to claim 1 comprising, for each directed edge, at least one of: determining the normal vectors of the base triangles corresponding to the directed edge according to an equation having the form of equation (4) described above; andobtaining target edge lengths for the output hex-mesh and determining the normal vectors of the base triangles corresponding to the directed edge according to an equation having the form of equation (6) described above.
  • 5. A method according to claim 4 wherein obtaining target edge lengths for the output hex-mesh comprises one or more of: receiving the target edge lengths for the output hex-mesh; using the edge-lengths of the input hex-mesh as the target edge lengths for the output hex-mesh; and estimating the target edge lengths for the output hex-mesh.
  • 6. A method according to claim 5 wherein obtaining target edge lengths for the output hex-mesh comprises estimating the target edge lengths for the output hex-mesh and estimating the target edge lengths for the output hex-mesh comprises performing an edge-length optimization which optimizes an edge-length energy function over a plurality of edges in either the input hex-mesh or the current hex-mesh.
  • 7. A method according to claim 6 where the edge-length energy function has the form of equation (22) described herein.
  • 8. A method according to claim 1 wherein performing the optimization of the energy function comprises performing an iterative optimization and wherein, for each iteration of the iterative optimization, the energy function comprises, for each directed edge, a weighted penalty term which expresses a preference for the directed edge to be aligned with a target edge direction {circumflex over (n)}ij.
  • 9. A method according to claim 8 wherein, for each iteration of the iterative optimization, updating the weighted penalty term for each directed edge.
  • 10. A method according to claim 8 wherein performing the first iterative procedure comprises, for each iteration of the first iterative procedure and for each directed edge, determining the target edge direction {circumflex over (n)}ij.
  • 11. A method according to claim 10 wherein, for each directed edge, determining the target edge direction {circumflex over (n)}ij is based on characteristics of the current hex-mesh local to the edge-cone corresponding to the directed edge.
  • 12. A method according to claim 11 wherein, for each directed edge, the characteristics of the current hex-mesh local to the edge-cone corresponding to the directed edge are the normal vectors of the base triangles of the edge-cone corresponding to the directed edge and the positions of the vertices which define the directed edge.
  • 13. A method according to claim 10 wherein, for each directed edge, determining the target edge direction {circumflex over (n)}ij comprises performing a local optimization which optimizes a local energy function comprising a plurality of local terms, each local term expressing a preference for the target edge direction {circumflex over (n)}ij to be aligned with a normal vector of a corresponding one of the base triangles of the edge-cone corresponding to the directed edge.
  • 14. A method according to claim 10 wherein, for each directed edge, determining the target edge direction {circumflex over (n)}ij comprises: initially setting an initial target edge direction {circumflex over (n)}ij to correspond to the direction of an average of the normal vectors of the base triangles of the edge-cone corresponding to the directed edge;evaluating whether the initial target edge direction {circumflex over (n)}ij satisfies non-inversion constraints; andif the initial target edge direction {circumflex over (n)}ij satisfies non-inversion constraints, then determining the target edge direction {circumflex over (n)}ij to be the initial target edge direction {circumflex over (n)}ij and, otherwise, performing a local optimization which minimizes a local energy function which comprising a plurality of local terms, each local term expressing a preference for the target edge direction {circumflex over (n)}ij to be aligned with a normal vector of a corresponding one of the base triangles of the edge-cone corresponding to the directed edge.
  • 15. A method according to claim 10 wherein, for each iteration of the iterative optimization, the weighted penalty term is based on the target edge direction {circumflex over (n)}ij.
  • 16. A method according to claim 15 wherein, for each directed edge, the weighted penalty term comprises a penalty function Eijp which is optimized as part of the energy function and a penalty weight wijp that is updated between iterations of the second iterative optimization.
  • 17. A method according to claim 16 wherein, for each directed edge, the penalty function Eijp expresses the preference for the directed edge to be aligned with a target edge direction ñij.
  • 18. A method according to claim 15 wherein, for each directed edge, the weighted penalty term comprises a geometry factor W(αij) based at least in part on a largest angle αij between the target direction {circumflex over (n)}ij and the normal vectors of base triangles of the edge-cone corresponding to the directed edge.
  • 19. A method according to claim 8 wherein, for each iteration of the iterative optimization, the energy function comprises a parallel-edges regularization term Eregularize_parallel, which expresses a preference for directions of topologically parallel edges of the same hexahedron to be the same.
  • 20. A method according to claim 8 wherein, for each iteration of the iterative optimization, the energy function comprises a consecutive-edges regularization term Eregularize_consecutive, which expresses a preference for directions of topologically consecutive edges of face-adjacent hexahedra to be the same.
  • 21. A method according to claim 13 wherein, for each surface directed edge having both of its vertices on a surface boundary of the input mesh, performing the local optimization comprises optimizing a boundary-edge energy function which expresses a preference for the surface directed edge to remain on the surface boundary.
  • 22. A method according to claim 8 wherein the energy function comprises a boundary preservation term Eboundary which expresses a preference for vertices which are on a surface boundary of the input hex mesh to remain on the boundary surface.
  • 23. A method according to claim 13 wherein, for each directed edge, performing the location optimization comprises performing the local optimization with first non-inversion constraints until the current mesh is free from inverted hexahedra and then switching the first non-inversion constraints to first quality-improvement constraints which require improved quality relative to previous iterations of the local optimization.
  • 24. A method according to claim 18 comprising, for each iteration of the first iterative process, determining a worst angle w from among the largest angles αij across the plurality of edge-cones corresponding to the plurality of directed edges in the current mesh, and if w is less than 90°, changing the geometry factor W(αij) from a first geometry factor to a second geometry factor for subsequent iterations of the first iterative process, the second geometry factor different from the first geometry factor.
  • 25. A system for improving quality of a hex-mesh, the system comprising: one or more processors configured to:obtain an input hex-mesh;perform a first iterative procedure which starts with the input hex-mesh and which outputs an output hex-mesh having improved quality relative to the input hex-mesh;wherein the one or more processors are configured to perform the first iterative procedure by: initializing a current hex-mesh to be equal to the input hex mesh;for each iteration of the first iterative procedure:performing an optimization (e g minimization) of an energy function over a plurality of directed-edges in the current hex-mesh to determine updated vertex positions for vertices in the current hex-mesh, wherein for each directed edge, the energy function comprises a term that expresses a preference for the directed edge to be aligned with normal vectors of base triangles of an edge-cone corresponding to the directed edge; andupdating the current hex-mesh with the updated vertex positions; andafter one or more iterations, setting the output hex-mesh to be equal to the current hex-mesh.
REFERENCE TO RELATED APPLICATIONS

This application claims the benefit of the priority, and the benefit of 35 USC 119(e), of U.S. application Ser. No. 62/196894 which is hereby incorporated herein by reference.

Provisional Applications (1)
Number Date Country
62196894 Jul 2015 US