-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathstep3c_validation_pairwise_decoding_mne_to_cosmo.m
73 lines (54 loc) · 2.16 KB
/
step3c_validation_pairwise_decoding_mne_to_cosmo.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
function step3c_validation_pairwise_decoding_mne_to_cosmo(bids_dir, toolbox_dir, varargin)
%% Function that takes preprocessed MNE data and transforms it to a matlab-cosmo script
% Note: this script requires the MNE-matlab & cosmomvpa toolboxes
%
% @ Lina Teichmann, 2022
%
% Usage:
% step3c_validation_pairwise_decoding_mne_to_cosmo(bids_dir, ...)
%
% Inputs:
% bids_dir path to the bids root folder
% toolbox_dir path to toolbox folder containtining CoSMoMVPA
%
% Returns:
% ds Cosmo data struct, saved in BIDS/derivatives/preprocessed folder
%
%% parameters
preprocdir = [bids_dir '/derivatives/preprocessed/'];
addpath(genpath([toolbox_dir '/mne-matlab']))
addpath(genpath([toolbox_dir '/CoSMoMVPA']))
n_participants = 4;
%% loop
for p=1:n_participants
tic
tmp_filenames = dir([preprocdir '/preprocessed_P' num2str(p) '-epo*.fif']);
n1 = {tmp_filenames.name};
[~,I] = sort(cellfun(@length,n1));
all_files = n1(I);
%sanity check
disp('stacking files in this order: ')
for i = 1:length(all_files); disp(all_files{i}); end
for f = 1:length(all_files)
epo{f} = make_ds(fiff_read_epochs([preprocdir filesep cell2mat(all_files(f))]));
end
sa_tab = readtable([bids_dir '/sourcedata/sample_attributes_P' num2str(p) '.csv']);
sa = table2struct(sa_tab,'toscalar',1);
ds = cosmo_stack(epo);
ds.sa = sa;
save([preprocdir '/P' num2str(p) '_cosmofile.mat'],'ds','-v7.3')
fprintf('Saving finished in %i seconds\n',ceil(toc))
end
end
%% helper function
function ds = make_ds(part)
data = reshape(part.data,[size(part.data,1),size(part.data,2)*size(part.data,3)]);
chan = repmat(1:size(part.data,2),1,size(part.data,3));
time = repelem(1:size(part.data,3),1,size(part.data,2));
ds = struct();
ds.samples = data;
ds.a.fdim.labels = [{'chan'};{'time'}];
ds.a.fdim.values = [{1:size(part.data,2)};{part.times}];
ds.fa.chan = chan;
ds.fa.time = time;
end