Skip to content

Latest commit

 

History

History
73 lines (66 loc) · 4.12 KB

README.md

File metadata and controls

73 lines (66 loc) · 4.12 KB

Topological Graph Representation for Automatic Sulcal Curve Extraction

Description

A proper geometric representation of the cortical regions is a fundamental task for cortical shape analysis and landmark extraction. However, a significant challenge has arisen due to the highly variable, convoluted cortical folding patterns. Here, we propose a novel topological graph representation for automatic sulcal curve extraction (TRACE). In practice, the reconstructed surface suffers from noise influences introduced during image acquisition/surface reconstruction. In the presence of noise on the surface, TRACE determines stable sulcal fundic regions by employing the line simplification method that prevents the sulcal folding pattern from being significantly smoothed out. The sulcal curves are then traced over the connected graph in the determined regions by the Dijkstra’s shortest path algorithm.

image

Installation

You can download and compile the source code using CMake. Or you can pull docker image:

$ docker pull ilwoolyu/cmorph

Usage

Input

  • surface file (.vtk): triangular 3D mesh

Output

  • curve files (.scurve or/and .gcurve): indices of the selected sulcal/gyral points
  • barycentric curve files (.scurve.bary or/and .gcurve.bary): barycentric coefficients and edges for geodesic trajectories of sulcal curves - the most accurate curve information
  • surface file (.vtk): triangular 3D mesh with curve information that stores the number of branch.

Commands

The following command line will generate "output.scurve" and "output.scurve.vtk"

$ CurveExtraction -i input.vtk -o output --sulcus

By default, a junction point appears in every branch it belongs to. To allow only one juction point in output:

$ CurveExtraction --nojunction

To applying spatial or shape operator smoothing:

$ CurveExtraction --smoothIter <# of iters> --smoothTensorIter <# of iters>

To obtain the complete geodesic trajectories of sulcal curves:

$ CurveExtraction --cart (Cartesian coordinates: x-y-z)
$ CurveExtraction --bary (barycentric coordinates: vert IDs and coefficient)

Note: scurve outputs contain curves traced ONLY along the extracted sulcal points. The intermediate points may not be fully captured. These scurve outputs are NOT recommended for detailed curve representations. Please use cart or bary outputs instead.

To ignore vtk output

$ CurveExtraction --noVtk

Note: vtk outputs are designed for visual quality check.

To enable multi-thread support (OpenMP)

$ CurveExtraction --nThreads <# of threads>

See more options:

$ CurveExtraction -h

In Docker, you need a sudo acces. To run, type:

$ docker run \
         -v <LOCAL_INPUT_PATH>:/INPUT/ \
         -v <LOCAL_OUTPUT_PATH>:/OUTPUT/ \
         --rm ilwoolyu/cmorph:1.0 \
         CurveExtraction -i /INPUT/input.vtk -o /OUTPUT/output --sulcus

Please refer to our papers [1,2] for technical details (theory, parameters, methodological validation, etc.).

Requirements for build

MeshLib (general mesh processing)
SlicerExecutionModel (CLI)
To reduce package dependencies, CLI is now supported by CLI11. This tool no longer uses SlicerExecutionModel. CLI11 will be automatically installed via CMake.

References

  1. Lyu, I., Kim, S., Woodward, N., Styner, M., Landman, B., TRACE: A Topological Graph Representation for Automatic Sulcal Curve Extraction, IEEE Transactions on Medical Imaging, 37(7), 1653-1663, 2018.
  2. Lyu, I., Kim, S., Styner, M., Automatic Sulcal Curve Extraction on the Human Cortical Surface, SPIE Medical Imaging 2015, SPIE9413, 94130P-1-94130P-7.