This application is related to a patent application of Markus Kaufmann et al., filed on the same date as this application, entitled Method for Creating Single 3D Surface Model from A Point Cloud, Ser. No. 10/626,795, the entire contents of which are incorporated by reference herein.
A. Field of the Invention
This invention is directed to an interactive workstation and associated computerized techniques for facilitating detection of individual teeth boundaries and gingival boundaries from a three-dimensional virtual computer model of teeth: The identification and separation of the teeth from the gingival tissue has applications in digital dentistry and orthodontics. For example, the separation of the teeth from the gingiva is typically a preliminary step in planning of treatment for orthodontic patients on a computer.
B. Description of Related Art
The traditional process of diagnosis and treatment planning for a patient with orthodontic problems or disease typically consists of the practitioner obtaining clinical history, medical history, dental history, and orthodontic history of the patient supplemented by 2D photographs, 2D radiographic images, CT scans, 2D and 3D scanned images, ultrasonic scanned images, and in general non-invasive and sometimes invasive images, plus video, audio, and a variety of communication records. Additionally, physical models, such as made from plaster of Paris, of the patient's teeth are created from the impressions taken of the patient's upper and lower jaws. Such models are manually converted into teeth drawings by projecting teeth on drawing paper. Thus, there is a large volume of images and data involved in the diagnosis and treatment planning process. Furthermore, the information may require conversion from one form to another and selective reduction before it could become useful. There are some computerized tools available to aid the practitioner in these data conversion and reduction steps, for example to convert cephalometric x-rays (i.e., 2 dimensional x-ray photographs showing a lateral view of the head and jaws, including teeth) into points of interest with respect to soft tissue, hard tissue, etc., but they are limited in their functionalities and scope. Even then, there is a fairly substantial amount of manual work involved in these steps.
Additionally, the physical molds of the patient's dentition are converted into physical models such that each tooth can be moved and repositioned individually. However, such models allow free movement of teeth without regard to the patient's biological constraints, and can frequently lead to impractical treatment set-ups.
Furthermore, a number of measurements, e.g., available space between teeth, are also often done manually. Generally, these steps are time consuming and prone to inherent inaccuracies. Furthermore, the practitioner has to contend with the biological interdependencies within the patient, which introduces constraints eliminating certain treatment options that would otherwise be acceptable, between the soft tissue, the hard tissue, and the teeth. There is lack of an integrated platform which a practitioner could utilize to filter-out non-practicable treatment options.
Consequently, the practitioner is left to mental visualization, chance process to select the treatment course that would supposedly work. Furthermore, the diagnosis process is some-what ad-hoc and the effectiveness of the treatment depends heavily upon the practitioner's level of experience. Often, due to the complexities of the detailed steps and the time consuming nature of them, some practitioners take a short cut, relying predominantly on their intuition to select a treatment plan. For example, the diagnosis and treatment planning is often done by the practitioner on a sheet of acetate over the X-rays. All of these factors frequently contribute towards trial and error, hit-and-miss, lengthy and inefficient treatment plans that require numerous mid-course adjustments. While at the beginning of treatment things generally run well as all teeth start to move at least into the right direction, at the end of treatment a lot of time is lost by adaptations and corrections required due to the fact that the end result has not been properly planned at any point of time. By and large, this approach lacks reliability, reproducibility and precision. More over, there is no comprehensive way available to a practitioner to stage and simulate the treatment process in advance of the actual implementation to avoid the often hidden pitfalls. And the patient has no choice and does not know that treatment time could be significantly reduced if proper planning was done.
In recent years, computer-based approaches have been proposed for separating teeth in patient's 3D dentition model. A 3D scanned model of a patient's dentition, whether taken in-vivo or from a physical model, typically covers the surfaces of all teeth and parts of the surrounding gum, but there can also be gaps in it, i.e. parts of teeth and gum the 3D scan did not reach. Given this data, the present invention is directed to a procedure to analyze the data and to determine which portions of the scanned data correspond to the gums and which portions correspond to the individual. Thus, both the transitions between the teeth and the gums and those between adjoining teeth are detected, and the portions between these transitions are correctly assigned to the corresponding portions of the scanned jaw.
Cheang et al., U.S. Pat. No. 6,371,761, describe a method using flexible plane for separating teeth wherein a computer-implemented method separates first and second portions of a tooth by defining a cutting surface intersecting the first and second portions; and applying the cutting surface to the to the tooth to separate the tooth into two portions. Pavlovskaia, et al, U.S. Pat. No. 6,386,878, and U.S. Patent Application Publication 2002/0177108 describe a method using cutting surface for removing gingival tissue from teeth wherein a computer-implemented method removes gingival from a model of a tooth by defining a cutting surface along the gingiva; and applying the cutting surface to the to the tooth to separate the gingival from the in a single cut. Jones et al., U.S. Pat. No. 6,409,504, and in related U.S. Patent Application Publication 2003/0039389, and U.S. Patent Application Publication 2002/0102009, describe a method for manipulating a digital dentition model to form models of individual dentition components wherein computer-automated techniques are described using “voxel representation” and “geometric representation” of a 3D model. Pavlovskaia, et al, U.S. Pat. No. 6,463,344, describe a computer-implemented method that generates a computer model of one or more teeth, by receiving as input a digital data set of meshes representing the teeth; creating a parametric representation of the digital data set; and displaying the computer model of the teeth using the parametric representation. Chisti et al, U.S. Published Patent Application 2003/0039941, describe digitally modeling the deformation of gingival tissue during orthodontic treatment.
In recent years, computer-based approaches have been proposed for aiding orthodontists in their practice. However, these approaches are limited to diagnosis and treatment planning of craniofacial structures, including the straightening of teeth. See Andreiko, U.S. Pat. No. 6,015,289; Snow, U.S. Pat. No. 6,068,482; Kopelmann et al., U.S. Pat. No. 6,099,314; Doyle, et al., U.S. Pat. No. 5,879,158; Wu et al., U.S. Pat. No. 5,338,198, and Chisti et al., U.S. Pat. Nos. 5,975,893 and 6,227,850, the contents of each of which is incorporated by reference herein.
A method for generation of a 3D model of the dentition from an in-vivo scan of the patient, and interactive computer-based treatment planning for orthodontic patients, is described in published PCT patent application of OraMetrix, Inc., the assignee of this invention, publication no. WO 01/80761, the contents of which are incorporated by reference herein. The PCT application, at pages 73 and 75, describes several methods for separating teeth from a virtual model, using user interaction and virtual tooth models. The application suggests that tooth separation could be done using an automated algorithm looking for grooves between tooth crowns and gingival tissue, but does not describe what that algorithm might be or describe how the process would work.
Other background references related to capturing three dimensional models of dentition and associated craniofacial structures include S. M. Yamany and A. A. Farag, “A System for Human Jaw Modeling Using Intra-Oral Images” in Proc. IEEE Eng. Med. Biol. Soc. (EMBS) Conf., Vol. 20, Hong Kong, October 1998, pp. 563–566; and M. Yamany, A. A. Farag, David Tasman, A. G. Farman, “A 3-D Reconstruction System for the Human Jaw Using a Sequence of Optical Images,” IEEE Transactions on Medical Imaging, Vol. 19, No. 5, May 2000, pp. 538–547. The contents of these references are incorporated by reference herein.
A method is provided for automatically identifying or determining tooth crowns in a virtual three-dimensional model of teeth and associated anatomical structures (e.g., gingival tissue) in a dental arch. Separation of such teeth into independent virtual objects is useful for a variety of purposes, including moving the virtual tooth objects relative to each other to simulate treatment of a patient, such as simulate orthodontic treatment.
The method includes the step of storing the model in a memory accessible to a general-purpose computer. The computer including a processing unit. The method includes the step of providing machine-readable instructions for execution by the processing unit. The instructions operate on the model in the following respects:
1) orientating the model with reference to a plane;
2) automatically determining local maxima of the model and areas bounded by the local maxima;
3) automatically determining saddle points between the local maxima in the model, the saddle points corresponding to boundaries between teeth;
4) determining the position of the saddle points along a dental archform, and
5) for each tooth, automatically identifying a line or path linking the saddle points to each other, the lines marking a transition between teeth and gingival tissue and between adjacent teeth in the model, and identifying areas bounded by the lines and in the direction of the plane as corresponding to the tooth crowns.
Since the process for detection of crowns identifies lines defining the transition between the teeth and gingival tissue, the identification of the teeth necessarily results in identification of the gingival tissue as well. In particular, the gingival tissue will ordinarily comprise the portion of the model in the areas bounded by the lines and in the direction away from the plane.
In yet another aspect of the invention, it will also be appreciated that we have described a ravine detection invention that provides instructions for execution by a programmed computer that identifies a path interconnecting saddle points between virtual teeth in a virtual model of the dentition. The path comprises a transition between teeth and gingival tissue and between adjacent teeth in a virtual model of dentition. In a preferred embodiment, as explained in
The scanner 10 obtains scan data describing the surface configuration and shape of the dentition 16. The scanner electronics module 14 includes a programmed computer that converts data from the probe 12 into a point cloud, each point in the cloud having three-dimensional coordinates corresponding to a point on the surface of the object. The above-cited PCT application contains a description of a method of generating point cloud data, in a form of a series of individual three-dimensional “frames”, which are in turn registered to each other in a best fit manner to form a complete 3D point cloud model of the object. The reader is directed to the PCT document for a description of the generation of the point cloud. The scan data is transmitted to a general-purpose computer 18, which includes a central processing unit 20, a hard disk memory 21, and a user interface consisting of a monitor or display 22, a mouse 24, and keyboard 26. The scan data (point cloud) is stored in the hard disk memory 21 of the computer. The computer also includes machine executable instructions, described herein, for processing the points in the point cloud and generating a single mesh surface configuration representing a three-dimensional virtual model of the dentition and gingival tissue. The virtual model comprising the single mesh surface of the dentition is shown displayed on the computer monitor 22, as indicated at 28. The mouse and keyboard provide a means by which the user accesses the 3D surface generation software and initiates the processing, and then manipulate, study, measure, or otherwise use the resulting 3D surface.
As noted above, a method is described herein for automatically identifying tooth crowns in a virtual three-dimensional model 28 of teeth in a dental arch. The method includes a step of storing the model in a memory accessible to a general-purpose computer, such as the hard disk memory 21 of
As noted above, the method of the present invention is capable of executing in a fully automated manner, with no user involvement. Depending on the quality of the scan data, the method may benefit from some user involvement, as will be described below. The method will be described more particularly in conjunction with
The initial step in the process, orienting the model with respect to a plane, can be done with either the initial point cloud or a representation of the point cloud as a single continuous surface or mesh. The remaining operations are ideally performed on a single continuous mesh surface. Hence, a processing step is performed of converting the point cloud model to a single surface representation. The process of converting a point cloud to a single mesh surface will be described initially in conjunction with
Conversion of Point Cloud to Single Mesh Surface
The object of the procedure is to generate from this cloud of points a new boundary or surface representation consisting of points and triangles which, as far as possible, consists exactly of one layer on every area of the surface of the scanned object. This is indicated in
In general, the vertices of the triangles 32 forming the single mesh surface are not points in the point cloud, but rather they are newly-constructed vertices formed as a weighted average of a set of nearby points that satisfy selection criteria; moreover, the vertices of the triangles are tested against rejection criteria described herein in order to insure that the triangle surface conforms to the point cloud with a minimum of deviation. The manner of selecting the set of points used to construct the new vertices of the triangles 32 and testing the new vertex to see if it should be used are explained in detail in conjunction with
Referring now to
The method includes the step of storing the cloud of points in a memory (e.g., hard disk 21) of a computer 18. The method further includes the step of providing machine-executable instructions for the computer that operate on the cloud of points 30. The instructions construct an initial triangle from the cloud of points. This will be described in conjunction with
The method continues with constructing a multitude of adjacent triangles forming a single continuous surface representing the object. Preferred methods will be described in more detail below in conjunction with
Referring now in particular to
The process starts by selecting a first point 40. The first point may be any randomly selected point in the point cloud, the first point (index=1), the last point (index=n, where n is the number of points in the point cloud), or otherwise. The method continues by selecting a second point 42, which may also be a point in the point cloud. The point 42 could be selected in a variety of possible methods, such as any point in the point cloud that has a distance from the first point 40 that does not exceed a specified threshold; a point having the closest index number to the index number of the first point, or the point could be constructed from averaging X, Y and Z values from set of points in the vicinity of the first point 40. (The first point could similarly be selected).
After the first two points are selected, an edge 44 is constructed joining points 40 and 42. The task is now to select a third point forming the third vertex of the first triangle. In a preferred embodiment, a third point 46 is selected as a weighted average of points in a region that is a certain distance way from the edge 44, not too close, not too far (the distance criterion could also use the first and second points instead of the edge). The aim here in selection of the third point (or, more generally, any new point forming a vertex of a triangle in the surface after creation of the initial triangle) is to continue as homogeneously as possible the existing surface structure (the single mesh that has already been generated) and ensure that the deviation between the surface generated with the new point and the source data points is kept to a minimum. The minimization of the deviation is achieved by using a weighted mean of all source data points to select the third point 46. Here, a weighted mean of all source data points is formed for this purpose, which do not exceed a certain maximum distance from the edge 44 and which are not located in certain exclusion areas. These exclusion areas comprise all areas located “behind” the edge (to the left of the edge 44) or behind the neighboring edges—and hence within one of the triangles referencing one of the points of the edge. The points are weighted such that those points that contribute to the formation of a triangle whose sides are as equal as possible are assigned the greatest relative weight. But if the mean variation of the normals of the source data points involved (measure of surface curvature) or the angle of the triangle formed with the aid of the new point with the other triangle of the open edge exceeds a threshold value, then the point is rejected, because excessive deviation of the new triangle from the source data points is to be expected. In this case the formation of the mean value is repeated, the weights being changed in favor of a smaller triangle. If the procedure is successful, a new triangle which references the two points of the open edge and the new point is formed and the list of the open edges is updated accordingly. The process of selecting the initial third point and all the new vertices forming the single continuous surface will be explained further in conjunction with
This can be seen in the example of
The process proceeds by selecting another open edge, for example edge 50, and constructing a new triangle formed by the edge 50 and another point derived from the point cloud. The area within triangle 1 is in an exclusion area, so the algorithm seeks points in the “front of the edge”, or to the upper right of triangle 1 in
The process of selecting new points and triangles continues as shown in
Thus, in a preferred embodiment, the process includes instructions for forming triangles from either the point cloud or previously identified vertices in the surface. The algorithm generally generates, in succession, either:
As indicated by the voids in the point clouds in
The preferred embodiment includes rules for generating triangles without generating a new point, i.e., from existing vertices of triangles already created. In a first possible rule, new triangles could be created when two adjacent open edges together form acute angle. A triangle can be formed in this case, which is situated between these two edges, i.e., which references the 3 points of the two edges. In a refinement of this rule, this triangle is formed only if the mean distance between the source data points located above (or below) this triangle and the triangle area does not exceed a certain threshold.
As a second possibility, a triangle can be created when point of another open edge lies near the open edge (and in front of it). This is the example of creating triangle 8 in
As a third possible example, triangles are constructed to fill holes, that is when three open edges together limit a triangular hole. The hole is closed by a triangle which references the three vertices of these three edges.
Referring now to
As noted earlier, the process of constructing a single mesh surface can be used for any type of object. The present inventors are currently concerned with the particular problem of generating a surface model of the dentition of human patients. Such models are useful in planning orthodontic treatment using a computer, among other things.
The surface model may include holes or gaps in scan data, indicated at 134 in
At the first step 202, a check is made to see if there are vertices or points that have not been tested for formation of a triangle. At the beginning of the procedure, the answer of course is yes, so the process proceeds to step 204. At step 204, the process needs to generate two starting points which creates the initial open edge. This was described above in conjunction with
In the case of the first open edge, of course block 208 will be answered in the negative, so the process reverts to block 216. Here, a test is made to see if the open edge selected at block 206 and tested at block 216 is adjacent to another open edge (share a common vertex) and if the angle between the edges is an acute angle. If so, the processing reverts to block 218 and a triangle is formed between these two edges (see
Again, in the case of the initial or first open edge, block 220 will be answered in the negative, and so the process reverts to block 224. Here, a test is made to see if there are points in the point cloud to generate a new vertex. The block 224 is described below in conjunction with
As is shown in
If, at module 214, there are no untested open edges remaining, the process reverts to step 202 to see if there are points in the point cloud that have not been tested. If there are points in the points list that have not been tested, a new starting edge is selected in a new part of the point cloud (as indicated at step 204) and the processing of
The module 224 of
Referring now in particular to
Let P1, P2 be the vertices of the open edge, {right arrow over (n)} the normal-vector of the existing triangle adjacent to the edge P1, P2. Then let
e=∥P2−P1∥, the length of the open edge.
C is expressed as follows:
C={P|∥P−P1∥<2e^∥P−P2∥<2e^(P2−P1)×(P−P1)>0}, which is the set of all points,
which are not too far away from the two vertices of the open edge, and do not lie ‘behind’ the open edge. Then the new vertex V will be given formula W:
with the weights
wP,P
These weights are >0 for every PεC and have their maximum along the half-circle of points, which form equilateral triangles with P1 and P2. The weighting of points and selection of points in set C insures that the mesh tends to be quite regular.
Referring again to block 230 of
If there are points in the point cloud in the set C, the process proceeds to step 234 and the calculation of the new vertex using the formula W above.
At step 236, the new vertex is tested against rejection criteria for a new vertex. There are two criteria that are used in the preferred embodiment, however it is possible to just use the second criterion alone:
1: The variation of the surface normals of the source data points in the set C used to construct the vertex must be less than a threshold value; and
2. The angle between the surface normals of the adjacent triangle and the new triangle must be less than a threshold value.
The first criterion will be explained in conjunction with
The second criteria in
From the above description, and with reference to the previous Figures, it will be appreciated that we have described a method for creating a surface representation of a three-dimensional object. The method includes the step of scanning the object with a scanner and storing scan data in a memory of a computer, as shown in
In still another aspect, a method has been described for creating a surface representation of a three-dimensional object from a cloud of points, each point having three-dimensional spatial coordinates. The method comprises the steps of storing the cloud of points in a memory of a computer and storing, in the memory of the computer, a list of points comprising the cloud of points and a list of open edges. The method further comprises the step of providing machine executable instructions for the computer that operate on the cloud of points, the instructions:
1) constructing an initial open edge from points in the cloud of points (
2) constructing a triangle forming a portion of the surface representation from the open edge using predetermined rules for generating triangles forming the surface representation (
3) adjusting the list of open edges in view of the construction of the triangle (step 212,
4) checking to see if there are open edges that have not been tried yet to form a triangle forming a portion of the surface representation, and if so, repeating steps 2) and 3) (step 214,
5) as steps 2), 3) and 4) execute, adjusting the list of points by marking the points in the list of points that are used to generate vertices of triangles in step 2) and not using them further in the modeling procedure (indicated by the voids in the clouds of points in
6) repeatedly iterating steps 2), 3), 4) and 5) until the instructions have attempted to generate triangles from all open edges in accordance with the predetermined rules for generating triangles (rules 208, 216, 220 of
It will also be appreciated that we have described a method for constructing a three-dimensional model of an anatomical structure (such as teeth or any other anatomical structure), comprising the steps of:
scanning the anatomical structure with a scanner and obtaining scan data (see
converting the scan data to a cloud of points (described in the prior PCT application of OraMetrix or generally known in the art of 3D scanners);
storing the cloud of points in a memory of a computer (
executing machine executable instructions in the computer, the instructions operating on the cloud of points to construct an initial triangle (
Crown Detection Process
Referring now to
At step 302, the procedure is started. The first step shown in
The process continues with a step 308 of finding the local maxima in the model and the areas defined by the local maxima, “catchment areas” as defined herein. This procedure is illustrated in
The processing continues with a step 310 of determining the location of saddle points in the virtual model and a step 312 of determining the position of the saddle points along a dental arch form, which makes use in one embodiment of a parabolic coordinate transform. The order in which steps 310 and 312 execute are interchangeable, as will be understood from the following description. The processing continues with a step 314 of performing an automatic area search. This procedure is shown in
Pre-Positioning Model (Step 304) (
The aim of this procedure 304 is to perform a transformation TV which spatially positions the cloud of points (or single mesh surface or other form in which the data is represented) in such a manner that the plane of occlusion approximately corresponds to the plane of the x-y coordinates, the “center of gravity” of the of the arch is near the z coordinate axis and the opening of the palatomaxillary arch is pointing in the direction of the positive y coordinate.
In the event that the procedure 304 executes on a cloud of points, the procedure can be sped up by only using a subset of the cloud of points, e.g., only every 10th point. This positioning algorithm is quite robust, so it does not matter whether one uses the original point cloud or the single mesh surface. If one uses the original point cloud, and only a subset of points is used, the choice of points has no influence on later steps in the process 300. The algorithm can handle any number of points, from a single mesh with some 10 thousand points to a very dense scan with several million points. In the event that the point cloud is used, a numerical index assigned to each point is used for the point selection, i.e., for the subset of points to use. All the points in the point cloud are consecutively numbered, and the method uses every point with an index divisible by 10, for example.
In a first step 320 in process 304, a first approximation of an up vector and center point is made. The up vector is the mean of the normals of all vertices, which gives a rough approximation of the up vector (the vector that is transformed into the positive z coordinate by TV). The mean of all X, Y, Z coordinates of all points in the model forms the first rough approximation of the center point C (“center of gravity” of the arch).
Thus, the center point C and the up vector can be represented by the equations:
Center point:
where Pi are the data points.
Up vector:
where ni are the surface-normal-vectors of the data-points The process continues with determining a plane in which the arch is oriented to. It is not necessary to arrive at a specific plane. In the present example, an approximation of a plane of occlusion EO is determined. Reference is made to
Equations used to find T0, T1 are as follows.
T0=Pm, with ∀i≠m: Pi·{right arrow over (u)}≦Pm·{right arrow over (u)}
T1=Pn, with
nεJ={j|Pj·(({right arrow over (u)}×(C−T0))×{right arrow over (u)})≧C·(({right arrow over (u)}×(C−T0))×{right arrow over (u)})}
and with
where x is the vector cross product operator and · indicates scalar multiplication.
The formula for T2 is rather complicated to express in mathematical terms, because there are different cases, depending on the constellation of C, T0 and T1. However, persons skilled in art will be able to develop algorithms to find T2 from the present discussion, or find some other point in which to construct a plane containing T0 and T1 for the present purposes of orientation.
The plane defined by T0, T1, and T2 forms the plane EO that is sought (approximation of the plane of occlusion).
To reduce sensitivity to excessive noise or artifacts, is preferable not to take the first point found for T0, T1 and T2, but rather the n-th point should be selected (n>0). By this we mean that we do not, as written in the formulas above, take the maximum value of a set, but we sort the values and take the n-th value, for example the 10th (i.e. we take a point, so that there are exactly nine other points, which would more fulfill our criterion.). We do this for T0, T1 and T2. In fact this point is one of the main reasons for the robustness of this process step.
The process continues with step 328 of refining or more precisely determining the location of the center of the arch. The problem, particularly when a point cloud is used in procedure 304, is that there can be considerable variation in the local point density in different parts of the scan. Therefore the mean X, Y, Z value of the points does not generally lie in the center of the virtual model. The procedure in step 328 resolves the location of the center so that the center does not depend on an inhomogeneous point cloud density.
At step 328, all points of the cloud of points not exceeding a certain distance (e.g., 8.0 mm) from EO are projected onto EO. Starting from the existing center point, the x-y plane is divided into sectors of the same angle into which these points are sorted. The center of gravity of the centers of gravity of the points in each sector is the new center. At step 330, the distance between the new center and the previous center is determined and a comparison is made to a threshold. If the distance is greater than the threshold, the process loops back to step 328 and the process repeats. This gives a better approximation of the center point. Repeated iteration of steps 328 and 330 yields the center.
The projection used in step 328 is as follows:
p: R3→R2
(Px,Py,Pz)(Px,Py)
The sectors Si,iε{0, . . . , 99} are used.
The point P belongs to the sector Sn with:
where arctan (x,y) is similar to arctan (y/x), but within the right quadrant, regarding the signs of both x and y.
In the repeated iterations of step 330 and 328, the result of one iteration is a new approximation of the “center of gravity” C, which can than be used (in the above formula) for the next iteration. We can stop this process either after a fixed number of iterations (e.g. 5) or when C does not change significantly (e.g. 1.0 mm) any more.
The positioning process 304 has a final step 334 of determining a back vector that lies on the plane of occlusion and points toward the opening of the palatomaxillary arch. If a unit vector is formed from the center toward the center of each of the sectors of c) in which a minimum number of points has been sorted and if their mean value is formed, the front vector is obtained (=−back vector).
The front vector is represented by the following equation:
Front vector
where |Sj| is the number of points which belong to sector Sj.
Back-vector: {right arrow over (b)}=−{right arrow over (f)}.
Referring now to
Find Local Maximums and Their Catchment Areas (Process 308)(
We now have a single mesh consisting of adjacent triangle surfaces, which is oriented in such a way that the plane of occlusion EO is “above”, i.e., pointing toward the positive z direction. The neighborhood relationship of points is also defined through triangulation: Two points neighbor each other if there is a triangle which references the two points. In the strict sense, each point that has no neighbor with a greater z coordinate is a local maximum.
In the process 308, if, starting from any point, one keeps going to the neighboring point with the greatest z coordinate until this is no longer possible, one finds a maximum M. The point of origin then belongs to the catchment area of M. If this procedure is repeated for all points, one obtains all maximums and their catchment areas.
However, since this strict definition of a maximum leads to very many maximums situated in close proximity to each other, it is advisable to sort out certain maximums. Thus, when searching for maximums, it is permissible, if a maximum Ms in the strict sense is found, also to go over to neighbors (or their neighbors etc.) with lower z coordinates, as long as the difference of the z-coordinates of this point and Ms does not exceed a certain quantity, such as 0.25 mm in the case of teeth. If a path to a point with a z coordinate greater than Ms is found in this manner, Ms should be sorted out and removed from the list of maxima.
Only the remaining maximums, and their expanded catchment areas, are considered in the following procedures 310, 312 and 314 of
The number of maximums can vary between about 30 (between 1 and 4 maximums on each tooth crown) and 100 (scan with brackets, many gaps, very non-smooth surface). T0, T1, T2 may be contained in the list of maximums, but the processing do not care about that. Every point in the virtual model belongs to exactly one catchment area.
The flow chart of
The sorting of the local maxima, described above, does not appear in the flow chart since the flow chart would have been unnecessarily long and more complex otherwise. On the other hand these sorting out mechanisms are very heuristic and not a substantial part of the whole process. The whole process can easily be performed without this sorting out, it will only take longer.
Finding Saddle Points (310) (
Referring again to
All possible saddle points Sij differing in pairs from other saddle points now make up the quantity of saddle points S={S0, . . . , Ss}. ‘Differing in pairs’ just means ‘not equal to each other’: If, e.g., S3,6 is equal to S5,9 (which may happen, because Wij are not necessarily disjoint), we do not list both, but only one of them. According to the above definition there could be more than one saddle point corresponding to Mi and Mj. In practice we chose any one of them.
Normally, there is at least one maximum on the crown of each tooth; molars and premolars usually have several. The saddle points between the maximums of adjoining teeth mark, relatively precisely, the places “between” the teeth. These points are later used as starting points for detecting ravines, a process described in conjunction with
The method for finding saddle point candidates is as follows. All triangle edges whose one vertex belongs to the catchment area of the maximum Mi, the other vertex to the catchment area of Mj, form the boundary between the two catchment areas. The lower vertex (the vertex with the smaller z coordinates) of the highest edge of this boundary is a saddle point candidate Kij.
The process proceeds with a sorting out process for saddle point candidates. Not every one of these saddle point candidates is a saddle point. Because if there is a path from Mi to Mj via other catchment areas without having to pass a saddle point (candidate) which has a smaller z coordinate than Kij, then Kij is not a saddle point. This is determined by means of a tree search from each catchment area i to every other catchment area j.
Determine Location of Saddle Points on Arch Form (e.g., Parabola) (312)(
The process of
The aim of procedure 312 is to arranging saddle points along a dental arch. A parabolic system of coordinates is helpful in arranging the saddle points along the dental arch and, later on, in measuring the “width” of an area (=extension along the dental arch). For this purpose, a parabola is placed on the x-y plane in such a manner that its axis lies on the y axis, the apex has the y coordinate of the maximum Mi, with the smallest y coordinate, and that the distance from the parabola to all the other maxima Mi is as short as possible. This parabola roughly follows the dental arch, its apex being situated at the front teeth. This is shown in
A suitable formula for defining the shape of the parabola is as follows:
par: y=ax2+b, where b is defined by the apex (as explained above), and
where Mj=(Mxj,Myj) are the Maximums, and
J={j|Myj>b+8.0}
In the parabolic coordinate transformation, a parabolic x coordinate is now calculated to each vertex V of each triangle in the virtual model. The parabolic x-coordinate is the (signed) arc length of the parabola from the apex to the base point of V (i.e., the point of the parabola closest to V). The parabolic x-coordinates of the saddle points are used in the subsequent procedures for forming a path that links the saddle points and separates the tooth crowns from the gingival tissue, as will be apparent from the discussion below. With the transformation performed (including the transformation of the saddle points), the parabolic x-coordinates for the saddle points make it possible to sort the saddle points into a saddle sequence and measure approximate lengths along the dental arch.
It will be appreciated that the parabolic transformation in step 312 could be performed for all points in the model first, and then the saddle points determined, or the other way around. Either way, once the saddle points have been determined and the parabolic transformation performed, the x-coordinates of the saddle points will be known and thus the sorting of the saddle points along the arch form can be performed.
Perform Automatic Area Search (314) (
Referring back to
The aim of the automatic area search process 314 is to find a sequence of saddle points in which two successive saddle points are on opposite sides of each tooth. The areas between the successive saddle points then correspond to a tooth crown. This sequence of saddle points is generally a partial sequence of the saddle sequence (i.e., the sequence of all saddle points arranged according to parabolic x coordinates).
The main idea of the process 314 is to perform a tree search over all possible partial sequences of the saddle sequence, calculate of a quality for each such partial sequence (measure of plausibility), and select of best partial sequence. The quality of each partial sequence is determined as follows. The area width deviations from an average width typical of the type of tooth concerned, and the height of the area, are among the factors taken into account for each area between two successive saddle points. The sum of the deviations is the quality of the partial sequence.
In performing the tree search, a breakoff criteria is used. The tree search has to be broken off prematurely at different points in order to arrive at a result within a reasonable length of time. This is done, if e.g., an area cannot be marked off between two successive saddle points, there is (excessive) overlapping of two successive areas (areas between three successive saddle points) (this is the case, e.g., when all three saddles lie in the region of one tooth), or if the distance between two successive saddle points becomes too large (in excess of a multiple of the maximum expected tooth width).
Since many areas Gij occur in different branches of the search tree, it is advisable to save areas that have already been calculated. This is done with the aid of a map. This map assigns no or exactly one elementary area to each triangle of the scan. A quantity of elementary areas is now assigned in turn to each calculated area. All areas that have already been calculated are indexed in a matrix (number of saddle points X number of saddle points). In this way, the area Gij can be retrieved for each Si, Sj pair if it has already been determined. The map is also a convenient means of determining overlaps of two areas (quantity of elementary areas contained in both areas).
With reference now to the flow chart of
If either block 434 or 436 results in a negative response, the processing proceeds to block 444, where the process checks to see if the stack is empty. If no, the process proceeds to block 446 and saddle S is removed from the stack and the process goes back to block 434. If, at block 444 the stack is empty, the process proceeds to bock 448 and a test is made to see if there is another available starting saddle. If so, the process proceeds to loop back to block 432, If not, the process ends by choosing the sequence of regions with the best overall quality (stored in block 442). In this sequence of regions (areas), each region (area) corresponds to a tooth crown.
A. Delimitation of an Area Between Two Saddle Points (438)(
The module 438 of
Width: Difference between the largest and the smallest of all parabolic x coordinates of all vertices contained in the area.
Height: Largest z coordinate of all vertices of the area (local maximum).
The process of delimitation of an area 438 will now be explained with reference to the flow chart of
If the ravine detection algorithm 362 of
If the search at 368 was successful, the area Gi,j between the two ravines is delimited and the success of the procedure is noted at step 376. This success at step 376 is used by block 440 in
B. Ravine Detection (362/368)(
The aim of the ravine detection process 362/368 of
The basis of the underlying ravine detection process is a line or path that is constructed along the vertices or nodes of the triangles in the mesh surface. An edge between two nodes corresponds either to a triangle edge or to the imaginary line linking two vertices, which are edge points of one and the same hole. (This second kind of edge makes it possible for the ravine search to be done even through holes.) The algorithm further uses local curvature to find the line that follows the “bottom” of the ravine. In particular, based on the angle of the triangles adjacent to the edge that is used for the line, and the size of such triangles, a local surface curvature is calculated for each edge of the line that corresponds to a triangle edge.
The local curvature to find the path following the “bottom” of the ravine is defined as follows. If we have 2 triangles i, j, and their normalized normal vectors {right arrow over (n)}i, {right arrow over (n)}j, and the points Pn and Pm which form the common edge of the triangles i and j, then the curvature c is defined:
A vector field (
In the ravine detection method, a tree search is now carried out along a path traversing edges of triangles, starting from the starting point, saddle point Si. A quality can be assigned to each edge (triangle surface edge) of the line. Two qualities are determined: the curvature of the edge (concavity) and the angle formed between the edge and the vector field at the starting point of the edge (parallelism). The quality of a branch of the search tree is obtained by adding the qualities of all edges from the root (starting point) to the end of the edge—multiplied by their lengths—and dividing them by the total length of the branch.
We now search for that branch from among all the branches which reach the destination point, which has the highest quality at the destination point. If a complete search cannot be carried out within a reasonable length of time, the search is broken off prematurely at numerous places. Thus, this process does not, in general, find the very best solution, but one of the best solutions, which is enough for the present purposes to result in a correct gingival tissue/tooth separation. Some of the breakoff criteria which are used are: (1) a branch is not continued if another branch leading to the same branch ends but one with a better quality has been found, and (2) a branch is not continued if a maximum length is exceeded, a minimum quality is fallen short of, or a certain start or target-point environment is departed from.
Referring now to the flow chart of
The process proceeds to step 394, and a check is,made to see if the stack is empty. If not, the process proceeds to step 396, where a node (starting point) is selected from the stack. At step 398, a neighboring point N in the mesh is chosen and a calculation is made of the quality Q of the branch (the ravine or series of interconnecting triangle edges from the starting point to the point P). At step 400, a check of the breakoff criteria is performed. If the check is satisfied, the processing proceeds to block 402, which checks to see if the point P is already in the search tree. If so, the processing proceeds to block 404, where a test is made of the quality Q to see if it is better than the quality for the neighboring point N that is already stored. If the quality is better, the process proceeds as indicated at step 406 by deleting the point N and all branches below N from the tree that were previously stored, and proceeding to module 408 where N is added along with quality Q to the tree, where the point N is added as a child or branch from point P and point N is added to the stack.
If, at point 402 the neighboring point P was not already in the search tree, the process proceeds to step 408 as indicated in
If, at step 406, the quality Q of point N is not as good as the quality of N already stored in the processing proceeds to block 410. The processing from module 408 also proceeds to block 410, as shown in
Eventually, the process of
From the foregoing discussion, it will be appreciated that in yet another aspect of the invention, we have described a ravine detection invention that provides instructions for execution by a programmed computer that identifies a path interconnecting saddle points between virtual teeth in a virtual model of the dentition. The path comprises a transition between teeth and gingival tissue and between adjacent teeth in a virtual model of dentition. In a preferred embodiment, as explained in
Persons skilled in the art will appreciate that variation from the details of the presently preferred embodiment may be made without departure from the true scope of the invention. This true scope is to be determined by reference to the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
5338198 | Wu et al. | Aug 1994 | A |
5879158 | Doyle et al. | Mar 1999 | A |
5975893 | Chishti et al. | Nov 1999 | A |
6015289 | Andreiko et al. | Jan 2000 | A |
6068482 | Snow | May 2000 | A |
6099314 | Kopelman et al. | Aug 2000 | A |
6227850 | Chishti et al. | May 2001 | B1 |
6334853 | Kopelman et al. | Jan 2002 | B1 |
6371761 | Cheang et al. | Apr 2002 | B1 |
6386878 | Pavlovskaia et al. | May 2002 | B1 |
6409504 | Jones et al. | Jun 2002 | B1 |
6463344 | Pavloskaia et al. | Oct 2002 | B1 |
20020102009 | Jones et al. | Aug 2002 | A1 |
20020177108 | Pavlovskaia et al. | Nov 2002 | A1 |
20030039389 | Jones et al. | Feb 2003 | A1 |
20030039941 | Chishti et al. | Feb 2003 | A1 |
20030235803 | Nikolskiy et al. | Dec 2003 | A1 |
Number | Date | Country |
---|---|---|
WO0180761 | Nov 2001 | WO |
Number | Date | Country | |
---|---|---|---|
20050019732 A1 | Jan 2005 | US |