Skip to content

What you can do with nilabels

Sebastiano Ferraris edited this page Mar 17, 2019 · 10 revisions

Main features of the code are:

  • Check if there are missing labels in a segmentation (.nii or .nii.gz) and returns a report with the number of connected components per label.

  • Given a segmentation and a label descriptor (itk-snap convention or fsl convention) it returns the corresponding RGB image (4d image with 3 layers in the fourth dimension corresponding to R G B channels).

  • Get the stacks of 4d images so that they are predisposed for label fusion algorithms (using for example niftySeg for the label fusion).

  • Quickly manipulate the components of the header, applying rotations respect to the center of the image or the origin, change the datatype or the translational part.

  • Normalise the intensities of an image given the values below a list of labels of a segmentation, getting the contour of a segmentation, and produce graftings between segmentations.

  • Relabel a segmentation given the list of old and the corresponding new labels.

  • Permute labels according to a given permutation.

  • Keep only one label and assign all the others the same value.

  • get the probabilistic prior from a stack of segmentations.

  • Clean a segmentation leaving only a pre-defined number of connected components for each label and merging the extra components with the closest label.

  • Compute volumes per label of a segmentations.

  • Compute distances between segmentations, such as the dice score, covariance distance, Hausdorff distance and normalised symmetric contour distance.

  • Get all the voxel values below a specified label of a segmentation from the underpinning anatomical image (FA, MD...)

  • Manipulate the shape of the volume of an image, extending a slice an new dimension, splitting the labels in a 4d image and merge it back, and cut each slice of a 4d volume for a given 3d binary compatible segmentation.

  • Symmetrize a segmentation respect to a plane (with and without rigid registration based on an underpinning anatomy).

  • Create a simple phantom to test label fusion algorithms.

  • Visualise a 3D or 4D array from an Ipython session, through a dummy nifti image opened in ITK-snap.

Clone this wiki locally