mne.channels.DigMontage#
- class mne.channels.DigMontage(*, dig=None, ch_names=None)[source]#
Montage for digitized electrode and headshape position data.
Warning
Montages are typically created using one of the helper functions in the
See Also
section below instead of instantiating this class directly.- Parameters:
Methods
__add__
(other)Add two DigMontages.
add_estimated_fiducials
(subject[, ...])Estimate fiducials based on FreeSurfer
fsaverage
subject.add_mni_fiducials
([subjects_dir, verbose])Add fiducials to a montage in MNI space.
apply_trans
(trans[, verbose])Apply a transformation matrix to the montage.
copy
()Copy the DigMontage object.
Get all channel and fiducial positions.
plot
(*[, scale, scale_factor, show_names, ...])Plot a montage.
remove_fiducials
([verbose])Remove the fiducial points from a montage.
rename_channels
(mapping[, allow_duplicates])Rename the channels.
save
(fname, *[, overwrite, verbose])Save digitization points to FIF.
See also
Notes
New in v0.9.0.
- add_estimated_fiducials(subject, subjects_dir=None, verbose=None)[source]#
Estimate fiducials based on FreeSurfer
fsaverage
subject.This takes a montage with the
mri
coordinate frame, corresponding to the FreeSurfer RAS (xyz in the volume) T1w image of the specific subject. It will callmne.coreg.get_mni_fiducials()
to estimate LPA, RPA and Nasion fiducial points.- Parameters:
- subject
str
The FreeSurfer subject name.
- subjects_dirpath-like |
None
The path to the directory containing the FreeSurfer subjects reconstructions. If
None
, defaults to theSUBJECTS_DIR
environment variable.- verbosebool |
str
|int
|None
Control verbosity of the logging output. If
None
, use the default verbosity level. See the logging documentation andmne.verbose()
for details. Should only be passed as a keyword argument.
- subject
- Returns:
- instinstance of
DigMontage
The instance, modified in-place.
- instinstance of
Notes
Since MNE uses the FIF data structure, it relies on the
head
coordinate frame. Any coordinate frame can be transformed tohead
if the fiducials (i.e. LPA, RPA and Nasion) are defined. One can use this function to estimate those fiducials and then usemne.channels.compute_native_head_t(montage)
to get the head <-> MRI transform.
- add_mni_fiducials(subjects_dir=None, verbose=None)[source]#
Add fiducials to a montage in MNI space.
- Parameters:
- subjects_dirpath-like |
None
The path to the directory containing the FreeSurfer subjects reconstructions. If
None
, defaults to theSUBJECTS_DIR
environment variable.- verbosebool |
str
|int
|None
Control verbosity of the logging output. If
None
, use the default verbosity level. See the logging documentation andmne.verbose()
for details. Should only be passed as a keyword argument.
- subjects_dirpath-like |
- Returns:
- instinstance of
DigMontage
The instance, modified in-place.
- instinstance of
Notes
fsaverage
is in MNI space and so its fiducials can be added to a montage in “mni_tal”. MNI is an ACPC-aligned coordinate system (the posterior commissure is the origin) so since BIDS requires channel locations for ECoG, sEEG and DBS to be in ACPC space, this function can be used to allow those coordinate to be transformed to “head” space (origin between LPA and RPA).
- apply_trans(trans, verbose=None)[source]#
Apply a transformation matrix to the montage.
- Parameters:
- transinstance of
mne.transforms.Transform
The transformation matrix to be applied.
- verbosebool |
str
|int
|None
Control verbosity of the logging output. If
None
, use the default verbosity level. See the logging documentation andmne.verbose()
for details. Should only be passed as a keyword argument.
- transinstance of
- copy()[source]#
Copy the DigMontage object.
- Returns:
- diginstance of
DigMontage
The copied DigMontage instance.
- diginstance of
- get_positions()[source]#
Get all channel and fiducial positions.
- Returns:
- positions
dict
A dictionary of the positions for channels (
ch_pos
), coordinate frame (coord_frame
), nasion (nasion
), left preauricular point (lpa
), right preauricular point (rpa
), Head Shape Polhemus (hsp
), and Head Position Indicator(hpi
). E.g.:{ 'ch_pos': {'EEG061': [0, 0, 0]}, 'nasion': [0, 0, 1], 'coord_frame': 'mni_tal', 'lpa': [0, 1, 0], 'rpa': [1, 0, 0], 'hsp': None, 'hpi': None }
- positions
- plot(*, scale=None, scale_factor=None, show_names=True, kind='topomap', show=True, sphere=None, axes=None, verbose=None)[source]#
Plot a montage.
- Parameters:
- scale
float
Determines the scale of the channel points and labels; values < 1 will scale down, whereas values > 1 will scale up. Default to None, which implies 1.
- scale_factor
float
Determines the size of the points. Deprecated, use scale instead.
- show_namesbool |
list
Whether to display all channel names. If a list, only the channel names in the list are shown. Defaults to True.
- kind
str
Whether to plot the montage as ‘3d’ or ‘topomap’ (default).
- showbool
Show figure if True.
- sphere
float
| array_like | instance ofConductorModel
|None
| ‘auto’ | ‘eeglab’ The sphere parameters to use for the head outline. Can be array-like of shape (4,) to give the X/Y/Z origin and radius in meters, or a single float to give just the radius (origin assumed 0, 0, 0). Can also be an instance of a spherical
ConductorModel
to use the origin and radius from that object. If'auto'
the sphere is fit to digitization points. If'eeglab'
the head circle is defined by EEG electrodes'Fpz'
,'Oz'
,'T7'
, and'T8'
(if'Fpz'
is not present, it will be approximated from the coordinates of'Oz'
).None
(the default) is equivalent to'auto'
when enough extra digitization points are available, and (0, 0, 0, 0.095) otherwise.New in v0.20.
Changed in version 1.1: Added
'eeglab'
option.- axesinstance of
Axes
| instance ofAxes3D
|None
Axes to draw the sensors to. If
kind='3d'
, axes must be an instance of Axes3D. If None (default), a new axes will be created.New in v1.4.
- verbosebool |
str
|int
|None
Control verbosity of the logging output. If
None
, use the default verbosity level. See the logging documentation andmne.verbose()
for details. Should only be passed as a keyword argument.
- scale
- Returns:
- figinstance of
matplotlib.figure.Figure
The figure object.
- figinstance of
Examples using
plot
:Working with sensor locations
- remove_fiducials(verbose=None)[source]#
Remove the fiducial points from a montage.
- Parameters:
- verbosebool |
str
|int
|None
Control verbosity of the logging output. If
None
, use the default verbosity level. See the logging documentation andmne.verbose()
for details. Should only be passed as a keyword argument.
- verbosebool |
- Returns:
- instinstance of
DigMontage
The instance, modified in-place.
- instinstance of
Notes
MNE will transform a montage to the internal “head” coordinate frame if the fiducials are present. Under most circumstances, this is ideal as it standardizes the coordinate frame for things like plotting. However, in some circumstances, such as saving a
raw
with intracranial data to BIDS format, the coordinate frame should not be changed by removing fiducials.
- rename_channels(mapping, allow_duplicates=False)[source]#
Rename the channels.
- Parameters:
- mapping
dict
|callable()
A dictionary mapping the old channel to a new channel name e.g.
{'EEG061' : 'EEG161'}
. Can also be a callable function that takes and returns a string.Changed in version 0.10.0: Support for a callable function.
- allow_duplicatesbool
If True (default False), allow duplicates, which will automatically be renamed with
-N
at the end.New in v0.22.0.
- mapping
- Returns:
- instinstance of
DigMontage
The instance. Operates in-place.
- instinstance of
- save(fname, *, overwrite=False, verbose=None)[source]#
Save digitization points to FIF.
- Parameters:
- fnamepath-like
The filename to use. Should end in .fif or .fif.gz.
- overwritebool
If True (default False), overwrite the destination file if it exists.
- verbosebool |
str
|int
|None
Control verbosity of the logging output. If
None
, use the default verbosity level. See the logging documentation andmne.verbose()
for details. Should only be passed as a keyword argument.