1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429
|
.. _cookbook:
==========================
The typical M/EEG workflow
==========================
Overview
========
This section describes a typical MEG/EEG workflow, eventually up to source
reconstruction. The workflow is summarized in :ref:`flow_diagram`.
References below refer to Python functions and objects.
.. _flow_diagram:
.. figure:: images/flow_diagram.svg
:alt: MNE Workflow Flowchart
:align: center
**Workflow of the MNE software**
Preprocessing
=============
The following MEG and EEG data preprocessing steps are recommended:
- Bad channels in the MEG and EEG data must be identified, see :ref:`marking_bad_channels`.
- The data has to be filtered to the desired passband.
- Artifacts should be suppressed (e.g., using ICA or SSP).
.. _marking_bad_channels:
Marking bad channels
--------------------
Sometimes some MEG or EEG channels are not functioning properly
for various reasons. These channels should be excluded from
analysis by marking them bad as::
>>> raw.info['bads'] = ['MEG2443'] # doctest: +SKIP
Especially if a channel does not show
a signal at all (flat) it is important to exclude it from the
analysis, since its noise estimate will be unrealistically low and
thus the current estimate calculations will give a strong weight
to the zero signal on the flat channels and will essentially vanish.
It is also important to exclude noisy channels because they can
possibly affect others when signal-space projections or EEG average electrode
reference is employed. Noisy bad channels can also adversely affect
averaging and noise-covariance matrix estimation by causing
unnecessary rejections of epochs.
Recommended ways to identify bad channels are:
- Observe the quality of data during data
acquisition and make notes of observed malfunctioning channels to
your measurement protocol sheet.
- View the on-line averages and check the condition of the channels.
- Compute preliminary off-line averages with artifact rejection,
SSP/ICA, and EEG average electrode reference computation
off and check the condition of the channels.
- View raw data with :func:`mne.io.Raw.plot` without SSP/ICA
enabled and identify bad channels.
.. note:: It is strongly recommended that bad channels are identified and
marked in the original raw data files. If present in the raw data
files, the bad channel selections will be automatically transferred
to averaged files, noise-covariance matrices, forward solution
files, and inverse operator decompositions.
Artifact suppression
--------------------
SSP
###
The Signal-Space Projection (SSP) is one approach to rejection
of external disturbances in software. Unlike many other
noise-cancellation approaches, SSP does
not require additional reference sensors to record the disturbance
fields. Instead, SSP relies on the fact that the magnetic field
distributions generated by the sources in the brain have spatial
distributions sufficiently different from those generated by external
noise sources. Furthermore, it is implicitly assumed that the linear
space spanned by the significant external noise patterns has a low
dimension.
SSP-based rejection is often done using the
:func:`mne.preprocessing.compute_proj_ecg` and
:func:`mne.preprocessing.compute_proj_eog` methods, see
:ref:`tut-projectors-background` and :ref:`tut-artifact-ssp` for more
information.
ICA
###
Many M/EEG signals including biological artifacts reflect non-Gaussian
processes. Therefore PCA-based artifact rejection will likely perform worse at
separating the signal from noise sources.
ICA-based artifact rejection is done using the :class:`mne.preprocessing.ICA`
class, see the :ref:`ica` section for more information.
Epoching and evoked data
========================
Epoching of raw data is done using events, which define a ``t=0`` for your
data chunks. Event times stamped to the acquisition software can be extracted
using :func:`mne.find_events`::
>>> events = mne.find_events(raw) # doctest: +SKIP
The ``events`` array can then be modified, extended, or changed if necessary.
If the original trigger codes and trigger times are correct for the analysis
of interest, :class:`mne.Epochs` for the first event type (``1``) can be
constructed using::
>>> reject = dict(grad=4000e-13, mag=4e-12, eog=150e-6) # doctest: +SKIP
>>> epochs = mne.Epochs(raw, events, event_id=1, tmin=-0.2, tmax=0.5, # doctest: +SKIP
>>> proj=True, picks=picks, baseline=(None, 0), # doctest: +SKIP
>>> preload=True, reject=reject) # doctest: +SKIP
.. note:: The rejection thresholds (set with argument ``reject``) are defined
in T / m for gradiometers, T for magnetometers and V for EEG and EOG
channels.
Rejection using annotations
---------------------------
The reject keyword of :class:`mne.Epochs` is used for rejecting bad epochs
based on peak-to-peak thresholds. Bad segments of data can also be rejected
by marking segments of raw data with annotations. See
:ref:`tut-reject-data-spans` and :class:`mne.Annotations` for more .
Once the :class:`mne.Epochs` are constructed, they can be averaged to obtain
:class:`mne.Evoked` data as::
>>> evoked = epochs.average() # doctest: +SKIP
Source localization
===================
MNE makes extensive use of the FreeSurfer file structure for analysis.
Before starting data analysis, we recommend setting up the environment
variable ``SUBJECTS_DIR`` (or set it permanently using :func:`mne.set_config`)
to select the directory under which the anatomical MRI data are stored.
This makes it so that the ``subjects_dir`` argument does not need to
be passed to many functions.
Anatomical information
----------------------
.. _CHDBBCEJ:
Cortical surface reconstruction with FreeSurfer
###############################################
The first processing stage is the creation of various surface
reconstructions with FreeSurfer. The recommended FreeSurfer workflow
is summarized on the `FreeSurfer wiki pages <https://surfer.nmr.mgh.harvard.edu/fswiki/RecommendedReconstruction>`_. See
also this information :ref:`tut-freesurfer-reconstruction`.
.. _setting_up_source_space:
Setting up the source space
###########################
This stage consists of the following:
- Creating a suitable decimated dipole grid on the white matter surface.
- Creating the source space file in fif format.
This is accomplished with using :func:`mne.setup_source_space` and
:func:`mne.write_source_spaces`. These assume that the anatomical MRI processing
has been completed as described in :ref:`CHDBBCEJ`.
.. _BABGCDHA:
.. table:: Recommended subdivisions of an icosahedron and an octahedron for
the creation of source spaces. The approximate source spacing and
corresponding surface area have been calculated assuming a
1000-cm2 surface area per hemisphere.
=========== ====================== =================== =============================
``spacing`` Sources per hemisphere Source spacing / mm Surface area per source / mm2
=========== ====================== =================== =============================
``'oct5'`` 1026 9.9 97
``'ico4'`` 2562 6.2 39
``'oct6'`` 4098 4.9 24
``'ico5'`` 10242 3.1 9.8
=========== ====================== =================== =============================
For example, to create the reconstruction geometry for ``subject='sample'``
with a ~5-mm spacing between the grid points, say::
>>> src = setup_source_space('sample', spacing='oct6') # doctest: +SKIP
>>> write_source_spaces('sample-oct6-src.fif', src) # doctest: +SKIP
This creates the source spaces and writes them to disk.
:ref:`plot_forward_source_space` illustrates how the source space is used to
compute the forward model.
.. _CHDBJCIA:
Creating the BEM model meshes
#############################
Calculation of the forward solution using the boundary-element
model (BEM) requires that the surfaces separating regions of different
electrical conductivities are tessellated with suitable surface
elements. Our BEM software employs triangular tessellations. Therefore,
prerequisites for BEM calculations are the segmentation of the MRI
data and the triangulation of the relevant surfaces.
For MEG computations, a reasonably accurate solution can
be obtained by using a single-compartment BEM assuming the shape
of the intracranial volume. For EEG, the standard model contains
the intracranial space, the skull, and the scalp.
At present, no bulletproof method exists for creating the
triangulations. Feasible approaches are described in :ref:`bem-model`.
.. _BABDBBFC:
Setting up the head surface triangulation files
###############################################
The segmentation algorithms described in :ref:`bem-model` produce
either FreeSurfer surfaces or triangulation
data in text. Before proceeding to the creation of the boundary
element model, standard files for FreeSurfer surfaces must be present:
1. **inner_skull.surf** contains the inner skull triangulation.
2. **outer_skull.surf** contains the outer skull triangulation.
3. **outer_skin.surf** contains the head surface triangulation.
.. _CIHDBFEG:
Setting up the boundary-element model
#####################################
This stage sets up the subject-dependent data for computing
the forward solutions:"
>>> model = make_bem_model('sample') # doctest: +SKIP
>>> write_bem_surfaces('sample-5120-5120-5120-bem.fif', model) # doctest: +SKIP
Where ``surfaces`` is a list of BEM surfaces that have each been read using
:func:`mne.read_surface`. This step also checks that the input surfaces
are complete and that they are topologically correct, *i.e.*,
that the surfaces do not intersect and that the surfaces are correctly
ordered (outer skull surface inside the scalp and inner skull surface
inside the outer skull).
This step assigns the conductivity values to the BEM compartments.
For the scalp and the brain compartments, the default is 0.3 S/m.
The default skull conductivity is 50 times smaller, *i.e.*,
0.006 S/m. Recent publications report a range of skull conductivity ratios
ranging from 1:15 :footcite:`OostendorpEtAl2000` to 1:25 - 1:50
:footcite:`GoncalvesEtAl2003,LewEtAl2009`. The MNE default ratio 1:50 is based
on the typical values reported in :footcite:`GoncalvesEtAl2003`, since their
approach is based on comparison of SEF/SEP measurements in a BEM model.
The variability across publications may depend on individual variations
but, more importantly, on the precision of the skull compartment
segmentation.
.. note:: To produce single layer BEM models (--homog flag in the C command
line tools) pass a list with one single conductivity value,
e.g. ``conductivities=[0.3]``.
Using this model, the BEM solution can be computed using
:func:`mne.make_bem_solution` as::
>>> bem_sol = make_bem_solution(model) # doctest: +SKIP
>>> write_bem_solution('sample-5120-5120-5120-bem-sol.fif', bem_sol) # doctest: +SKIP
After the BEM is set up it is advisable to check that the
BEM model meshes are correctly positioned using *e.g.*
:func:`mne.viz.plot_alignment` or :class:`mne.Report`.
.. note:: Up to this point all processing stages depend on the
anatomical (geometrical) information only and thus remain
identical across different MEG studies.
.. note:: If you use custom head models you might need to set the ``ico=None``
parameter to ``None`` and skip subsampling of the surface.
.. _CHDBEHDC:
Aligning coordinate frames
--------------------------
The calculation of the forward solution requires knowledge
of the relative location and orientation of the MEG/EEG and MRI
coordinate systems (see :ref:`head_device_coords`). The head coordinate
frame is defined by identifying the fiducial landmark locations,
making the origin and orientation of the head coordinate system
slightly user dependent. As a result, it is safest to reestablish
the definition of the coordinate transformation computation
for each experimental session, *i.e.*, each time when new head
digitization data are employed.
The corregistration is stored in ``-trans.fif`` file. If is present,
you can follow :ref:`tut-source-alignment` to validate its correctness.
If the ``-trans.fif`` is not present or the alignment is not correct
you need to use :func:`mne.gui.coregistration` (or its convenient command line
equivalent :ref:`mne coreg`) to generate it.
.. XXX: It would be good to link to the ``-trans.fif`` file description
.. warning:: This step is important. If the alignment of the
coordinate frames is inaccurate all subsequent processing
steps suffer from the error. Therefore, this step should be
performed by the person in charge of the study or by a trained
technician. Written or photographic documentation of the alignment
points employed during the MEG/EEG acquisition can also be
helpful.
.. _computing_the_forward_solution:
Computing the forward solution
------------------------------
After the MRI-MEG/EEG alignment has been set, the forward
solution, *i.e.*, the magnetic fields and electric
potentials at the measurement sensors and electrodes due to dipole
sources located on the cortex, can be calculated with help of
:func:`mne.make_forward_solution` as::
>>> fwd = make_forward_solution(raw.info, fname_trans, src, bem_sol) # doctest: +SKIP
Computing the noise-covariance matrix
-------------------------------------
The MNE software employs an estimate of the noise-covariance
matrix to weight the channels correctly in the calculations. The
noise-covariance matrix provides information about field and potential
patterns representing uninteresting noise sources of either human
or environmental origin.
The noise covariance matrix can be calculated in several
ways:
- Employ the individual epochs during
off-line averaging to calculate the full noise covariance matrix.
This is the recommended approach for evoked responses, *e.g.* using
:func:`mne.compute_covariance`::
>>> cov = mne.compute_covariance(epochs, method='auto') # doctest: +SKIP
- Employ empty room data (collected without the subject) to
calculate the full noise covariance matrix. This is recommended
for analyzing ongoing spontaneous activity. This can be done using
:func:`mne.compute_raw_covariance` as::
>>> cov = mne.compute_raw_covariance(raw_erm) # doctest: +SKIP
- Employ a section of continuous raw data collected in the presence
of the subject to calculate the full noise covariance matrix. This
is the recommended approach for analyzing epileptic activity. The
data used for this purpose should be free of technical artifacts
and epileptic activity of interest. The length of the data segment
employed should be at least 20 seconds. One can also use a long
(``*> 200 s``) segment of data with epileptic spikes present provided
that the spikes occur infrequently and that the segment is apparently
stationary with respect to background brain activity. This can also
use :func:`mne.compute_raw_covariance`.
.. _CIHCFJEI:
Calculating the inverse operator
--------------------------------
The MNE software doesn't calculate the inverse operator
explicitly but rather computes an SVD of a matrix composed of the
noise-covariance matrix, the result of the forward calculation,
and the source covariance matrix. This approach has the benefit
that the regularization parameter ('SNR') can
be adjusted easily when the final source estimates or dSPMs are
computed. For mathematical details of this approach,
please consult :ref:`minimum_norm_estimates`.
This computation stage can be done by using
:func:`mne.minimum_norm.make_inverse_operator` as::
>>> inv = mne.minimum_norm.make_inverse_operator(raw.info, fwd, cov, loose=0.2) # doctest: +SKIP
Creating source estimates
-------------------------
Once all the preprocessing steps described above have been
completed, the inverse operator computed can be applied to the MEG
and EEG data as::
>>> stc = mne.minimum_norm.apply_inverse(evoked, inv, lambda2=1. / 9.) # doctest: +SKIP
And the results can be viewed as::
>>> stc.plot() # doctest: +SKIP
Group analyses
--------------
Group analysis is facilitated by morphing source estimates, which can be
done *e.g.*, to ``subject='fsaverage'`` as::
>>> morph = mne.compute_source_morph(stc, subject_from='sample', subject_to='fsaverage') # doctest: +SKIP
>>> stc_fsaverage = morph.apply(stc) # doctest: +SKIP
See :ref:`ch_morph` for more information.
References
==========
.. footbibliography::
|