-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpop_runIMA_study.m
524 lines (445 loc) · 26.3 KB
/
pop_runIMA_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
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
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
%
% Selects components using IC label, performs time-frequency decomposition, PCA and runs Independent Modulator
% Analysis (IMA) over conditions for each subject in a study
%
%[STUDY] = pop_runIMA_study(STUDY,varargin)
%
% Author: Johanna Wagner, Swartz Center for Computational Neuroscience, UC San Diego, 2019
% adapted from a function written by Julie Onton
%
%% Example computing IMA over all subjects contained in study selecting only brain ICs using IC label, with
% parameters for time-frequency decomposition: log scale, frequency limit 6
% to 120Hz, wavelet cycles [6 0.5], reducing the dimensions of timewindows
% of the tf decomposition using pfac 8 (for a description of pfac see
% below), and using AMICA as the ica algorithm for IMA
%
% >> [IMA] = pop_runIMA_study(STUDY, ALLEEG, 'selectICs', {'brain'}, 'freqscale', 'log', 'frqlim', [6 120], 'cycles', [6 0.5], 'pcfac', 8,...
% 'icatype', 'amica')
%
%
% INPUTS:
% STUDY - STUDY structure with information on stored IMA files
% ALLEEG - ALLEEG structure
% subject - subject to compute IMA on - provide subject code/number as string i.e. '3'
% if empty computes results for all subjects in the study
% frqlim -- [minfrq maxfrq] minimum and maximum frequencies to include in spectral decomposition
% freqscale -- ['linear',or 'log']
% pcfac -- [integer] - regulates the dimension that the time windows of the spectral data will
% be reduced to before IMA - the smaller pcfac, the more dimensions will be
% retained ndims = (freqs*ICs)/pcfac where freqs is the number of estimated
% frequencies and ICs is the number of ICs (default is 10)
% epochlength -- [number] if data is not epoched size of data epoch in seconds (default 4)
% selectICs -- ['cell'] select ICs with IC label can be {'brain' 'muscle' 'eye' 'artefact' 'off'}
% several categories can be chosen at once default {'off'};...
% iclthreshold -- [number between 0 and 1] defines the thersold for IC label to select the components
% specified in 'selectICs' a higher number indicates a stricter threshold default [0.7]
% usedip -- ['string'] {'on' 'off'} use dipole residual variance (RV) in addition to ICLabel to select
% brain components, default {'on'}
% dipthreshold -- 'real' [number between 0 and 1] which cutoff to use for dipole RV for selecting brain
% components default [0.15];...
% icatype -- ['string'] which ICA algorithm to run {'amica' 'infomax'} (default 'infomax')
%
%% time frequency decomposition parameters see also newtimef()
% cycles -- [real] indicates the number of cycles for the time-frequency
% decomposition {default: 0}
% If 0, use FFTs and Hanning window tapering.
% If [real positive scalar], the number of cycles in each Morlet
% wavelet, held constant across frequencies.
% If [cycles cycles(2)] wavelet cycles increase with
% frequency beginning at cycles(1) and, if cycles(2) > 1,
% increasing to cycles(2) at the upper frequency,
% If cycles(2) = 0, use same window size for all frequencies
% (similar to FFT when cycles(1) = 1)
% If cycles(2) = 1, cycles do not increase (same as giving
% only one value for 'cycles'). This corresponds to a pure
% wavelet decomposition, same number of cycles at each frequency.
% If 0 < cycles(2) < 1, cycles increase linearly with frequency:
% from 0 --> FFT (same window width at all frequencies)
% to 1 --> wavelet (same number of cycles at all frequencies).
% The exact number of cycles in the highest frequency window is
% indicated in the command line output. Typical value: 'cycles', [3 0.5]
% overlapfac -- [number between 0 and 1] percentage by which to overlap
% timewindows a larger number means larger overlap - default 0.6
% nfreqs -- number of output frequencies. For FFT, closest computed
% frequency will be returned. Overwrite 'padratio' effects
% for wavelets. {default: use 'padratio'}
% padratio -- FFT-length/winframes (2^k) {default: 4}
% Multiplies the number of output frequencies by dividing
% their spacing (standard FFT padding). When cycles~=0,
% frequency spacing is divided by padratio.
% wletmethod --['dftfilt'|'dftfilt2'|'dftfilt3'] Wavelet type to use.
% 'dftfilt2' -> Morlet-variant wavelets, or Hanning DFT.
% 'dftfilt3' -> Morlet wavelets. See the timefreq() function
% for more details {default: 'dftfilt3'}
% winsize -- [integer] in sec size of timwindows to use for time-frequency decomposition
% needs to be smaller than epochsize. Note: this parameter
% is overwritten when the minimum frequency and number of cycles requires
% a longer time window. {default: cycles*(length of a cycle at lowest freq in sec)}
%
%
%%% OUTPUT
% STUDY structure with fields under STUDY.etc.IMA.imafilename and STUDY.etc.IMA.imafilepath
% pointing to the .ima files and filepaths for each subject;
% IMA - structure with fields of IMA output (see detailed description below)
% results are saved subjectwise in the original subject folder with the extension .ima
% this file has the same properties as a .mat file and can be loaded in Matlab using
% load(['filename.ima'], '-mat' )
%
%
% Detailed description of IMA output structure:
% IMA.wts - weights of IMA decomposition
% IMA.sph - spheres of IMA decomposition
% IMA.meanpwr - mean power spectra of single ICs
% IMA.timevec - timevector
% IMA.freqvec - frequency vector
% IMA.freqscale - frequency scale of computed spectra ('log' or 'linear')
% IMA.freqlim - frequency limits of spectra
% IMA.npcs - number of dimensions that have been used to reduce the data before IMA
% IMA.complist - component indices on which IMA was run on
% IMA.srate - original sampling rate of EEG data used to compute the spectra
% IMA.ntrials - number of trials used to commpute the time-frequency decomposition
% IMA.ntw_trials - number of timewindows per trial
% IMA.winsize - window length for computing spectra in the time-frequency decomposition
% IMA.epochlength - epochlength used for computing time-frequency decomposition in seconds*
% IMA.eigvec - pc backprojection in time
% IMA.pc - pc spectral backprojection
% IMA.timefreq - time-frequency decomposition (spectograms for each IC)
% IMA.timepntCond - total number of timepoints in time-frequency
% decomposition in each condition
% IMA.timevec_cond - timevector of full length of time-frequency
% decomposition for each condition
% IMA.meanpwrCond - mean power spectra for each IC and each condition
% IMA.condition - names and order of conditions
% IMA.STUDYname - filename of the STUDY the IMA decomposition belongs to
% IMA.STUDYfilepath - filepath of the STUDY the IMA decomposition belongs to
% IMA.subj - subject the IMA has been comuted on
% IMA.subjfilename - filenames of the EEG data the IMA has been computed on
% IMA.subjfilepath - filepath of the EEG data the IMA has been computed on
function [STUDY] = pop_runIMA_study(STUDY,ALLEEG, varargin)
g = finputcheck(varargin, {'frqlim' 'real' [] []; ...
'freqscale' 'string' {'linear' 'log'} 'log';...
'pcfac' 'integer' [] 7;...
'cycles' 'real' [] [3 0.5];...
'overlapfac' 'real' [] [0.8];...
'nfreqs' 'integer' [] [];...
'padratio' 'integer' [] [4];...
'wletmethod' 'string' {'dftfilt' 'dftfilt2' 'dftfilt3'} 'dftfilt3';...
'winsize' 'integer' [] [];...
'epochlength' 'real' [] [];...
'selectICs' 'cell' {'brain' 'muscle' 'eye' 'artefact' 'off'} {'off'};...
'iclthreshold_brain' 'real' [] [0.7];...
'iclthreshold_muscle' 'real' [] [0.7];...
'iclthreshold_eye' 'real' [] [0.7];...
'iclthreshold_artefact' 'real' [] [0.7];...
'usedip' 'string' {'on' 'off'} 'on';...
'dipthreshold' 'real' [] [0.15];...
'icatype' 'string' {'amica' 'infomax'} 'infomax'...
}, 'inputgui');
if isstr(g), error(g); end;
% Check if ICLABEL is installed
try PLUGINLIST = evalin('base', 'PLUGINLIST'); catch, PLUGINLIST = []; end
if ~isempty(PLUGINLIST) && isfield(PLUGINLIST, 'plugin')
indPlugin = strmatch(lower('ICLabel'), lower({ PLUGINLIST.plugin }), 'exact');
end
flag_iclabel = 1;
if indPlugin == 0
flag_iclabel = plugin_askinstall('ICLabel');
end
if nargin<3
freqlim_def = [3 ALLEEG(1).srate/2-10];
iclabel_list = {'Brain', 'Muscle', 'Eye', 'Heart'};
freqscale_list = {'linear' 'log'} ;
if flag_iclabel
cb_chbx_iclabel = ['val_chbx_iclabel = get(findobj(''Tag'', ''chbx_iclabel''), ''Value'');' ...
'if ~val_chbx_iclabel,'...
'set(findobj(''Tag'', ''chbx_iclabel''), ''Value'', 0);'...
'set(findobj(''Tag'', ''chbx_brain''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''chbx_muscle''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''chbx_eye''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''chbx_heart''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''ed_brainthrs''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''ed_musclethrs''),''enable'', ''off'');'...
'set(findobj(''Tag'', ''ed_eyethrs''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''ed_heartthrs''), ''enable'', ''off'');'...
'else;'...
'set(findobj(''Tag'', ''chbx_iclabel''), ''Value'', 1);'...
'set(findobj(''Tag'', ''chbx_brain''), ''enable'', ''on'');'...
'set(findobj(''Tag'', ''chbx_muscle''), ''enable'', ''on'');'...
'set(findobj(''Tag'', ''chbx_eye''), ''enable'', ''on'');'...
'set(findobj(''Tag'', ''chbx_heart''), ''enable'', ''on'');'...
'set(findobj(''Tag'', ''ed_brainthrs''), ''enable'', ''on'');'...
'set(findobj(''Tag'', ''ed_musclethrs''),''enable'', ''on'');'...
'set(findobj(''Tag'', ''ed_eyethrs''), ''enable'', ''on'');'...
'set(findobj(''Tag'', ''ed_heartthrs''), ''enable'', ''on'');'...
'end;'];
else
cb_chbx_iclabel = ['set(findobj(''Tag'', ''chbx_iclabel''), ''Value'', 0);'...
'set(findobj(''Tag'', ''chbx_brain''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''chbx_muscle''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''chbx_eye''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''chbx_heart''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''ed_brainthrs''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''ed_musclethrs''),''enable'', ''off'');'...
'set(findobj(''Tag'', ''ed_eyethrs''), ''enable'', ''off'');'...
'set(findobj(''Tag'', ''ed_heartthrs''), ''enable'', ''off'');'];
end
uilist = {{'style' 'text' 'string' 'Select ICs'}...
{ 'style' 'Checkbox' 'string' 'ICLabel tags' 'Tag', 'chbx_iclabel', 'callback', cb_chbx_iclabel 'Value' 0} {'style' 'text' 'string' 'Labels'} {'style' 'text' 'string' 'Threshold (%)'}...
{ 'style' 'Checkbox' 'string' iclabel_list{1} 'Tag', 'chbx_brain', 'Value' 0, 'enable', 'off'} {'style' 'edit' 'string' num2str(g.iclthreshold_brain) 'tag' 'ed_brainthrs', 'enable', 'off'}...
{ 'style' 'Checkbox' 'string' iclabel_list{2} 'Tag', 'chbx_muscle', 'Value' 0, 'enable', 'off'} {'style' 'edit' 'string' num2str(g.iclthreshold_muscle) 'tag' 'ed_musclethrs' 'enable', 'off'}...
{ 'style' 'Checkbox' 'string' iclabel_list{3} 'Tag', 'chbx_eye', 'Value' 0, 'enable', 'off'} {'style' 'edit' 'string' num2str(g.iclthreshold_eye) 'tag' 'ed_eyethrs' 'enable', 'off'}...
{ 'style' 'Checkbox' 'string' iclabel_list{4} 'Tag', 'chbx_heart', 'Value' 0, 'enable', 'off'} {'style' 'edit' 'string' num2str(g.iclthreshold_artefact) 'tag' 'ed_heartthrs' 'enable', 'off'}...
{}...
{'style' 'text' 'string' 'Freq. limits (Hz)'} ...
{'style' 'edit' 'string' num2str(freqlim_def) 'tag' 'freqlimits'}...
{'style' 'text' 'string' 'Freq. scale'}...
{'style' 'popupmenu' 'string' freqscale_list 'tag' 'freqscale' 'value' 2}...
{'style' 'text' 'string' 'pcfac (see Help)'}...
{'style' 'edit' 'string' num2str(g.pcfac) 'tag' 'pcfac'}...
{'style' 'text' 'string' 'pop_runima_study options (see Help)'}...
{'style' 'edit' 'string' ' ' 'tag' 'ed_opt'} {}};
ht = 9; wt = 3 ;
geom = {{wt ht [0 0] [1 1]} ...
{wt ht [0.1 1] [1 1]} {wt ht [1 1] [1 1]} {wt ht [1.45 1] [1 1]}...
{wt ht [1 2] [0.5 1]} {wt ht [1.5 2] [0.3 1]}...
{wt ht [1 3] [0.5 1]} {wt ht [1.5 3] [0.3 1]}...
{wt ht [1 4] [0.5 1]} {wt ht [1.5 4] [0.3 1]}...
{wt ht [1 5] [0.5 1]} {wt ht [1.5 5] [0.3 1]}...
{wt ht [0.1 6] [1 1]}...
{wt ht [0 7] [1 1]} {wt ht [0.5 7] [0.5 1]} {wt ht [1.1 7] [1 1]} {wt ht [1.5 7] [0.5 1]} {wt ht [2 7] [1 1]} {wt ht [2.5 7] [0.5 1]} ...
{wt ht [0 8] [1 1]} {wt ht [1 8] [2 1]} ...
{wt ht [0.1 9] [1 1]}...
};
[result, ~, ~, resstruct, ~] = inputgui('title','Run STUDY Independent Modulator Analysis -- pop_runIMA_study', 'geom', geom, 'uilist',uilist, 'helpcom','pophelp(''pop_runIMA'');');
if isempty(result), return; end;
if resstruct.chbx_iclabel
guilabels = [resstruct.chbx_brain resstruct.chbx_muscle resstruct.chbx_eye resstruct.chbx_heart];
g.selectICs = iclabel_list{logical(guilabels)};
g.iclthreshold_brain = str2num(resstruct.ed_brainthrs);
g.iclthreshold_eye = str2num(resstruct.ed_eyethrs);
g.iclthreshold_muscle = str2num(resstruct.ed_musclethrs);
g.iclthreshold_artefact = str2num(resstruct.ed_heartthrs);
else
g.selectICs = 'off';
end
g.frqlim = str2num(resstruct.freqlimits);
g.freqscale = freqscale_list{resstruct.freqscale};
g.pcfac = str2num(resstruct.pcfac);
%%
% Retrieve optional parameters
tmpoptparams = eval( [ '{' get(findobj(gcf,'tag','ed_opt'),'string') '}' ] );
tmpparams_name = tmpoptparams(1:2:end);
% Update parameters here
c =1;
for i = 1: length(tmpparams_name)
g.(tmpparams_name{i}) = tmpoptparams{c+1};
c = c+2;
end
end
%% check format of EEG set
ncond = length({STUDY.datasetinfo.subject})/length(unique({STUDY.datasetinfo.subject}));
nsubj = length(STUDY.subject);
for iko = 1:nsubj
indsj = find(ismember({STUDY.datasetinfo.subject}, STUDY.subject(iko)));
eind = 1;
clear EEGtmp
for ika = indsj;
EEGtmp{eind} = pop_loadset('filename',STUDY.datasetinfo(ika).filename,'filepath',STUDY.datasetinfo(ika).filepath);
eind = eind+1;
end
%% check if IC label plugin is installed
%% ask if plugin should be downloaded
g.plotcomps = [];
if sum(ismember(g.selectICs,'off')) == 0;
indPlugin = 0;
% try, PLUGINLIST = evalin('base', 'PLUGINLIST'); catch, PLUGINLIST = []; end;
% if ~isempty(PLUGINLIST) && isfield(PLUGINLIST, 'plugin')
% indPlugin = strmatch(lower('ICLabel'), lower({ PLUGINLIST.plugin }), 'exact');
% end
%
% if indPlugin == 0;
% installRes = plugin_askinstall('ICLabel');
% if installRes == 0
% errordlg2('Cannot select ICs with IC Label. Please install ICLabel in previous step or using the eeglab extension manager.',...
% 'ICLabel not installed');
% error('ICLabel not installed. Cannot select ICs with IC Label. Please install ICLabel in previous step or using the eeglab extension manager.')
% end
% end
%
%% check if dipoles are computed
fprintf('selecting ICs with IClabel... \n')
if sum(strcmp(g.selectICs,'brain')) == 1 && strcmp(g.usedip, 'on') && ~isfield(EEGtmp{1}.dipfit,'model');
errordlg2('You chose to use dipole residual variance in addition to IC Label to select brain components. You need to first compute dipole locations.',...
'No dipole locations present');
error('No dipole locations present. You need to first compute dipole locations.')
end
%% run IC label
EEGtmp{1} = pop_iclabel( EEGtmp{1}, 'Default');
% check which IC label is most probable for each IC
[VAL,IND] = max(EEGtmp{1}.etc.ic_classification.ICLabel.classifications(:,1:7),[],2);
% select braincomps
if strcmp(g.usedip, 'on') % use IC label classification plus dipole RV for selecting ICs
LOGIC{1} = find((IND == 1) & (VAL > g.iclthreshold_brain) & [EEGtmp{1}.dipfit.model.rv]' < g.dipthreshold);
else
LOGIC{1} = find((IND == 1) & (VAL > g.iclthreshold_brain)); % use only IC label classification
end
LOGIC{2} = find((IND == 2) & (VAL > g.iclthreshold_muscle)); % find muscle ICs with classification accuracy above threshold
LOGIC{3} = find((IND == 3) & (VAL > g.iclthreshold_eye)); % find eye ICs with classification accuracy above threshold
LOGIC{4} = find((IND == 4) & (VAL > g.iclthreshold_artefact)); % find heart ICs with classification accuracy above threshold
indICs = find(ismember(lower(g.selectICs), {'brain' 'muscle' 'eye' 'heart'}));
INDKEEP = [];
for iki = 1:length(indICs)
INDKEEP = [INDKEEP LOGIC{iki}']; % check which ICs are part of the predefined categories
end
g.plotcomps = INDKEEP;
% update component indices in the STUDY structure
for indd = indsj;
STUDY.datasetinfo(indd).comps = INDKEEP;
end
end
if isempty(g.plotcomps);
g.plotcomps = STUDY.datasetinfo(ika).comps;
end
if isempty(g.frqlim)
g.frqlim = [3 EEGtmp{1}.srate/2];
end
%% if data is not epoched - estimate overlap of epochs
if isempty(g.epochlength)
if size(EEGtmp{1}.icaact) == 3;
g.epochlength = EEGtmp{1}.xmax - EEGtmp{1}.xmin;
else
g.epochlength = 6;
end
end
% calculate windowsize needed to estimate n cycles of lowest frequency
TWindow = (g.cycles(1)*(1/g.frqlim(1)));
if isempty(g.winsize) || g.winsize < TWindow;
g.winsize = TWindow;
end
overlap = (g.winsize*g.overlapfac);
timesout = round(g.epochlength/(g.winsize-overlap));
overlapframes = overlap*EEGtmp{1}.srate;
%% check if windowsize exceeds epoch length or if epoch length is large enough to estimate lowest frequency with n cycles
if g.winsize >= g.epochlength && g.winsize > TWindow;
errordlg2('Window size selected for time-frequency decomposition is larger than epoch size. Either choose a smaller time window size or a larger epoch size.',...
'Window size exceeds epoch limits');
error('Window size exceeds epoch limits. Window size selected for time-frequency decomposition is larger than epoch size. Either choose a smaller time window size or a larger epoch size.')
elseif g.winsize >= g.epochlength && g.winsize == TWindow;
errordlg2('Window size determined for for estimating lowest frequency with n cycles is larger than epoch size. You need to choose a larger epoch size.',...
'Epoch size is too small for estimating lowest frequency with n cycles');
error('poch size is too small for estimating lowest frequency with n cycles. Window size determined for for estimating lowest frequency with n cycles is larger than epoch size. You need to choose a larger epoch size.')
end
timevecorig = [];
if length(size(EEGtmp{1}.data)) == 2;
fprintf('data is not epoched \n')
fprintf('estimating epoch overlap... \n')
%% epoching data
for inc = 1:length(EEGtmp)
EEGcurr = EEGtmp{inc};
% add data channel with timevector to track later rejected parts
% during epoching
EEGcurr.data(end+1,:) = EEGcurr.times;
EEGcurr.nbchan = size(EEGcurr.data,1);
if ~isempty(EEGcurr.chanlocs)
EEGcurr.chanlocs(end+1).label = 'timevec';
end;
timevecorig{inc} = EEGcurr.times;
% estimate how may epochs of predefined length fit into data given
% predefined overlap
NEO = ceil(EEGcurr.pnts/((g.epochlength*EEGcurr.srate-overlapframes)));
% determine latency of events for epochs
LATEO = (overlapframes:g.epochlength*(EEGcurr.srate)-overlapframes:(g.epochlength*(EEGcurr.srate)-overlapframes)*NEO)
% create event structure with type and latency
markersEO = [ones(size(LATEO))'*inc*100 LATEO'];
[EEGcurr] = pop_importevent(EEGcurr, 'event', ... % import events to eeg dataset
markersEO, 'fields', {'type', 'latency'}, ...
'append', 'yes', 'align', 0, 'timeunit', NaN );
EEGcurr = eeg_checkset( EEGcurr );
fprintf('epoching data... \n')
% epoch dataset
EEGcurr = pop_epoch( EEGcurr, { num2str(inc*100) }, [0 g.epochlength], 'epochinfo', 'yes');
EEGcurr = eeg_checkset( EEGcurr );
eegdata{inc} = EEGcurr.icaact; % save icaactivity of dataset in cell array
timevecproc{inc} = squeeze(EEGcurr.data(end,:,:)); % save timevector of processed epoched data to cell array
EEGcurr = pop_select( EEGcurr,'nochannel',size(EEGcurr.data,1)); %delete perviously created timevector channel
EEGtemp{inc} = EEGcurr;
end
else %% in case that EEG datasets are already epoched EEG structure and icaactivity of dataset in cell array
for inc = 1:length(EEGtmp)
EEGtemp{inc} = EEGtmp{inc};
eegdata{inc} = EEGtmp{inc}.icaact;
timevecproc_temp = linspace(0,(EEGtmp{inc}.pnts*EEGtmp{inc}.trials)/EEGtmp{inc}.srate,EEGtmp{inc}.pnts*EEGtmp{inc}.trials);
timevecproc{inc} = reshape(timevecproc_temp*1000,[EEGtmp{inc}.pnts,EEGtmp{inc}.trials]);
%repmat(EEGtmp{inc}.times, EEGtmp{inc}.trials,1)';
end
end
%% run IMA
[IMAweights,IMAsphere, meanpwr, freqvec, n_trials, ntw_trials,...
pcs, eigvec, pc, timefreq,...
meanpwrCond] = runIMA(eegdata,EEGtemp{1}.pnts, [EEGtemp{1}.xmin EEGtemp{1}.xmax]*1000, EEGtemp{1}.srate,...
'plotcomps', g.plotcomps, 'cycles', g.cycles, 'timesout', timesout, 'frqlim', g.frqlim, 'freqscale', g.freqscale, 'winsize', g.winsize, 'icatype', g.icatype);
%%%%% downsample the previously saved timevector of the processed dataset to the number of time frequency output timepoints of IMA
timevec_res = [];
% if length(size(EEGtmp{1}.data)) == 2;
for inc = 1:length(EEGtmp)
timevec_res{inc} = downsample(squeeze(timevecproc{inc}(1:end-overlapframes,:)),round(size(squeeze(timevecproc{inc}(1:end-overlapframes,:)),1)/ntw_trials));
end
% for inc = 1:length(EEGtmp)
% timevec_res{inc} = downsample(squeeze(timevecorig{inc}),n_trials(inc)*ntw_trials);
% end
condvec = [1 n_trials*ntw_trials];
%% warp timef data to original datalength
timefreqtmp = [];
eigvectmp = [];
timevec = [];
opi = 0;
for inc = 1:length(EEGtmp)
[timefreqtmp] = [timefreqtmp; resample(timefreq((condvec(inc)+1):(condvec(inc+1)+condvec(inc)),:),timevec_res{inc}(:))];
[eigvectmp] = [eigvectmp; resample(eigvec((condvec(inc)+1):(condvec(inc+1)+condvec(inc)),:),timevec_res{inc}(:))];
timepntcond{inc} = (condvec(inc)+1):(condvec(inc+1)+condvec(inc)); % select trials for condition
timevec = [timevec; opi + timevec_res{inc}(:)];
opi = timevec_res{inc}(end);
end
timefreq = timefreqtmp;
eigvec = eigvectmp;
% end
%% save IMA results in IMA structure
IMA.wts = IMAweights;
IMA.sph = IMAsphere;
IMA.meanpwr = meanpwr;
IMA.freqvec = freqvec;
IMA.timevec = timevec;
IMA.timevec_cond = timevec_res;
IMA.freqscale = g.freqscale;
IMA.freqlim = g.frqlim;
IMA.npcs = pcs;
IMA.complist = g.plotcomps;
IMA.srate = EEGtemp{1}.srate;
IMA.ntrials = n_trials;
IMA.ntw_trials = ntw_trials;
IMA.winsize = g.winsize;
IMA.epochlength = g.epochlength;
IMA.eigvec = eigvectmp;
IMA.pc = pc;
IMA.timefreq = timefreqtmp;
IMA.meanpwrCond = meanpwrCond;
IMA.timepntCond = timepntcond;
IMA.condition = unique({STUDY.datasetinfo.condition},'stable');
IMA.STUDYname = STUDY.filename;
IMA.STUDYfilepath = STUDY.filepath;
IMA.subj = STUDY.subject(iko);
IMA.subjfilename = {STUDY.datasetinfo(indsj).filename};
IMA.subjfilepath = {STUDY.datasetinfo(indsj).filepath};
newfilename = extractBefore(STUDY.filename,'.study');
IMA.filename = [IMA.subj{1} '_' newfilename '.ima'];
%% save IMA results to file
save([EEGtmp{1}.filepath '/' IMA.subj{1} '_' newfilename '.ima'],'IMA');
STUDY.etc.IMA.subjfilename{iko} = IMA.subjfilename;
STUDY.etc.IMA.subjfilepath{iko} = IMA.subjfilepath;
STUDY.etc.IMA.imafilename{iko} = [IMA.subj{1} '_' newfilename '.ima'];
STUDY.etc.IMA.imafilepath{iko} = IMA.subjfilepath{1};
STUDY.etc.IMA.subject{iko,:} = IMA.subj{1};
[STUDY] = pop_savestudy( STUDY, ALLEEG, 'savemode','resave');
clear EEGtmp EEGcurr
end
fprintf('\ndone.\n');