BACKGROUND OF THE INVENTION
The present invention relates to 3D computed tomography (CT) colonography, and more particularly, to automated polyp segmentation for 3D CT colonography.
Colon cancer is the number two cause of cancer death in men and women combined, but it is one of the most preventable cancers because doctors can identity and remove pre-cancerous growths known as polyps. 3D CT colonography (CTC), or virtual colonoscopy, is emerging as a powerful polyp screening tool because of its non-invasiveness, low cost, and high sensitivity. 3D CTC visualizes the colon, and allows a physician to navigate the colon to search for polyps. However, the physician needs to manually adjust the navigation speed and change the angle in order to see a polyp clearly. For example, a polyp may be hidden in a colonic fold and thus could be missed during the physician's visual inspection. Accordingly, there has been much research in computer aided detection (CAD) of polyps in CTC, and several such CAD systems have been proposed. Once a polyp is detected either manually or automatically, the polyp is measured and classified by a physician. However, there is a large variability in physician's measurements of polyps. Therefore, an accurate, consistent, and automated method for polyp measurement is desirable.
Polyp segmentation is defined as extracting as isolating a polyp from the colon wall at a given location. In addition to its significant value for polyp measurement in clinical practice, polyp segmentation is also important for computer aided detection of polyps. Polyp segmentation is a challenging task because polyps are abnormal growths from the colon wall and the “expected” segmentations are often a semantic, perceptual boundary with low imaging contrast support. Furthermore, there are multiple shape categories of polyps, such as sessile, pedunculated, flat, etc., with a large 3D shape/appearance variation. Conventional polyp segmentation methods utilize unsupervised segmentation or clustering in 3D data volumes. Such methods include, fuzzy clustering, deformable model or snakes, variational level-set method, and heuristic surface curvature constraints. These unsupervised approaches work well for up to 70% of polyps due to unclear polyp/nonpolyp boundaries, large within-class polyp appearance/shape variations, or limited heuristic shape assumptions. Accordingly, a polyp segmentation method having increased accuracy is desirable.
BRIEF SUMMARY OF THE INVENTION
The present invention provides a method and system for automatic polyp segmentation in 3D computed tomography colonography (CTC) volumes. Embodiments of the present invention utilize a multi-stage probabilistic learning framework for automatically segmenting polyp voxels from surrounding tissue. Embodiments of the present invention integrate low- and mid-level information for discriminative learning under local polar coordinates that are aligned on the 3D colon surface around a detected polyp.
In one embodiment of the present invention, an initial polyp position in a CTC volume is received. A polyp tip is detected in a neighborhood of the initial polyp position. The polyp tip may be detected by using a trained 3D point detector to detect polyp tip voxel candidates, which are then clustered and centered to determine a polyp tip voxel. A local polar coordinate system is then fit to a colon surface in the CTC volume with the origin of the local polar coordinate system at the detected polyp tip. Polyp interior and polyp exterior voxels are detected along each axis of the local polar coordinate system. The polyp interior and polyp exterior voxels can be detected using a trained 3D box detector. A boundary of a polyp is segmented in the CTC volume by detecting a boundary voxel for each axis of the local polar coordinate system based on the detected polyp interior and polyp exterior voxels. The boundary voxels can be detected by 1D curve parsing using a trained classifier. The segmented polyp boundary can be smoothed, and used to automatically measure the size of the segmented polyp.
These and other advantages of the invention will be apparent to those of ordinary skill in the art by reference to the following detailed description and the accompanying drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 illustrates patterns for generating steerable features for polyp segmentation;
FIG. 2 illustrates a method for segmenting a polyp in a 3D CTC volume according to an embodiment of the present invention;
FIG. 3 illustrates exemplary results of steps 204-208 of the polyp segmentation method of FIG. 2;
FIG. 4 illustrates exemplary results of fitting a local polar coordinate system to a colon surface of a CTC sub-volume;
FIG. 5 illustrates exemplary polyp interior and exterior detection results;
FIG. 6 illustrates two-layered polyp boundary segmentation of steps 212 and 214 of the polyp segmentation method of FIG. 2;
FIG. 7 illustrates an example of the looped trellis structure of the local polar coordinate system;
FIG. 8 illustrates exemplary polyp segmentation results using the method of FIG. 2; and
FIG. 9 is a high level block diagram of a computer capable of implementing the present invention.
DETAILED DESCRIPTION
The present invention is directed to a method for polyp segmentation in 3D computed tomography colonography (CTC) volumes. Embodiments of the present invention are described herein to give a visual understanding of the polyp segmentation method. A digital image is often composed of digital representations of one or more objects (or shapes). The digital representation of an object is often described herein in terms of identifying and manipulating the objects. Such manipulations are virtual manipulations accomplished in the memory or other circuitry/hardware of a computer system. Accordingly, is to be understood that embodiments of the present invention may be performed within a computer system using data stored within the computer system.
Polyp segmentation, as performed in embodiments of the present invention, is the extraction of a polyp from a CTC volume given an initial position. The initial position can be manually selected by a physician or output by computer aided detection (CAD) software using a closed 1D boundary in the 3D CTC volume. When viewing CTC volumes to look for polyps, some physicians view the volume in 2D and some in 3D, leading to large variations in the initial positions selected. Conventional polyp detection systems (i.e., CAD programs) also generate many false alarms and predict polyp locations with limited accuracy. This large variability in the initial position of the polyp locations reduces the reliability of the initial polyp locations.
In order to compensate for such inaccuracies and inconsistencies and improve overall system performance, embodiments of the present invention provide robust, learning based polyp segmentation. In order to segment a polyp, the polyp tip is detected as a voxel on the polyp surface by a 3D point detector, followed by clustering and centering. A polar coordinate system is then constructed using the detected polyp tip as its origin with a set of evenly sampled radial axes, which are 1D curves on the colon surface. The polyp boundary learning is performed along these 1D sampling axes using two-layered stacking learning using a 3D box detector and 1D curve parsing detector to effectively determine which portion of the curve is polyp and which portion of the curve is non-polyp. The binary probabilistic boundary decisions on all 1D curves/axes are assembled jointly based on their axis connectivity in the polar coordinates to generate a complete 3D polyp segmentation.
The hierarchical, multistage probabilistic boosting learning framework used by embodiments of the present invention relies on a large pool of features, which are extracted from colon surfaces under local-to-global scales. In particular, steerable features can be used to train detectors utilized by embodiments of the present invention. FIG. 1 illustrates patterns for generating steerable features for polyp segmentation. As illustrated in FIG. 1, image (a) illustrates an axis-based pattern 102 for polyp tip detection. Assuming that the sampling pattern 102 is placed with its center grid at any given voxel v, the sampling pattern 102 contains three sampling axes as the gradient directions calculated in v's neighborhood under three scales, respectively. Along each axis, nine grids are evenly sampled and 71 intensity, gradient, and curvature based local features are calculated for each grid. This process is repeated for half and quarter downsampled CT volumes. Altogether, this results in M=81=3×9×3 grid nodes, which brings 71×81=5751 features. Image (b) of FIG. 1 illustrates a box-based pattern 104 used for polyp interior/exterior material/texture classification. For the box-based sampling pattern 104, there are 7×7×5 sampling grids under each volume scale. This results in a total of 52185 features. A classifier trained using the axis-based pattern 702 and a probabilistic boosting tree (PBT) is referred to herein as a 3D point detector, while a classifier trained using the box-based pattern 704 and a PBT is referred to herein as a 3D box detector.
In polyp boundary detection, 400 parsing based features can be used for feature selection. According to embodiments of the present invention, the hierarchical multi-stage learning-based polyp segmentation can be implemented using three learning steps, in which the polyp-class probabilistic training examples are collected and grouped from a voxel-level detector (for polyp tip voxels), to a box-level detector (for boxes of polyp interior material), to a curve-parsing detector using stacking probabilities generated by the box-level detector. This local-to-global, class-conditional framework results in robust and accurate polyp segmentation.
FIG. 2 illustrates a method for segmenting a polyp in a 3D CTC volume according to an embodiment of the present invention. As illustrated in FIG. 2, at step 202, a 3D CTC volume is received. The CTC volume can be received directly from an image acquisition device, or can be received by loading a CTC volume stored in memory, storage, or other computer readable medium of a computer system. The CTC volume can be used for training or testing. CTC volumes used for training can be annotated.
At step 204, a sub-volume of the 3D CTC volume is generated based on an initial polyp location in the 3D CTC volume. The sub-volume is a polyp region generated based on an initial polyp location. The initial polyp location can be manually selected, for example by a physician using an input device, such as a mouse. Alternatively, the initial polyp location can be a polyp detection result of a CAD system. The sub-volume is generated by extracting a 3D polyp region surrounding the initial polyp location. For example, the sub-volume can be an 81×81×81 voxel region surrounding the initial polyp location. FIG. 3 illustrates exemplary results of steps 204-208 of the polyp segmentation method of FIG. 2. Image (a) of FIG. 3 is a slice of CTC sub-volume. The CTC sub-volume shows an initial polyp location 302 output from a CAD system. As shown in image (a), the initial polyp location 302 is located at the center of the CTC sub-volume.
Returning to FIG. 2, at step 206, a polyp tip is detected in the sub-volume using a 3D point detector. The polyp tip is defined herein as a colon surface voxel inside the polyp region (sub-volume), and reasonable close to the center of the polyp region. Since the polyp tip is defined as a colon surface voxel, the search domain for the polyp tip can be limited to the domain of surface voxels (i.e., voxels with non-zero gradients). In order to extract the domain of surface voxels, a gradient surface can be generated, for example using 3D Canny edge detection. Image (b) of FIG. 3 shows the voxel-based gradient surface generated from image (a) using 3D Canny edge detection. Once the surface voxels are extracted by generating the gradient surface, the polyp tip detection can be performed by classification of surface voxels as polyp tip voxel candidates, and clustering and centering the polyp tip voxel candidates to determine the polyp tip voxel.
For training a 3D point detector for polyp tip detection, neighboring surface voxels ({v}: dist(τ, v)<l1) with Euclidean distances less than a predefined metric l1 from the labeled polyp tip position τ for each polyp in the training set, are selected as positive training samples. Other surface voxels ({v}: dist(τ, v)>l2) with relative Euclidean distances larger than l2 are selected as negative training samples. The condition l1<l2 is enforced so that the trained classifier is forced to distinguish centrally located polyp voxels from non-polyp voxels. A 3D point detector is trained to solve this classification problem. The 3D point detector can be a probabilistic boosting tree (PBT) classifier trained using the axis-based steerable features described above and shown in image (a) of FIG. 1. A PBT classifier is trained by recursively constructing a tree, where each of the nodes represents a strong classifier. Once the strong classifier of each node is trained, the input training data for the node is classified into two sets (positives and negatives) using the learned strong classifier. The two new sets are fed to left and right child nodes respectively to train the left and right child nodes. In this way, the PBT classifier is constructed recursively. The trained classifier (3D point detector) is denoted herein as PBT1.
The trained 3D point detector (PBT1) is used to detect polyp tip voxel candidates from the surface voxels of the sub-volume. Accordingly, once PBT1 is learned, PBT1 determines a positive-class probability value prob(v)(from 0 to 1) for each surface voxel v of the sub-volume. If prob(v)>T1 for a voxel, where T1 is a first threshold value, then the voxel is classified as a polyp tip voxel candidate. Image (c) of FIG. 3 shows detected polyp tip voxel candidates 304 in a CTC sub-volume.
From all the detected polyp tip voxel candidates (S{v}={v}: prob(v)>T1) in a volume (or sub-volume), one voxel is detected as the polyp tip voxel by clustering and centering. The first threshold value T1 can be determined based on receiver operating characteristics (ROC) of the trained PBT classifier (PBT1). Connected component analysis is applied to partition the set S{v} into a list of n clusters C1{v}, C2{v}, . . . , Cn {v}. For each of the clusters, a fitness score Pi=ΣvεCi{v}{prob(v)}, i=1, 2, . . . , n is calculated, reflecting the overall fitness of that class being a positive polyp tip class. The cluster with the maximal fitness score is selected: Cj{v} where Pj≧Pi, i=1, 2, . . . , n, and the other clusters are discarded. According to a possible implementation, a 3D multivariate normal distribution based spatial prior G(v(x,y,z)|μ, Σ) can be integrated into Pi to reflect the confidence of the initial polyp position input μ for the CAD system or manual selection. The geometric mean μ(x, y, z) of the winning cluster Cj{v(x, y, z)} is calculated and projected to the colon surface by finding v where dist( v, μ)≦dist(v, μ) and vεS{v}. v is the detected polyp tip voxel. The detected polyp tip voxel v is detected by integrating PBT learned class-conditional information from local (i.e., polyp tip 3D point detection) to semi-global scale (i.e., clustering and centering).
Returning to FIG. 2, at step 208, a colon surface model is generated. The colon surface model can be generated using the Marching Cubes algorithm. The Marching Cubes algorithm is a well known method of constructing a polygonal mesh of an isosurface from a 3D field of scalar values or voxels (i.e., a 3D volume) in both medical and geological scans. The Marching Cubes algorithm subdivides a 3D volume space into a series of small cubes. The algorithm then “marches” through each of the cubes by testing the fitness of the current set of corner points against the predefined 15 configurations, and replaces the cube with an appropriate set of polygons. A global mesh is then generated by fusing all the cube polygons while enforcing a smoothness constraint. Since the gradient of the scalar field at each voxel is also the normal vector of a hypothetical isosurface passing from that point, these normals can be interpolated along the edges of each cube to calculate the normals of all the generated vertices. Referring to FIG. 3, image (d) shows a mesh-based CTC colon surface model generated from the sub-volume of image (a) using the Marching Cubes algorithm.
Returning to FIG. 2, at step 210 a local polar coordinate system is fit to the colon surface. Once the mesh-based colon surface is generated, the polyp tip t is identified as the closest vertex on the mesh from v. Accordingly, v is transferred onto the mesh as t. The local polar coordinate system is generated using t as its origin. Given a normal vector nt at t, two other axes which are orthogonal to nt are defined. In theory, the configuration of these two axes is not unique (i.e., they can be any two axes in nt s orthogonal plane Pt passing through t which are mutually orthogonal as well), but embodiments of the present invention fix this configuration by enforcing one axis (Y) passing through the intersection point of Pt and a predefined line vector, such as [1,0,z], where z is an arbitrary value. nt is denoted as axis X, another axis constrained as Y, and axis Z is calculated as the cross product of×and Y. The cutting planes Pn are defined as planes passing through nt or X, and another line segment Y′ in Pt which evenly rotates from Y in a clockwise direction. The axes of the final constructed polar coordinates are the intersected curves between Pn and the colon surface mesh. The coordinates on each are defined based on their geodesic distances from t (the origin) on the corresponding cutting curve or axis. The total number of axes is set as I, and they are spatially ordered in a loop. Axis i is adjacent to axes mod(i−1, I) and mod(i+1, I). FIG. 4 illustrates exemplary results of fitting a local polar coordinate system to a colon surface of a CTC sub-volume. As illustrated in FIG. 4, image (a) is a slice of a CTC sub-volume showing the initial polyp location 402, which is the center of the sub-volume, and the polyp tip voxel candidates 404 detected by the 3D point detector. Image (b) shows the detected final polyp tip 406 and the polar coordinates 408 fit to the sub-volume.
The fitting of a local polar coordinate system, which is a spatially ordered collection of 1D curve axes, is used to represent the 3D polyp surface due to the flexibility and convenient formulation to parameterization. Compared to Conformal mapping, no user indentified 3D-2D correspondences are needed and there is no constraint on 3D surface with disk topology. Furthermore, this representation, which uses a collection of 1D curves as sampling coordinates to model the 3D colon surface shape, decreases the intrinsic dimensionality problem (i.e., 1D vs. 3D modeling). This decomposable formulation makes it feasible to construct or model a large variety of 3D shapes using an assembly of simple 1D curves that are learnable and flexible.
Returning to FIG. 2, at step 212, polyp interior and exterior voxels are detected using a structural 3D box detector. For training the 3D box detector, from annotated polyp boundaries Bi, i=1, 2, . . . , I on polar coordinates, the voxels along each axis of the local polar coordinate system can be labeled as positive class (i.e., voxels lying inside the polyp boundary (Sp{vij}={vij}:(PC(vij)≦Bi−ε))), or negative class (i.e., voxels lying outside of the polyp boundary (Sn{vij}={vij}:(PC(vij)≧Bi−ε))). PC(vij) is the polar coordinates value for any voxel vij on the ith axis, Bi is the polar coordinates of the labeled boundary point on the same axis, and ε is a small value to keep a distance margin between Sp and Sn for learnability. This binary learning tree problem is solved by training a PBT based classifier, referred to herein as PBT2, with the 3D box based steerable features illustrated in image (b) of FIG. 1. Boxes are centered at each voxel and aligned with the local gradient surface. Compared with the 3D point detector PBT1 used for polyp tip detection, the 3D box detector PBT2 contains more structural information within a larger neighboring spatial span.
The trained 3D box detector PBT2 is used to detect voxels within the polyp by classifying voxels along each polar coordinate axis as polyp interior or polyp exterior voxels. For each voxel, a polyp interior class-conditional probability is calculated representing the probability that the voxel is a polyp interior voxel. FIG. 5 illustrates exemplary polyp interior and exterior detection results. As illustrated in FIG. 5, image (a) shows a slice of a CTC sub-volume along a cutting plane defined by the local polar coordinates. Image (a) shows the polyp interior class-conditional probability responses along two exemplary polar coordinate axes 502 and 504 inside the cutting plane. The higher probabilities are shown as surface voxels 506 having whiter intensities. The intersection of the normal vector 508 at the origin of the local polar coordinates and the axes 502 and 504 is at the origin of the local polar coordinate system. Annotated polyp interior/exterior boundaries 510 and 512 are shown on the polar coordinate axes 502 and 504, respectively. Image (b) shows a plot of polyp interior class-conditional probability responses on the axis 502 of image (a) from the origin of the local polar coordinate system. The location of the annotated polyp boundary 510 in image (a) is shown at 514 in image (b).
Returning to FIG. 2, at step 214, the polyp surface boundary is detected using boosted 1D curve parsing and stacking. In order to detect the polyp boundary, this step is treated as a statistical curve parsing problem of finding polyp/nonpolyp breaking points on 1D curves. Given the output probabilities from the polyp interior/exterior detection (step 212), another layer of boundary boosting learning is applied, based on the theory of stacked generality. This is equivalent to learning a new classifier in the embedded, semantic space learned by the 3D box detector (as a wrapped) in the previous step. To learn the true polyp boundary of 1D vectors of noisy values, the coordinates along each axis are labeled as positive class (i.e., coordinates within a small distance threshold distance threshold of the annotated boundary S+{vij}={vij}:(Bt−ε1)≦PC(vij)≦(Bi+ε1)) or, negative class (i.e., coordinates outside of the small distance threshold of the annotated boundary S−{vij}={vij}≧(Bi+ε2))||(PC(vij)≦(Bi−ε2))). ε2>ε1 can be set to keep the distance margin (ε2−ε1)>0 between S+ and S− for reducing learning ambiguity.
From S+ and S−, vij probability value pij is evaluated using PBT2. Thus, an array of {pij } is obtained on each axis i as A(pij)=(pi1, pi2, pi3, . . . , pij, . . . ). Then the following features are calculated for according to each vij or pij from Af(pij)=(pi1, pi2, pi3, . . . , pij)and Ab(pij)=(pi, j+1, pi,j+2, pi,j+3, . . . ) respectively, for two-class PBT learning:
- 1) probability count features: the count of p s above a threshold θ in array Af or Ab; and
- 2) probability gap features: the size vector of the largest gaps of the θ-threshold probability array for Af or Ab, sorted in decreasing order.
Af(pij) represents pij s forward array spatially from origin to vij, and Ab(pij) represents pij s backward array spatially from vi,j+1 to end. The θ-threshold probability array means replacing every element p in Af or Ab with 0 if p<θ and 1 if p≧0. The gap size is the count of continuous 0's. It is possible to set θ=i×0.05, i=0, 1, . . . 19 and the size of gap vectors to be 20 for each θ. If there are less than 20 existing gaps, 0 can be used to fill up the 20-element vector. Therefore a total of 440=(20+20×20)×2 features are calculated as the feature selection pool for PBT learning. These features are used to train a PBT-based classifier. The resulting classifier is denoted herein as PBT3.
Using the trained classifier PBT3, a new probability value pij is calculated for each voxel vij on the local polar coordinates by evaluating its forward and backward probability arrays Af(pij) and Ab(pij) output by PBT2 . To determine a unique boundary point on any axis i, vik, is selected with piki=max{pi1, pi2, pi3, . . . , pij, . . . }. Accordingly, a boundary voxel viki is detected for each polar coordinate axis, and the set of boundary voxels define a boundary of the polyp. FIG. 6 illustrates the two-layered polyp boundary segmentation of steps 212 and 214. As illustrated in FIG. 6, image (a) shows the polyp interior class probability response map on the polyp surface, with voxels 602 having higher probabilities shown as whiter intensities. Image (b) shows the segmented polyp boundary contour 604 overlayed on the local polar coordinate system 606. Image (b) also shows segments 608 and 610 representing the two main axes for polyp dimensioning.
Returning to FIG. 2, at step 216, the segmented polyp surface boundary is smoothed. Assuming that the selection of each viki is solely based on {pi1, pi2, pi3, . . . , pij, . . . } and independent with respect to the formation on other axes, the final polyp segmentation boundary will be rugged by sequentially connecting v1ki, v2k2, . . . , on all axes of the local polar coordinates. For smoothness, these boundary decisions can be assembled using Gaussian blurring over their polar coordinates values PC(v1k1), PC(v2k2), . . . , according to neighborhoods of successive axes. Alternatively, Viterbi-like dynamic programming can be utilized to solve this sequential smoothing problem with a looped trellis structure. Another possible smoothing solution is loopy belief propagation, which treats the local polar coordinates as a general looped 2D graph. FIG. 7 illustrates an example of the looped trellis structure of the local polar coordinate system. As illustrated in FIG. 7, image (a) shows the loopy structure of the axes of the local polar coordinates overlayed on the polyp surface, and image (b) shows the equivalent looped sequential trellis or looped 2D graph topology. Gaussian blurring is indeed a spatially homogenous smoothing filter, while Viterbi and loopy belief propagation are non-homogenous functions by building pairwise content-sensitive potential functions. All three smoothing approaches function as assemblers of propagating 1D axis segmentations across neighboring axes in polar coordinates.
The method of FIG. 2 results in a smoothed segmented polyp boundary. The segmented polyp can be output. For example, the segmented polyp boundary can be displayed as an image, such as on a display device of a computer system, stored on a storage, memory, or other computer readable medium. A physician can use such segmentation results for diagnostic and medical purposes, for example for polyp removal or diagnosis of colon cancer. FIG. 8 illustrates exemplary polyp segmentation results using the method of FIG. 2. As illustrated in FIG. 8, the segmentation method can be used to segment various shape categories of polyps. Images (a) and (b) show segmentation results 802 and 804 for sessile polyps. Image (c) shows segmentation results 806 for a mass polyp. Image (d) shows segmentation results 808 for a polyp on a fold. Image (e) shows segmentation results 810 for a pedunculated polyp. Image (f) shows segmentation results 812 for a flat polyp.
The segmented polyp boundary can also be used to automatically calculate polyp measurements. After the polyp boundary is segmented for a polyp, a set of positive polyp surface voxels (with their associated probabilities p) inside the segmented polyp boundary can be enumerated. It is then straightforward to calculate the polyp dimensions. A pair of positive voxels v11, v12 are detected with the maximal Euclidean distance from each other to define a first polyp axis. Using the distance dist(v11,v12) as the estimated polyp size, other pairs of voxels v2, v2 that are orthogonal to v11, v12 (i.e., (v2′, v2″)⊕(v11, v12)=0). A pair of voxels v21,v22 are then selected from the orthogonal voxels v2, v2 with the maximal Euclidean distance from each other as the second polyp axis. A third polyp axis can also be calculated by similarly calculating a third orthogonal axis. The detected polyp axes are used to calculate the size of the polyp.
The above-described polyp segmentation methods may be implemented on a computer using well-known computer processors, memory units, storage devices, computer software, and other components. A high level block diagram of such a computer is illustrated in FIG. 9. Computer 902 contains a processor 904 which controls the overall operation of the computer 902 by executing computer program instructions which define such operation. The computer program instructions may be stored in a storage device 912, or other computer readable medium (e.g., magnetic disk), and loaded into memory 910 when execution of the computer program instructions is desired. Thus, the steps of the method of FIG. 2, may be defined by the computer program instructions stored in the memory 910 and/or storage 912 and controlled by the processor 904 executing the computer program instructions. Furthermore, the classifiers trained by the above described methods and the segmentation results achieved by the above described methods can be stored in the memory 910 and/or storage 912. An image acquisition device 920, such as a CT scanning device, can be connected to the computer 902 to input 3D CTC volumes to the computer 902. It is possible to implement the image acquisition device 920 and the computer 902 as one device. It is also possible that the image acquisition device 920 and the computer 902 communicate wirelessly through a network. The computer 902 also includes one or more network interfaces 906 for communicating with other devices via a network. The computer 902 also includes other input/output devices 908 that enable user interaction with the computer 902 (e.g., display, keyboard, mouse, speakers, buttons, etc.) One skilled in the art will recognize that an implementation of an actual computer could contain other components as well, and that FIG. 9 is a high level representation of some of the components of such a computer for illustrative purposes.
The foregoing Detailed Description is to be understood as being in every respect illustrative and exemplary, but not restrictive, and the scope of the invention disclosed herein is not to be determined from the Detailed Description, but rather from the claims as interpreted according to the full breadth permitted by the patent laws. It is to be understood that the embodiments shown and described herein are only illustrative of the principles of the present invention and that various modifications may be implemented by those skilled in the art without departing from the scope and spirit of the invention. Those skilled in the art could implement various other feature combinations without departing from the scope and spirit of the invention.