Segmentation of a Knee Bone in 3D
To quantify and measure the properties of a component in a volume, segmentation is a necessary first step. To segment the bone tissue in an MRT volume, a clustering algorithm is used to achieve a rough segmentation and apply a grow-cut algorithm to obtain the final result.
Out[1]= | data:image/s3,"s3://crabby-images/87e07/87e07cf920ed6aa6356440721d470530a42ba70b" alt="" |
The volume is preprocessed using MedianFilter to regularize noise. An initial segmentation is performed by clustering voxel intensities using ClusteringComponents. This partitions the data into three regions: empty space, muscle tissue, and the rest, which includes bone, fat, and skin.
Out[2]= | data:image/s3,"s3://crabby-images/ebca5/ebca53131f8fecfae84648ffa78b54f7d3847826" alt="" |
Extract the segment with highest mean intensity, which depicts bone, fat, and skin tissue.
Out[3]= | data:image/s3,"s3://crabby-images/39bb1/39bb171913b9c2370e932b6de4a4de49fe6ed469" alt="" |
Out[4]= | data:image/s3,"s3://crabby-images/16246/16246517ca4af041a0f499d6ac140f4b645b113b" alt="" |
GrowCutComponents can provide a nice final segmentation. In order to create two markers for bone and no-bone areas, one can use morphological operations.
The bone marker can be computed by eroding the segment using a radius 4, which deletes all thin skin and fat layers and also erodes some of the bone.
Out[5]= | data:image/s3,"s3://crabby-images/51f1d/51f1df77b9b197043f1dc8b1959ad40d373a5276" alt="" |
For the no-bone marker, dilate the bone core more than what was eroded and extract the surface around the dilated volume.
Out[6]= | data:image/s3,"s3://crabby-images/84e49/84e49980408f623fe9ec8ec96b91d6626f60f478" alt="" |
Run the 3D grow-cut-algorithm to refine the segmentation.
Out[7]= | data:image/s3,"s3://crabby-images/4fd8c/4fd8cd24dabeb13a8e25702ffab1aec9148da174" alt="" |
Visualize the segmentation.
Out[8]= | data:image/s3,"s3://crabby-images/a36d1/a36d1e07ccb90ab379d1008113e2ea8f9c61a6bd" alt="" |
Size and density measurements can be calculated for each segment.
Out[9]= | data:image/s3,"s3://crabby-images/e3e2c/e3e2c488b034d548926765eb3baa1c26d4cb40ab" alt="" |
Out[37]//TraditionalForm= |
| data:image/s3,"s3://crabby-images/5c940/5c9404c45a1ea3d5534835beb0539257d9768d9e" alt="" |