core.reference.slices

Module: core.reference.slices

A set of methods to get coordinate maps which represent slices in space.

Functions

nipy.core.reference.slices.bounding_box(coordmap, shape)[source]

Determine a valid bounding box from a CoordinateMap and a shape.

Parameters

coordmap : CoordinateMap or AffineTransform

Containing mapping between voxel coordinates implied by shape and physical coordinates.

shape : sequence of int

shape implying array

Returns

limits : (N,) tuple of (2,) tuples of float

minimum and maximum coordinate values in output space (range) of coordmap. N is given by coordmap.ndim[1].

Examples

Make a 3D voxel to mni coordmap

>>> from nipy.core.api import vox2mni
>>> affine = np.array([[1, 0, 0, 2],
...                    [0, 3, 0, 4],
...                    [0, 0, 5, 6],
...                    [0, 0, 0, 1]], dtype=np.float64)
>>> A = vox2mni(affine)
>>> bounding_box(A, (30,40,20))
((2.0, 31.0), (4.0, 121.0), (6.0, 101.0))
nipy.core.reference.slices.xslice(x, y_spec, z_spec, world)[source]

Return an LPS slice through a 3d box with x fixed.

Parameters

x : float

The value at which x is fixed.

y_spec : sequence

A sequence with 2 values of form ((float, float), int). The (float, float) components are the min and max y values; the int is the number of points.

z_spec : sequence

As for y_spec but for z

world : str or CoordinateSystem CoordSysMaker or XYZSpace

World 3D space to which resulting coordmap refers

Returns

affine_transform : AffineTransform

An affine transform that describes an plane in LPS coordinates with x fixed.

Examples

>>> y_spec = ([-114,114], 115) # voxels of size 2 in y, starting at -114, ending at 114
>>> z_spec = ([-70,100], 86) # voxels of size 2 in z, starting at -70, ending at 100
>>> x30 = xslice(30, y_spec, z_spec, 'scanner')
>>> x30([0,0])
array([  30., -114.,  -70.])
>>> x30([114,85])
array([  30.,  114.,  100.])
>>> x30
AffineTransform(
   function_domain=CoordinateSystem(coord_names=('i_y', 'i_z'), name='slice', coord_dtype=float64),
   function_range=CoordinateSystem(coord_names=('scanner-x=L->R', 'scanner-y=P->A', 'scanner-z=I->S'), name='scanner', coord_dtype=float64),
   affine=array([[   0.,    0.,   30.],
                 [   2.,    0., -114.],
                 [   0.,    2.,  -70.],
                 [   0.,    0.,    1.]])
)
>>> bounding_box(x30, (y_spec[1], z_spec[1]))
((30.0, 30.0), (-114.0, 114.0), (-70.0, 100.0))
nipy.core.reference.slices.yslice(y, x_spec, z_spec, world)[source]

Return a slice through a 3d box with y fixed.

Parameters

y : float

The value at which y is fixed.

x_spec : sequence

A sequence with 2 values of form ((float, float), int). The (float, float) components are the min and max x values; the int is the number of points.

z_spec : sequence

As for x_spec but for z

world : str or CoordinateSystem CoordSysMaker or XYZSpace

World 3D space to which resulting coordmap refers

Returns

affine_transform : AffineTransform

An affine transform that describes an plane in LPS coordinates with y fixed.

Examples

>>> x_spec = ([-92,92], 93) # voxels of size 2 in x, starting at -92, ending at 92
>>> z_spec = ([-70,100], 86) # voxels of size 2 in z, starting at -70, ending at 100
>>> y70 = yslice(70, x_spec, z_spec, 'mni')
>>> y70
AffineTransform(
   function_domain=CoordinateSystem(coord_names=('i_x', 'i_z'), name='slice', coord_dtype=float64),
   function_range=CoordinateSystem(coord_names=('mni-x=L->R', 'mni-y=P->A', 'mni-z=I->S'), name='mni', coord_dtype=float64),
   affine=array([[  2.,   0., -92.],
                 [  0.,   0.,  70.],
                 [  0.,   2., -70.],
                 [  0.,   0.,   1.]])
)
>>> y70([0,0])
array([-92.,  70., -70.])
>>> y70([92,85])
array([  92.,   70.,  100.])
>>> bounding_box(y70, (x_spec[1], z_spec[1]))
((-92.0, 92.0), (70.0, 70.0), (-70.0, 100.0))
nipy.core.reference.slices.zslice(z, x_spec, y_spec, world)[source]

Return a slice through a 3d box with z fixed.

Parameters

z : float

The value at which z is fixed.

x_spec : sequence

A sequence with 2 values of form ((float, float), int). The (float, float) components are the min and max x values; the int is the number of points.

y_spec : sequence

As for x_spec but for y

world : str or CoordinateSystem CoordSysMaker or XYZSpace

World 3D space to which resulting coordmap refers

Returns

affine_transform : AffineTransform

An affine transform that describes a plane in LPS coordinates with z fixed.

Examples

>>> x_spec = ([-92,92], 93) # voxels of size 2 in x, starting at -92, ending at 92
>>> y_spec = ([-114,114], 115) # voxels of size 2 in y, starting at -114, ending at 114
>>> z40 = zslice(40, x_spec, y_spec, 'unknown')
>>> z40
AffineTransform(
   function_domain=CoordinateSystem(coord_names=('i_x', 'i_y'), name='slice', coord_dtype=float64),
   function_range=CoordinateSystem(coord_names=('unknown-x=L->R', 'unknown-y=P->A', 'unknown-z=I->S'), name='unknown', coord_dtype=float64),
   affine=array([[   2.,    0.,  -92.],
                 [   0.,    2., -114.],
                 [   0.,    0.,   40.],
                 [   0.,    0.,    1.]])
)
>>> z40([0,0])
array([ -92., -114.,   40.])
>>> z40([92,114])
array([  92.,  114.,   40.])
>>> bounding_box(z40, (x_spec[1], y_spec[1]))
((-92.0, 92.0), (-114.0, 114.0), (40.0, 40.0))