File: test_proc_history.py

package info (click to toggle)
python-mne 0.19.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 100,440 kB
  • sloc: python: 120,243; pascal: 1,861; makefile: 225; sh: 15
file content (38 lines) | stat: -rw-r--r-- 1,395 bytes parent folder | download | duplicates (2)
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
# Authors: Denis A. Engemann <denis.engemann@gmail.com>
#          Eric Larson <larson.eric.d@gmail.com>
# License: Simplified BSD

import os.path as op

import numpy as np
from numpy.testing import assert_array_equal

from mne.io import read_info
from mne.io.constants import FIFF

base_dir = op.join(op.dirname(__file__), 'data')
raw_fname = op.join(base_dir, 'test_chpi_raw_sss.fif')


def test_maxfilter_io():
    """Test maxfilter io."""
    info = read_info(raw_fname)
    mf = info['proc_history'][1]['max_info']

    assert mf['sss_info']['frame'] == FIFF.FIFFV_COORD_HEAD
    # based on manual 2.0, rev. 5.0 page 23
    assert 5 <= mf['sss_info']['in_order'] <= 11
    assert mf['sss_info']['out_order'] <= 5
    assert mf['sss_info']['nchan'] > len(mf['sss_info']['components'])

    assert (info['ch_names'][:mf['sss_info']['nchan']] ==
            mf['sss_ctc']['proj_items_chs'])
    assert (mf['sss_ctc']['decoupler'].shape ==
            (mf['sss_info']['nchan'], mf['sss_info']['nchan']))
    assert_array_equal(
        np.unique(np.diag(mf['sss_ctc']['decoupler'].toarray())),
        np.array([1.], dtype=np.float32))
    assert mf['sss_cal']['cal_corrs'].shape == (306, 14)
    assert mf['sss_cal']['cal_chans'].shape == (306, 2)
    vv_coils = [v for k, v in FIFF.items() if 'FIFFV_COIL_VV' in k]
    assert all(k in vv_coils for k in set(mf['sss_cal']['cal_chans'][:, 1]))