/
ica_var.py
35 lines (28 loc) · 882 Bytes
/
ica_var.py
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
import click
from mne.preprocessing import read_ica
import contextlib
import sys
import cStringIO
@contextlib.contextmanager
def nostdout():
save_stdout = sys.stdout
sys.stdout = cStringIO.StringIO()
yield
sys.stdout = save_stdout
@click.command()
@click.argument('subjdirs', nargs=-1)
def cli(subjdirs):
"""
Show the variance explained for mne ica solution
EXAMPLES:
Show explained variances for ica solutions for each subject in FIF_DATASET and write them to file vars.txt:
$ ica_var FIF_DATASET/*/*-ica.fif >> vars.txt
"""
for fname in subjdirs:
with nostdout():
ica = read_ica(fname)
n_comp = ica.n_components_
tot_var = ica.pca_explained_variance_.sum()
n_comp_var = ica.pca_explained_variance_[:n_comp].sum()
PVE = n_comp_var / tot_var
click.echo(PVE)