-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpop_plotIMtimecourse_study.m
152 lines (128 loc) · 7.08 KB
/
pop_plotIMtimecourse_study.m
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
% plot original IC time-frequency decomposition, PC time-frequency backprojection, IM time-frequency backprojection and IM
% weights
%
%
% pop_plotIMtimecourse_study(STUDY,varargin)
%
% Author: Johanna Wagner, Swartz Center for Computational Neuroscience, UC San Diego, 2019
% adapted from functions written by Julie Onton
%
%
%
% Example: for subject 4 and all conditions plot components 1, 5 and 8 with frequency limit 6-40Hz and smoothing 0.1
% - plot only IC time-frequency decomposition and PC time-frequency backprojections
%
% >> pop_plotIMtimecourse_study(STUDY, 'subject', 'S4','comps', [1 5 8],...
% 'frqlim', [6 40], 'plotcond', 'on', 'plotICtf', 'on', 'plotPCtf', 'on')
%
%
% Example: for subject 5 and all conditions plot components 3, 5 and 6 and IMs 2, 6 and 9 with frequency limit 6-40Hz and smoothing 0.1
% plot only IM time-frequency backprojections on ICs and IM weight
% timecourses
%
% >> pop_plotIMtimecourse_study(STUDY, 'subject', 'S5','comps', [3 5 6], 'factors', [2 6 9],...
% 'frqlim', [6 40], 'plotcond', 'on','smoothing', 40, 'plotIMtf', 'on', 'plotIMtime', 'on')
%
% INPUTS:
% STUDY - STUDY structure pointing to precomputed IMA information and EEG
% datasets
% subject - subject to plot - provide subject code/number as string i.e. 'S3'
% if empty plots results for all subjects in the study
% comps - [vector] independent components to plot - if empty plots all
% the independent components for a subject
% factors - [vector] IMs to plot - if empty plots all the IMs for a subject% frqlim - [min max] frequency limits for plotting
% frqlim - [min max] frequency limits for plotting
% plotcond - [string] 'off' or 'on' (default 'off'). If IMA over different
% conditions was computed plots a vertical line in between conditions and
% plots conditions in different colors for IM weights plotting
% smoothing - [integer] how many timepoints to use for moving average for
% smoothing. A higher number means more smoothing. default 40
% plotICtf - [string] {'on' 'off'} plot IC time-frequency decomposition, default 'off'
% plotPCtf - [string] {'on' 'off'} plot PC time-frequency backprojection, default 'off'
% plotIMtf - [string] {'on' 'off'} plot IM time-frequency backprojection, default 'off'
% plotIMtime - [string] {'on' 'off'} plot IM weights timecourse, default 'off'
function pop_plotIMtimecourse_study(STUDY,varargin)
g = finputcheck(varargin, { 'subject' 'string' {} ''; ...
'comps' 'integer' [] []; ...
'factors' 'integer' [] []; ...
'frqlim' 'real' [] []; ...
'plotcond' 'string' {'on' 'off'} 'off';...
'smoothing' 'integer' [] [40];...
'plotICtf' 'string' {'on' 'off'} 'off';...
'plotPCtf' 'string' {'on' 'off'} 'off';...
'plotIMtf' 'string' {'on' 'off'} 'off';...
'plotIMtime' 'string' {'on' 'off'} 'off';...
}, 'inputgui');
if isstr(g), error(g); end;
if ~isfield(STUDY.etc, 'IMA'), return; end
try
tmpIMA = load([STUDY.etc.IMA.imafilepath{1} filesep STUDY.etc.IMA.imafilename{1}], '-mat');
catch
return;
end
if nargin ==1
subjcallback = ['subjindx = get(findobj(''Tag'', ''subjname''),''value'');'...
'tmpIMA = load([STUDY.etc.IMA.imafilepath{subjindx} filesep STUDY.etc.IMA.imafilename{subjindx}], ''-mat'');'...
'ic_list = sprintfc(''%d'',tmpIMA.IMA.complist);'...
'im_list = sprintfc(''%d'',[1:tmpIMA.IMA.npcs]);'...
'set(findobj(''Tag'', ''icindx''), ''string'', ic_list);'...
'set(findobj(''Tag'', ''imindx''), ''string'', im_list);'];
subj_list = STUDY.etc.IMA.subject;
plotTypes2funtc = {'plotICtf', 'plotPCtf', 'plotIMtfims', 'plotIMtime'};
plotTypes = {'IC spectrogram', 'Summed IM backprojection', 'Combined IC-IM spectrogram', 'IM timecourse'};
freqLim = tmpIMA.IMA.freqlim;
ic_list = sprintfc('%d',tmpIMA.IMA.complist);
im_list = sprintfc('%d',[1:tmpIMA.IMA.npcs]);
plotopt = repmat({'off'}, 1,4);
uilist = {{'style' 'text' 'string' 'Subject'} {'style' 'popupmenu' 'string' subj_list 'tag' 'subjname' 'value' 1 'callback' subjcallback}...
{'style' 'text' 'string' 'Plot type'} {'style' 'popupmenu' 'string' plotTypes 'tag' 'plottype' 'value' 1}...
{'style' 'text' 'string' 'Freq. limits (Hz)'} {'style' 'edit' 'string' num2str(freqLim) 'tag' 'freqlimits'}...
{'style' 'text' 'string' 'Select ICs', } {'style' 'text' 'string' 'Select IMs'} ...
{'style' 'list' 'string' ic_list 'max',200,'min',1,'Tag','icindx'} {'style' 'list' 'string' im_list 'max',200,'min',1,'Tag','imindx' } {}};
ht = 7; wt = 2 ;
geom = {{wt ht [0 0] [1 1]} {wt ht [1 0] [1 1]}...
{wt ht [0 1] [1 1]} {wt ht [1 1] [1 1]}...
{wt ht [0 2] [1 1]} {wt ht [1 2] [1 1]}...
{wt ht [0 3] [1 1]} {wt ht [1 3] [1 1]}...
{wt ht [0 4] [1 3]} {wt ht [1 4] [1 3]}...
{wt ht [0 5] [1 3]}};
[result, ~, ~, resstruct, ~] = inputgui('title','Plot IM timecourse -- pop_plotIMtimecourse_study', 'geom', geom, 'uilist',uilist, 'helpcom','pophelp(''pop_plotspecdecomp'');');
if isempty(result), return; end;
g.subject = subj_list{resstruct.subjname};
indsj = find(ismember(STUDY.subject, g.subject));
%% load IMA file
tmpIMA = load([STUDY.etc.IMA.imafilepath{indsj} filesep STUDY.etc.IMA.imafilename{indsj}], '-mat' );
g.comps = tmpIMA.IMA.complist(resstruct.icindx);
g.factors = resstruct.imindx;
g.frqlim = str2num(resstruct.freqlimits);
plotopt{resstruct.plottype} = 'on';
end
%% check which subject/s to plot
%% getting activations
if isempty(g.subject)
subjcode = STUDY.subject{1};
else
subjcode = {g.subject};
end
%% allows plotting only one subject at a time
%for iko = 1:length(subjcode)
%indsj = find(ismember(STUDY.subject, subjcode{iko}));
indsj = find(ismember(STUDY.subject, subjcode));
%% load IMA file
load([STUDY.etc.IMA.imafilepath{indsj} filesep STUDY.etc.IMA.imafilename{indsj}], '-mat' );
EEG = pop_loadset('filename',IMA.subjfilename{1},'filepath',IMA.subjfilepath{1});
%% check if frequency limits, comps and IMs are empty
if isempty(g.frqlim)
g.frqlim = IMA.freqlim;
end
if isempty(g.comps)
g.comps = IMA.complist;
end
if isempty(g.factors)
g.factors = 1:IMA.npcs;
end
plotIMtimecourse(tmpIMA.IMA, EEG, 'comps',g.comps, 'factors', g.factors, 'frqlim', g.frqlim,...
'smoothing', g.smoothing,...
'plotICtf',plotopt{1}, 'plotPCtf', plotopt{2},...
'plotIMtf', plotopt{3}, 'plotIMtime', plotopt{4}, 'plotcond','on');
end