mne.time_frequency.tfr_morlet#
- mne.time_frequency.tfr_morlet(inst, freqs, n_cycles, use_fft=False, return_itc=True, decim=1, n_jobs=None, picks=None, zero_mean=True, average=True, output='power', verbose=None)[source]#
Compute Time-Frequency Representation (TFR) using Morlet wavelets.
Same computation as
tfr_array_morlet
, but operates onEpochs
orEvoked
objects instead ofNumPy arrays
.- Parameters
- inst
Epochs
|Evoked
The epochs or evoked object.
- freqs
array
offloat
, shape (n_freqs,) The frequencies of interest in Hz.
- n_cycles
int
|array
ofint
, shape (n_freqs,) Number of cycles in the wavelet, either a fixed number or one per frequency. The number of cycles
n_cycles
and the frequencies of interestfreqs
define the temporal window length. See notes for additional information about the relationship between those arguments and about time and frequency smoothing.- use_fft
bool
, defaultFalse
The fft based convolution or not.
- return_itc
bool
, defaultTrue
Return inter-trial coherence (ITC) as well as averaged power. Must be
False
for evoked data.- decim
int
|slice
, default 1 To reduce memory usage, decimation factor after time-frequency decomposition.
Note
Decimation is done after convolutions and may create aliasing artifacts.
- n_jobs
int
|None
The number of jobs to run in parallel. If
-1
, it is set to the number of CPU cores. Requires thejoblib
package.None
(default) is a marker for ‘unset’ that will be interpreted asn_jobs=1
(sequential execution) unless the call is performed under ajoblib.parallel_config
context manager that sets another value forn_jobs
.- picksarray_like of
int
|None
, defaultNone
The indices of the channels to decompose. If None, all available good data channels are decomposed.
- zero_mean
bool
, defaultTrue
Make sure the wavelet has a mean of zero.
New in v0.13.0.
- average
bool
, defaultTrue
If
False
return anEpochsTFR
containing separate TFRs for each epoch. IfTrue
return anAverageTFR
containing the average of all TFRs across epochs.Note
Using
average=True
is functionally equivalent to usingaverage=False
followed byEpochsTFR.average()
, but is more memory efficient.New in v0.13.0.
- output
str
Can be
"power"
(default) or"complex"
. If"complex"
, thenaverage
must beFalse
.New in v0.15.0.
- verbose
bool
|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.
- inst
- Returns
- power
AverageTFR
|EpochsTFR
The averaged or single-trial power.
- itc
AverageTFR
|EpochsTFR
The inter-trial coherence (ITC). Only returned if return_itc is True.
- power
See also
Notes
The Morlet wavelets follow the formulation in 1.
In spectrotemporal analysis (as with traditional fourier methods), the temporal and spectral resolution are interrelated: longer temporal windows allow more precise frequency estimates; shorter temporal windows “smear” frequency estimates while providing more precise timing information.
Time-frequency representations are computed using a sliding temporal window. Either the temporal window has a fixed length independent of frequency, or the temporal window decreases in length with increased frequency.
Figure: Time and frequency smoothing. (a) For a fixed length temporal window the time and frequency smoothing remains fixed. (b) For temporal windows that decrease with frequency, the temporal smoothing decreases and the frequency smoothing increases with frequency. Source: FieldTrip tutorial: Time-frequency analysis using Hanning window, multitapers and wavelets.
In MNE-Python, the temporal window length is defined by the arguments
freqs
andn_cycles
, respectively defining the frequencies of interest and the number of cycles: \(T = \frac{\mathtt{n\_cycles}}{\mathtt{freqs}}\)A fixed number of cycles for all frequencies will yield a temporal window which decreases with frequency. For example,
freqs=np.arange(1, 6, 2)
andn_cycles=2
yieldsT=array([2., 0.7, 0.4])
.To use a temporal window with fixed length, the number of cycles has to be defined based on the frequency. For example,
freqs=np.arange(1, 6, 2)
andn_cycles=freqs / 2
yieldsT=array([0.5, 0.5, 0.5])
.Convolution of a signal with a Morlet wavelet will impose temporal smoothing that is determined by the duration of the wavelet. In MNE-Python, the duration of the wavelet is determined by the
sigma
parameter, which gives the standard deviation of the wavelet’s Gaussian envelope (our wavelets extend to ±5 standard deviations to ensure values very close to zero at the endpoints). Some authors (e.g., 2) recommend specifying and reporting wavelet duration in terms of the full-width half-maximum (FWHM) of the wavelet’s Gaussian envelope. The FWHM is related tosigma
by the following identity: \(\mathrm{FWHM} = \sigma \times 2 \sqrt{2 \ln{2}}\) (or the equivalent in Python code:fwhm = sigma * 2 * np.sqrt(2 * np.log(2))
). Ifsigma
is not provided, it is computed fromn_cycles
as \(\frac{\mathtt{n\_cycles}}{2 \pi f}\) where \(f\) is the frequency of the wavelet oscillation (given byfreqs
). Thus whensigma=None
the FWHM will be given by\[\mathrm{FWHM} = \frac{\mathtt{n\_cycles} \times \sqrt{2 \ln{2}}}{\pi \times f}\](cf. eq. 4 in 2). To create wavelets with a chosen FWHM, one can compute:
n_cycles = desired_fwhm * np.pi * np.array(freqs) / np.sqrt(2 * np.log(2))
to get an array of values for
n_cycles
that yield the desired FWHM at each frequency infreqs
. If you want different FWHM values at each frequency, do the same computation withdesired_fwhm
as an array of the same shape asfreqs
.See
mne.time_frequency.morlet()
for more information about the Morlet wavelet.References
- 1
Catherine Tallon-Baudry, Olivier Bertrand, Claude Delpuech, and Jacques Pernier. Oscillatory Gamma-Band (30–70 Hz) Activity Induced by a Visual Search Task in Humans. Journal of Neuroscience, pages 722–734, 1997. doi:10.1523/JNEUROSCI.17-02-00722.1997.
- 2(1,2)
Michael X Cohen. A better way to define and describe Morlet wavelets for time-frequency analysis. NeuroImage, 199:81–86, 2019. doi:10.1016/j.neuroimage.2019.05.048.
Examples using mne.time_frequency.tfr_morlet
#
Overview of MEG/EEG analysis with MNE-Python
Frequency and time-frequency sensor analysis
Non-parametric 1 sample cluster statistic on single trial power
Non-parametric between conditions cluster statistic on single trial power
Mass-univariate twoway repeated measures ANOVA on single trial power
Spatiotemporal permutation F-test on full sensor data
Time-frequency on simulated data (Multitaper vs. Morlet vs. Stockwell vs. Hilbert)
Compute source level time-frequency timecourses using a DICS beamformer