Apparatus and method for simplifying three-dimensional mesh data
An apparatus and method for simplifying 3-Dimensional (3D) mesh data are disclosed. The method includes measuring discrete curvature at each point of received 3D mesh data, calculating an error based on distance-curvature error metrics including the discrete curvature, first sorting a low curvature one of the calculated error values in a heap in ascending order, selecting a minimum error among the calculated errors, determining if the minimum error is less than a threshold, contracting an edge if the selected minimum error is greater than the threshold, and recalculating an error of a surface neighboring to a surface on which the contracted edge belongs and re-sorting the calculated error values.
Latest Samsung Electronics Patents:
- Ultrasound apparatus and method of displaying ultrasound images
- Display device and method of inspecting the same
- Wearable device including camera and method of controlling the same
- Organic light emitting diode display
- Organic electroluminescence device and compound for organic electroluminescence device
This application claims the benefit of the earlier filing date, under 35 U.S.C. §119(a), to that Korean Patent Application entitled “APPARATUS AND METHOD FOR SIMPLIFYING THREE-DIMENSIONAL MESH DATA” filed in the Korean Intellectual Property Office on Jan. 3, 2008 and assigned Serial No. 10-2008-0000558, the contents of which are herein incorporated by reference.
BACKGROUND OF THE INVENTION1. Field of the Invention
The present invention relates to 3-Dimensional (3D) mesh data imaging and, more particularly, to an apparatus and method for extending a Quadric Error Metrics (QEM) algorithm by discrete curvature for simplifying 3D mesh data.
2. Description of the Related Art
With the recent progress of advanced automation and development into information society, applications of computer graphic have increased rapidly, e.g., animation, simulation, etc. Amid this, the recent introduction of 3-Dimensional (3D) graphic techniques into electronic equipments leads to paying attention to the development of a high speed graphic processing technology for processing large numbers of polygons and efficiently processing special effects, such as lighting effects, in order to configure a little more realistic graphic.
Mesh simplification is a technique to retain the original desired shape and feature of a 3D model while reducing the number of polygons necessary to render the shape and features. That is, mesh simplification refers a process of removing polygons having topological and geometrical information more than needed from an initial model, thus simplifying the initial model. A technology for simplifying such a 3D model has been utilized in many fields such as a Level of Detail (LOD) control technology of a computer animation and 3D game, a 3D graphic solution of the Internet, a real-time 3D graphic simulation, etc.
A goal of mesh simplification is to provide good approximation to retain geometrical information on the original model and a phase with less vertex and face. An advantage of mesh simplification is to reduce the amount of storage space required for rendering a large size model, reduce a data-structure building time, and visualize a model at high speed.
A conventional simplification algorithm can give rise to a change of a volume of the original mesh model during the simplification process. Performance of the mesh simplification algorithm depends on an execution time for simplifying the original mesh model and a quality of approximation of the simplified model. Thus, a volume of a simplified mesh model has been considered using a distance based QEM algorithm of several simplification algorithms that uses the sum of squares of distances from one point on a plane providing relatively good performance.
The QEM algorithm is an algorithm for simplifying a mesh model using iterative edge contraction in which a method of selecting an edge to contract is of importance. The QEM algorithm determines a vertex whose distance error is minimal at each edge as a position of a new vertex after edge contraction, using a cost function of prioritizing an edge to contract (i.e., so-called QEM), first selects an edge at which the vertex has the least distance error among edges, and contracts the selected edge.
However, the QEM algorithm performs quick and high quality simplification, but there is a problem that it cannot keep a feature of the original 3D model when completing a simplification step of simplifying the original 3D model.
SUMMARY OF THE INVENTIONAccording to one aspect of the present invention, a method for simplifying 3-Dimensional (3D) mesh data in an electronic equipment is provided. The method includes measuring discrete curvature at each point in said 3D mesh data, calculating an error based on distance-curvature error metrics comprising the discrete curvature measured at each point, selecting a minimum error among the calculated errors, contracting a corresponding edge of said 3D when the minimum error is more than the threshold to obtain a simplified version of said edge, recalculating an error of a surface neighboring to a surface on which the contracted edge belongs, and re-sorting said calculated error values.
According to another aspect of the present invention, an apparatus for simplifying 3-Dimensional (3D) mesh data is provided. The apparatus includes a controller and a graphic engine. The controller controls a function of measuring discrete curvature at each point, calculating an error based on distance-curvature error metrics including the measured discrete curvature, first sorting a low curvature one of the calculated error values of respective points in ascending order, determining if a minimum error among the calculated errors is less than a threshold, contracting an edge if the minimum error is more than the threshold, recalculating an error of a surface neighboring to a surface on which the edge contracts, and re-sorting the calculated errors. The graphic engine performs simplification by contracting an edge of the 3D mesh data under control of the controller.
The above features and advantages of the present invention will become more apparent from the following detailed description when taken in conjunction with the accompanying drawings in which:
Exemplary embodiments of the present invention will be described herein below with reference to the accompanying drawings. In the following description, well-known functions or constructions are not described in detail as they would obscure the invention in unnecessary detail.
In this case, the apparatus refers to a plurality of equipments for processing graphic such as a portable terminal, a personal computer, a mobile communication terminal, etc. or may represent one component or equipment among the plurality of the graphic processing equipments.
Referring to
The controller 100 controls a general operation of the apparatus and in addition to a general function, controls and processes a function of receiving 3D mesh data, measuring discrete curvature, measuring an error based on distance and curvature, first sorting and simplifying a middle point having less error, and providing an output to the display unit 106 according to an exemplary embodiment of the present invention.
Under control of the controller 100, the graphic engine 102 measures discrete curvature of the received 3D mesh data, measures an error based on distance and curvature, first sorts and simplifies a point having less error, and provides an output to the controller 100. The graphic engine 102 also directly outputs simplified 3D mesh data to the display unit 106.
The memory 104 stores a program for controlling a general operation of the electronic equipment, temporary data generated during an operation of the electronic equipment, a system parameter, and other depository data. In particular, the memory 104 stores a program for simplifying 3D mesh data. Memory 104 may be composed of well-known memory types such a PROM, RAM, and/or Flash.
The display unit 106 displays state information generated during an operation of the apparatus, and limited number of numerals and characters. The display unit 128 outputs a simplification model whose feature is preserved according to an exemplary embodiment of the present invention.
The input unit 108 includes keys for receiving numeral or character information and function keys for setting various kinds of functions, and outputs functions corresponding to the keys pressed by a user to the controller 100.
Referring to
Then, in step 205, an error is calculated based on distance-curvature error metrics and then, in step 207, a sort of the calculated errors.
Then, in step 208, a minimum error is selected from among the errors and then, in step 209, a determination is made whether the minimum error is less than a threshold value. If the minimum error is less than the threshold, in step 213, an edge of a vertex is contracted and in step 215, an error of a surface neighboring to a surface on which the edge contracts, is recalculated the calculated errors are resorted. Then, processing returns to step 209 and again performs the processing steps illustrated.
If the minimum error is less than the threshold value, then in step 211, the simplified data is outputted and processing is terminated according to the illustrated exemplary embodiment of the present invention.
With regard to the error calculation, a distance from one point on a plane of a triangular mesh is measured and the measured distance is used as an error, and is given in Equation 1 as:
d(
wherein d(
Discrete curvature for the vertex
An error obtained using the discrete curvature is substituted for ci in Equation 1. By the thus measured numerical value, a distance error (i.e., QEM) is extended into distance-curvature error metrics including discrete curvature(s). The distance-curvature error metrics change a sequence (order) of a heap to simplify a high curvature part last and simplify a low curvature part (i.e., a flat part) first by changing a sequence of the computed errors. For example, an error is measured by measuring discrete curvatures at vertexes (v1) and (v2) in Equation 2 and substituting the thus measured values in Equation 3.
The error obtained from Equations 2 and 3 is put in a heap for simplification and, among error values, an error value of a high curvature part moves to a rear part of the heap. By doing so, simplification is, although much, done with a feature of the original 3D mesh data that is preserved.
Referring to
Referring to
The above-described methods according to the present invention can be realized in hardware or as software or computer code that can be stored in a recording medium such as a CD ROM, an RAM, a floppy disk, a hard disk, or a magneto-optical disk or downloaded over a network, so that the methods described herein can be rendered in such software using a general purpose computer, or a special processor or in programmable or dedicated hardware, such as an ASIC or FPGA. As would be understood in the art, the computer, the processor or the programmable hardware include memory components, e.g., RAM, ROM, Flash, etc. that may store or receive software or computer code that when accessed and executed by the computer, processor or hardware implement the processing methods described herein.
As described above, an exemplary embodiment of the present invention has an effect of, upon simplification of 3D mesh data, being able to first simplify a specific part of the 3D mesh data model and thus increase the accuracy of a contour and a shape of the simplified model, by extending a QEM algorithm by discrete curvature and simplify a high discrete curvature part last.
While the invention has been shown and described with reference to certain preferred embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the spirit and scope of the invention as defined by the appended claims.
Claims
1. A method, operable in processor system, for simplifying 3-Dimensional (3D) mesh data of a mesh by reducing a number of triangles of the mesh, the method comprising:
- (a) measuring discrete curvature at each point in said 3D mesh data;
- (b) calculating errors based on distance-curvature error metrics comprising the discrete curvature measured at each point, and sorting the calculated errors in a heap, with errors of relatively high curvature parts of the mesh placed in a rear part of the heap;
- (c) selecting a minimum error among the calculated errors;
- (d) contracting an edge of said 3D mesh data corresponding to the minimum error when the minimum error is less than a threshold to obtain a simplified version of said mesh with the number of triangles of an entire mesh area reduced;
- (e) recalculating an error of a surface neighboring a surface to which the contracted edge belongs;
- (f) re-sorting said calculated errors in the heap; and
- repeating steps (c) through (f) until the minimum error is not less than the threshold, whereby simplification of the relative high curvature parts of the mesh is done last.
2. The method of claim 1, further comprising, if the selected minimum error is not less than the threshold, outputting said simplified 3D data.
3. The method of claim 1, wherein the discrete curvature is at least one of an average curvature, a Gaussian curvature, and a principal curvature.
4. The method of claim 1, wherein the threshold is a user input value.
5. An apparatus for simplifying 3-Dimensional (3D) mesh data of a mesh by reducing a number of triangles of the mesh, the apparatus comprising:
- a controller for controlling a function of:
- (a) measuring discrete curvature at each point,
- (b) calculating errors based on distance-curvature error metrics comprising the measured discrete curvature, and sorting the calculated errors in a heap, with errors of relatively high curvature parts of the mesh placed in a rear part of the heap,
- (c) selecting a minimum error among the calculated errors,
- (d) contracting an edge if the minimum error is less than a threshold to obtain a simplified representation of said mesh with the number of triangles of an entire mesh area reduced,
- (e) recalculating an error of a surface neighboring a surface on which the edge contracts,
- (f) re-sorting said errors in the heap; and
- repeating steps (c) through (f) until the minimum error is not less than the threshold, whereby simplification of the relative high curvature parts of the mesh is done last; and
- a graphic engine for displaying said simplified 3D mesh data.
6. The apparatus of claim 5, wherein the controller controls a function of providing the simplified data to said graphic engine when the selected minimum error is not less than the threshold.
7. The apparatus of claim 5, wherein the discrete curvature is at least one of an average curvature, a Gaussian curvature, and a principal curvature.
8. The apparatus of claim 5, wherein the threshold is a user input value.
9. The method of claim 1, wherein the processor system is at least one of a plurality of equipments selected from the group consisting of: a portable terminal, a mobile communication terminal, and a personal computer.
10. The apparatus of claim 5, wherein the apparatus is at least one of a plurality of equipments selected from the group consisting of: a portable terminal, a mobile communication terminal, and a personal computer.
11. The method of claim 1, wherein the error based on the distance-curvature error metrics comprising the discrete curvature measured at each point is calculated as:
- d( v,pi)=ni· v+ci (4)
- where,
- d( v,pi): distance from new vertex v=( vx, vy, vz) on plane (pi),
- n=(nix, niy, niz): vector of plane (pi), and
- ci: distance-curvature error comprising discrete curvature.
12. The method of claim 11, wherein the distance-curvature error comprising the discrete curvature is calculated as: H 1, 2 = ∑ j = 0 n { ( ( v j - 1 - v 1, 2 ) × ( v j - v 1, 2 ) ) · ( ( v j + 1 - v 1, 2 ) × ( v j - v 1, 2 ) ) } ∑ i = 0 n ( v j - v 1, 2 ) × ( v j + 1 - v 1, 2 ) ( 5 )
- where, v: vertex.
13. The apparatus of claim 5, wherein the error based on the distance-curvature error metrics comprising the discrete curvature measured at each point is calculated as:
- d( v,pi)=ni· v+ci (6)
- where,
- d( v,pi) distance from new vertex v=( vx, vy, vz) on plane (pi),
- n=(nix, niy, niz): vector of plane (pi), and
- ci: distance-curvature error comprising discrete curvature.
14. The apparatus of claim 13, wherein the distance-curvature error comprising the discrete curvature is calculated as: H 1, 2 = ∑ j = 0 n { ( ( v j - 1 - v 1, 2 ) × ( v j - v 1, 2 ) ) · ( ( v j + 1 - v 1, 2 ) × ( v j - v 1, 2 ) ) } ∑ i = 0 n ( v j - v 1, 2 ) × ( v j + 1 - v 1, 2 ) ( 7 )
- where, v: vertex.
15. A computer readable, non-transitory recording medium for simplifying 3-Dimensional (3D) mesh data of a mesh by reducing a number of triangles of the mesh, the recording medium including code which when accessed and executed by a processor causes the processor to:
- (a) measure discrete curvature at each point in said 3D mesh data;
- (b) calculate errors based on distance-curvature error metrics comprising the discrete curvature measured at each point, and sorting the calculated errors in a heap, with errors of relatively high curvature parts of the mesh placed in a rear part of the heap;
- (c) select a minimum error among the calculated errors;
- (d) contract an edge of said 3D mesh data corresponding to the minimum error when the minimum error is less than a threshold to obtain a simplified version of said mesh with the number of triangles of an entire mesh area reduced;
- (e) recalculate an error of a surface neighboring a surface to which the contracted edge belongs;
- (f) re-sort said calculated errors in the heap; and
- repeat steps (c) through (f) until the minimum error is not less than the threshold, whereby simplification of the relative high curvature parts of the mesh is done last.
16. The recording medium of claim 15, wherein said processor further outputs said simplified 3D data, when said selected minimum error is not less than the threshold.
17. The recording medium of claim 15, wherein the discrete curvature is at least one of an average curvature, a Gaussian curvature, and a principal curvature.
18. The recording medium of claim 15, wherein the threshold is a user input value.
19. The recording medium of claim 15, wherein the error based on the distance-curvature error metrics comprising the discrete curvature measured at each point is calculated as:
- d( v, p hd i)=ni· v+ci (4)
- where,
- d( v,pi) distance from new vertex v=( vx, vy, vz) on plane (pi),
- n=(nix, niy, niz): vector of plane (pi), and
- ci: distance-curvature error comprising discrete curvature.
20. The recording medium of claim 19, wherein the distance-curvature error comprising the discrete curvature is calculated as: H 1, 2 = ∑ j = 0 n { ( ( v j - 1 - v 1, 2 ) × ( v j - v 1, 2 ) ) · ( ( v j + 1 - v 1, 2 ) × ( v j - v 1, 2 ) ) } ∑ i = 0 n ( v j - v 1, 2 ) × ( v j + 1 - v 1, 2 ) ( 5 )
- where, v: vertex.
6208347 | March 27, 2001 | Migdal et al. |
7298903 | November 20, 2007 | Wang et al. |
20050168460 | August 4, 2005 | Razdan et al. |
20080129727 | June 5, 2008 | Oh et al. |
20080205717 | August 28, 2008 | Reeves et al. |
Type: Grant
Filed: Jan 5, 2009
Date of Patent: Aug 7, 2012
Patent Publication Number: 20090174711
Assignee: Samsung Electronics Co., Ltd. (Samsung-ro, Yeongtong-gu, Suwon-si, Gyeonggi-do)
Inventors: Suh-Ho Lee (Seongnam-si), Soo-Kyun Kim (Seoul), Joo-Kwang Kim (Yongin-si), Tae-Kyun Kim (Seongnam-si)
Primary Examiner: Hau Nguyen
Assistant Examiner: Leon T Cain, II
Attorney: Cha & Reiter, LLC
Application Number: 12/348,355
International Classification: G06T 17/00 (20060101); G06T 15/00 (20060101); G09G 5/00 (20060101);