labs.spatial_models.mroi

Module: labs.spatial_models.mroi

Inheritance diagram for nipy.labs.spatial_models.mroi:

Inheritance diagram of nipy.labs.spatial_models.mroi

Class

SubDomains

class nipy.labs.spatial_models.mroi.SubDomains(domain, label, id=None)

Bases: object

This is a class to represent multiple ROI objects, where the reference to a given domain is explicit.

A multiple ROI object is a set of ROI defined on a given domain, each having its own ‘region-level’ characteristics (ROI features).

Every voxel of the domain can have its own characteristics yet, defined at the ‘voxel-level’, but those features can only be accessed familywise (i.e. the values are grouped by ROI).

Parameters:
kint

Number of ROI in the SubDomains object

labelarray of shape (domain.size), dtype=np.int_

An array use to define which voxel belongs to which ROI. The label values greater than -1 correspond to subregions labelling. The labels are recomputed so as to be consecutive integers. The labels should not be accessed outside this class. One has to use the API mapping methods instead.

featuresdict {str: list of object, length=self.k}

Describe the voxels features, grouped by ROI

roi_featuresdict {str: array-like, shape=(self.k, roi_feature_dim)

Describe the ROI features. A special feature, id, is read-only and is used to give an unique identifier for region, which is persistent through the MROI objects manipulations. On should access the different ROI’s features using ids.

__init__(domain, label, id=None)

Initialize subdomains instance

Parameters:
domain: ROI instance

defines the spatial context of the SubDomains

label: array of shape (domain.size), dtype=np.int_,

An array use to define which voxel belongs to which ROI. The label values greater than -1 correspond to subregions labelling. The labels are recomputed so as to be consecutive integers. The labels should not be accessed outside this class. One has to use the select_id() mapping method instead.

id: array of shape (n_roi)

Define the ROI identifiers. Once an id has been associated to a ROI it becomes impossible to change it using the API. Hence, one should access ROI through their id to avoid hazardous manipulations.

copy()

Returns a copy of self.

Note that self.domain is not copied.

feature_to_voxel_map(fid, roi=False, method='mean')

Convert a feature to a flat voxel-mapping array.

Parameters:
fid: str

Identifier of the feature to be mapped.

roi: bool, optional

If True, compute the map from a ROI feature.

method: str, optional

Representative feature computation method if fid is a feature and roi is True.

Returns:
res: array-like, shape=(domain.size, feature_dim)

A flat array, giving the correspondence between voxels and the feature.

get_coord(id=None)

Get coordinates of ROI’s voxels

Parameters:
id: any hashable type

Id of the ROI from which we want the voxels’ coordinates. Can be None (default) if we want all ROIs’s voxels coordinates.

Returns:
coords: array-like, shape=(roi_size, domain_dimension)
if an id is provided,

or list of arrays of shape(roi_size, domain_dimension)

if no id provided (default)

get_feature(fid, id=None)

Return a voxel-wise feature, grouped by ROI.

Parameters:
fid: str,

Feature to be returned

id: any hashable type

Id of the ROI from which we want to get the feature. Can be None (default) if we want all ROIs’s features.

Returns:
feature: array-like, shape=(roi_size, feature_dim)
if an id is provided,

or list of arrays, shape=(roi_size, feature_dim)

if no id provided (default)

get_id()

Return ROI’s id list.

Users must access ROIs with the use of the identifiers of this list and the methods that give access to their properties/features.

get_local_volume(id=None)

Get volume of ROI’s voxels

Parameters:
id: any hashable type

Id of the ROI from which we want the voxels’ volumes. Can be None (default) if we want all ROIs’s voxels volumes.

Returns:
loc_volume: array-like, shape=(roi_size, ),
if an id is provided,

or list of arrays of shape(roi_size, )

if no id provided (default)

get_roi_feature(fid, id=None)
get_size(id=None)

Get ROI size (counted in terms of voxels)

Parameters:
id: any hashable type

Id of the ROI from which we want to get the size. Can be None (default) if we want all ROIs’s sizes.

Returns:
size: int
if an id is provided,

or list of int

if no id provided (default)

get_volume(id=None)

Get ROI volume

Parameters:
id: any hashable type

Id of the ROI from which we want to get the volume. Can be None (default) if we want all ROIs’s volumes.

Returns:
volumefloat
if an id is provided,

or list of float

if no id provided (default)

integrate(fid=None, id=None)

Integrate certain feature on each ROI and return the k results

Parameters:
fidstr

Feature identifier. By default, the 1 function is integrated, yielding ROI volumes.

id: any hashable type

The ROI on which we want to integrate. Can be None if we want the results for every region.

Returns:
lsum = array of shape (self.k, self.feature[fid].shape[1]),

The results

plot_feature(fid, ax=None)

Boxplot the distribution of features within ROIs. Note that this assumes 1-d features.

Parameters:
fid: string

the feature identifier

ax: axis handle, optional
recompute_labels()

Redefine labels so that they are consecutive integers.

Labels are used as a map to associate voxels to a given ROI. It is an inner object that should not be accessed outside this class. The number of nodes is updated appropriately.

Notes

This method must be called every time the MROI structure is modified.

remove_feature(fid)

Remove a certain feature

Parameters:
fid: str

Feature id

Returns:
fobject

The removed feature.

remove_roi_feature(fid)

Remove a certain ROI feature.

The id ROI feature cannot be removed.

Returns:
fobject

The removed Roi feature.

representative_feature(fid, method='mean', id=None, assess_quality=False)

Compute a ROI representative of a given feature.

Parameters:
fidstr

Feature id

methodstr, optional

Method used to compute a representative. Chosen among ‘mean’ (default), ‘max’, ‘median’, ‘min’, ‘weighted mean’.

idany hashable type, optional

Id of the ROI from which we want to extract a representative feature. Can be None (default) if we want to get all ROIs’s representatives.

assess_quality: bool, optional

If True, a new roi feature is created, which represent the quality of the feature representative (the number of non-nan value for the feature over the ROI size). Default is False.

Returns:
summary_feature: np.ndarray, shape=(self.k, feature_dim)

Representative feature computed according to method.

select_id(id, roi=True)

Convert a ROI id into an index to be used to index features safely.

Parameters:
idany hashable type, must be in self.get_id()

The id of the region one wants to access.

roibool

If True (default), return the ROI index in the ROI list. If False, return the indices of the voxels of the ROI with the given id. That way, internal access to self.label can be made.

Returns:
indexint or np.array of shape (roi.size, )

Either the position of the ROI in the ROI list (if roi == True), or the positions of the voxels of the ROI with id id with respect to the self.label array.

select_roi(id_list)

Returns an instance of MROI with only the subset of chosen ROIs.

Parameters:
id_list: list of id (any hashable type)

The id of the ROI to be kept in the structure.

set_feature(fid, data, id=None, override=False)

Append or modify a feature

Parameters:
fidstr

feature identifier

data: list or array

The feature data. Can be a list of self.k arrays of shape(self.size[k], p) or array of shape(self.size[k])

id: any hashable type, optional

Id of the ROI from which we want to set the feature. Can be None (default) if we want to set all ROIs’s features.

override: bool, optional

Allow feature overriding

Note that we cannot create a feature having the same name than
a ROI feature.
set_roi_feature(fid, data, id=None, override=False)

Append or modify a ROI feature

Parameters:
fid: str,

feature identifier

data: list of self.k features or a single feature

The ROI feature data

id: any hashable type

Id of the ROI of which we want to set the ROI feature. Can be None (default) if we want to set all ROIs’s ROI features.

override: bool, optional,

Allow feature overriding

Note that we cannot create a ROI feature having the same name than
a feature.
Note that the `id` feature cannot be modified as an internal
component.
to_image(fid=None, roi=False, method='mean', descrip=None)

Generates a label image that represents self.

Parameters:
fid: str,

Feature to be represented. If None, a binary image of the MROI domain will be we created.

roi: bool,

Whether or not to write the desired feature as a ROI one. (i.e. a ROI feature corresponding to fid will be looked upon, and if not found, a representative feature will be computed from the fid feature).

method: str,

If a feature is written as a ROI feature, this keyword tweaks the way the representative feature is computed.

descrip: str,

Description of the image, to be written in its header.

Returns:
nimnibabel nifti image

Nifti image corresponding to the ROI feature to be written.

Notes

Requires that self.dom is an ddom.NDGridDomain

Functions

nipy.labs.spatial_models.mroi.subdomain_from_array(labels, affine=None, nn=0)

Return a SubDomain from an n-d int array

Parameters:
label: np.array instance

A supposedly boolean array that yields the regions.

affine: np.array, optional

Affine transform that maps the array coordinates to some embedding space by default, this is np.eye(dim+1, dim+1).

nn: int,

Neighboring system considered. Unused at the moment.

Notes

Only labels > -1 are considered.

nipy.labs.spatial_models.mroi.subdomain_from_balls(domain, positions, radii)

Create discrete ROIs as a set of balls within a certain coordinate systems.

Parameters:
domain: StructuredDomain instance,

the description of a discrete domain

positions: array of shape(k, dim):

the positions of the balls

radii: array of shape(k):

the sphere radii

nipy.labs.spatial_models.mroi.subdomain_from_image(mim, nn=18)

Return a SubDomain instance from the input mask image.

Parameters:
mim: NiftiIImage instance, or string path toward such an image

supposedly a label image

nn: int, optional

Neighboring system considered from the image can be 6, 18 or 26.

Returns:
The MultipleROI instance

Notes

Only labels > -1 are considered

nipy.labs.spatial_models.mroi.subdomain_from_position_and_image(nim, pos)

Keep the set of labels of the image corresponding to a certain index so that their position is closest to the prescribed one.

Parameters:
mim: NiftiIImage instance, or string path toward such an image

supposedly a label image

pos: array of shape(3) or list of length 3,

the prescribed position