-
Notifications
You must be signed in to change notification settings - Fork 27
/
limo_get_result_file.m
134 lines (120 loc) · 4.3 KB
/
limo_get_result_file.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
function [FileName,PathName,FilterIndex]= limo_get_result_file
% routine to get result file(s) either from folder names or within a folder
% from file names
%
% FORMAT [FileName,PathName,FilterIndex]= limo_get_result_files
% OUTPUT FileName, PathName, Full File names are returned as string
%
% Arnaud Delorme & Cyril Pernet
% ------------------------------
% Copyright (C) LIMO Team 2023
Names = {};
Paths = {};
Files = {};
txtFile = '';
FilterIndex = 0;
FileName = 0;
PathName = 0;
limo_settings_script;
if limo_settings.newgui && ~isempty(limo_settings.workdir)
if exist(limo_settings.workdir,'dir')
cd(limo_settings.workdir);
end
end
% level 1 or level 2
options = { 'Level 1', 'Level 2'};
options_default = options{end};
if exist(fullfile(pwd,'LIMO.mat'),'file')
LIMO = load(fullfile(pwd,'LIMO.mat'));
if LIMO.LIMO.Level == 1
options_default = options{1};
end
end
res = limo_questdlg('Plot level 1 (subject) or level 2 (group) analysis file?', 'Result file', options{:}, options_default);
if isempty(res)
return
else
if contains(res, options{1}) % cancel
level = 1;
strGUI = 'Pick a result file for level 1 analysis (individual subject)';
else
level = 2;
strGUI = 'pick a result file for level 2 analysis (group analysis)';
end
end
if level == 1
dirContent = dir('sub*/eeg/ses*/*/*.mat');
else
% assuming default directory filenames
% if scripted, also look for actual filenames,
% when the user if inside a directory
dirContent1 = dir('one_sample_ttest*/*.mat');
if isempty(dirContent1)
dirContent1 = dir('one_sample_ttest*.mat');
end
if isempty(dirContent1)
dirContent1 = dir('one_sample_ttest*/*/*.mat');
end
dirContent2 = dir('paired_ttest*/*.mat');
if isempty(dirContent2)
dirContent2 = dir('paired_samples_ttest*.mat');
end
dirContent3 = dir('two_samples_ttest*/*.mat');
if isempty(dirContent3)
dirContent3 = dir('two_samples_ttest*.mat');
end
dirContent4 = dir('regression*/*.mat');
dirContent5 = [];
if isempty(dirContent4)
dirContent4 = dir('Covariate_effect_*.mat');
end
dirContent5 = dir('AN(C)OVA*/*.mat');
dirContent6 = [];
dirContent7 = [];
if isempty(dirContent5)
dirContent5 = dir('Condition_effect*.mat');
dirContent6 = dir('Covariate_effect_*.mat');
dirContent7 = dir('Rep_ANOVA_*.mat');
end
dirContent8 = dir('con_*.mat');
dirContent9 = dir('ess_*.mat');
dirContent = [dirContent1;dirContent2;dirContent3;dirContent4;...
dirContent5;dirContent6;dirContent7;dirContent8,dirContent9];
end
% remove Yr and LIMO files
for iFile = length(dirContent):-1:1
if contains(dirContent(iFile).name, 'LIMO.mat') || contains(dirContent(iFile).name, 'Yr.mat') || ...
contains(dirContent(iFile).name, 'Yhat.mat') || contains(dirContent(iFile).name, 'R2.mat') || ...
contains(dirContent(iFile).name, 'Y1r.mat') || contains(dirContent(iFile).name, 'Y2r.mat') || ...
contains(dirContent(iFile).name, 'Betas.mat')
dirContent(iFile) = [];
else
relPath = strrep(dirContent(iFile).folder, pwd, './');
dirContent(iFile).fullname = fullfile(relPath, dirContent(iFile).name);
if contains(dirContent(iFile).fullname, 'ess_')
dirContent(iFile).fullname = [ dirContent(iFile).fullname ' (contrast)' ];
end
end
end
if isempty(dirContent)
txt = [ 'No result files were found. Do you want' 10 ...
'to browse folders for a .mat result file?' ];
options = { 'Cancel', 'Browse'};
res = limo_questdlg(txt, 'Result file', options{:}, options{end});
if contains(res, options{1}) % cancel
return
else
[FileName,PathName,FilterIndex]=uigetfile('*.*','Select Result to plot');
end
else
uiList = { {'style' 'text' 'string' strGUI } ...
{ 'style' 'popupmenu' 'string' {dirContent.fullname} 'value', 1 } };
res = inputgui('uilist', uiList, 'geometry', { [1] [1] }, 'cancel', 'Browse');
if ~isempty(res)
FileName = dirContent(res{1}).name;
PathName = dirContent(res{1}).folder;
FilterIndex = 1;
else
[FileName,PathName,FilterIndex]=uigetfile('*.*','Select Result to plot');
end
end