-
Notifications
You must be signed in to change notification settings - Fork 16
/
pop_taskinfo.m
361 lines (345 loc) · 23.2 KB
/
pop_taskinfo.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
% pop_taskinfo() - BIDS task information
%
% Usage:
% EEG = pop_taskinfo(EEG);
%
% Inputs:
% EEG - EEGLAB dataset or group of dataset
%
% Optional input:
% 'default' - generate BIDS event info using default values without
% popping up the GUI
%
% Authors: Arnaud Delorme, Dung Truong SCCN, INC, UCSD, 2020
% Copyright (C) Arnaud Delorme, 2020
%
% This program is free software; you can redistribute it and/or modify
% it under the terms of the GNU General Public License as published by
% the Free Software Foundation; either version 2 of the License, or
% (at your option) any later version.
%
% This program is distributed in the hope that it will be useful,
% but WITHOUT ANY WARRANTY; without even the implied warranty of
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
% GNU General Public License for more details.
%
% You should have received a copy of the GNU General Public License
% along with this program; if not, write to the Free Software
% Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
function [EEG,com] = pop_taskinfo(EEG, varargin)
%% Default settings
bg = [0.65 0.76 1];
fg = [0 0 0.4];
fontSize = 11;
tfHeight = 0.035;
f = figure('MenuBar', 'None', 'ToolBar', 'None', 'Name', 'BIDS task information -- pop_taskinfo()', 'Color', bg, 'IntegerHandle','off');
f.Position(2) = 0;
f.Position(3) = 1200;
f.Position(4) = 900;
halfWidth = 0.5;
%% Generic task info
leftMargin = 0.02;
fullWidth = halfWidth - leftMargin - 0.04;
tfWidth = 0.35*fullWidth;
efWidth = 0.63*fullWidth;
efLeftMargin = leftMargin + tfWidth + 0.01;
top = 0.92;
uicontrol('Style', 'text', 'string', 'BIDS task information', 'fontweight', 'bold', 'fontsize',13,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top halfWidth 0.05]);
top = top - 0.03;
uicontrol('Style', 'text', 'string', 'Dataset name*','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '', 'tag', 'Name','fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
top = top - tfHeight - 0.01;
uicontrol('Style', 'text', 'string', 'Task name (no space)','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '', 'tag', 'TaskName','fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
top = top - tfHeight - 0.01;
uicontrol('Style', 'text', 'string', 'For several tasks, script using bids_export', 'BackgroundColor',bg,'fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
top = top - tfHeight - 0.01;
uicontrol('Style', 'text', 'string', 'README (short introduction to the experiment):','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top fullWidth tfHeight]);
uicontrol('Style', 'pushbutton', 'string', 'Show template:','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin+0.2 top halfWidth*0.2 tfHeight], 'Callback', @default_readme);
top = top - tfHeight*2.2;
uicontrol('Style', 'edit', 'string', '', 'tag', 'README','fontsize',fontSize, 'HorizontalAlignment', 'left', 'max', 3,'Units', 'normalized', 'Position', [leftMargin top fullWidth tfHeight*2.5]);
top = top - tfHeight - 0.01;
uicontrol('Style', 'text', 'string', 'Participant task description (description of the experiment):','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top fullWidth tfHeight]);
top = top - tfHeight*2.7;
uicontrol('Style', 'edit', 'string', '', 'tag', 'TaskDescription','fontsize',fontSize, 'HorizontalAlignment', 'left', 'max', 3,'Units', 'normalized', 'Position', [leftMargin top fullWidth tfHeight*3]);
top = top - tfHeight - 0.01;
uicontrol('Style', 'text', 'string', 'Participant instructions (as exact as possible):','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top fullWidth tfHeight]);
top = top - tfHeight*2.7;
uicontrol('Style', 'edit', 'string', '', 'tag', 'Instructions', 'HorizontalAlignment', 'left', 'max', 3,'Units', 'normalized', 'Position', [leftMargin top fullWidth tfHeight*3]);
top = top - tfHeight - 0.02;
uicontrol('Style', 'text', 'string', 'Authors','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '', 'tag', 'Authors','fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
top = top - tfHeight - 0.005;
uicontrol('Style', 'text', 'string', 'References and links','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '', 'tag', 'ReferencesAndLinks','fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
top = top - tfHeight - 0.005;
cm = uicontextmenu(f);
m1 = uimenu(cm,'Text','Lookup CognitiveAtlas TermURL','MenuSelectedFcn',{@btnCB,'http://www.cognitiveatlas.org/tasks/a/'});
tooltip = sprintf('URL of the corresponding Cognitive Atlas term that describes the task.\nRight click to lookup.');
uicontrol('Style', 'text', 'string', 'Task-relevant Cognitive Atlas term', 'Tooltip',tooltip,'UIContextMenu', cm,'fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top-0.005 tfWidth tfHeight+0.01]);
uicontrol('Style', 'edit', 'string', '', 'tag', 'CogAtlasID','fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
top = top - tfHeight - 0.005;
cm = uicontextmenu(f);
m1 = uimenu(cm,'Text','Lookup CogPO TermURL','MenuSelectedFcn',{@btnCB,'http://wiki.cogpo.org/index.php?title=Main_Page'});
tooltip = sprintf('URL of the corresponding CogPO term that describes the task.\nRight click to lookup.');
uicontrol('Style', 'text', 'string', 'Task-relevant CogPO term', 'Tooltip',tooltip,'UIContextMenu', cm,'fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top 0.35*fullWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '', 'tag', 'CogPOID','fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
top = top - tfHeight - 0.005;
uicontrol('Style', 'text', 'string', 'Institution','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '', 'tag', 'InstitutionName','fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
top = top - tfHeight - 0.005;
uicontrol('Style', 'text', 'string', 'Department','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '', 'tag', 'InstitutionalDepartmentName','fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
top = top - tfHeight - 0.005;
uicontrol('Style', 'text', 'string', 'Institution location','fontsize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg, 'HorizontalAlignment','left','Units', 'normalized', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '', 'tag', 'InstitutionAddress','fontsize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight]);
uicontrol(f, 'Style', 'pushbutton', 'String', 'Help', 'FontSize',fontSize, 'Units', 'normalized', 'Position', [0.05 0.01 0.15 0.04], 'Callback', @helpCB);
uicontrol(f, 'Style', 'pushbutton', 'String', 'Ok', 'FontSize',fontSize, 'Units', 'normalized', 'Position', [0.80 0.01 0.15 0.04], 'Callback', @okCB);
uicontrol(f, 'Style', 'pushbutton', 'String', 'Cancel', 'FontSize',fontSize, 'Units', 'normalized', 'Position', [0.64 0.01 0.15 0.04], 'Callback', @cancelCB);
%% EEG specific info
leftMargin = halfWidth;
fullWidth = halfWidth - 0.03;
tfWidth = 0.4*fullWidth;
efWidth = 0.6*fullWidth;
efLeftMargin = leftMargin + tfWidth + 0.01;
top = 0.92;
uicontrol('Style', 'text', 'string', 'BIDS EEG acquisition information', 'Units', 'normalized','FontSize',13,'FontWeight','bold','BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top 0.4 0.05]);
top = top-0.03;
uicontrol('Style', 'text', 'string', 'Cap manufacturer', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '','tag', 'CapManufacturer', 'FontSize',fontSize, 'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'Cap model', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '','tag', 'CapManufacturersModelName', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'EEG reference location*', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '','tag', 'EEGReference', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'EEG ground electrode location', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '','tag', 'EEGGround', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'EEG montage system (10-20, 10-10, custom)', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '','tag', 'EEGPlacementScheme', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'EEG amplifier maker', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '','tag', 'Manufacturer', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'EEG amplifier model', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight], 'Callback', @editedCB);
uicontrol('Style', 'edit', 'string', '','tag', 'ManufacturersModelName', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'EEG amplifier serial #', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '','tag', 'DeviceSerialNumber', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'EEG acquisition software version', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight]);
uicontrol('Style', 'edit', 'string', '','tag', 'SoftwareVersions', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'Hardware filters', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight+0.002]);
uicontrol('Style', 'edit', 'string', '','tag', 'HardwareFilters','FontSize',fontSize, 'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'Software filters*', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight+0.002]);
uicontrol('Style', 'edit', 'string', '','tag', 'SoftwareFilters', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth tfHeight], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style', 'text', 'string', 'Line frequency (Hz)*', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth 0.05]);
uicontrol('Style', 'popupmenu', 'string', {'Select','50','60'},'tag', 'PowerLineFrequency', 'FontSize',fontSize,'Units', 'normalized', 'Position', [efLeftMargin top efWidth 0.05], 'Callback', @editedCB);
top = top-0.06;
uicontrol('Style','text','string','* Required field', 'Units', 'normalized','FontSize',fontSize,'BackgroundColor',bg,'ForegroundColor',fg,'HorizontalAlignment','left', 'Position', [leftMargin top tfWidth tfHeight]);
% prefill data
preFill();
if nargin < 2
%% wait
waitfor(f);
elseif nargin < 3 && ischar(varargin{1}) && strcmp(varargin{1}, 'default')
okCB('','');
end
%% history
com = '% EEG = pop_taskinfo(EEG);';
%% Helper functions
function btnCB(src,event, url)
web(url);
end
function helpCB(src,event)
pophelp('pop_taskinfo');
end
function okCB(src,event)
for a=1:numel(EEG)
bids = [];
tInfo = [];
gInfo = [];
% preserve current BIDS info if have
if isfield(EEG(a), 'BIDS')
bids = EEG(a).BIDS;
if isfield(bids, 'tInfo')
tInfo = bids.tInfo;
end
if isfield(bids, 'gInfo')
gInfo = bids.gInfo;
end
end
% update tInfo and gInfo from input fields
objs = findall(f);
for i=1:numel(objs)
if ~isempty(objs(i).Tag)
if ~isempty(objs(i).String)
switch objs(i).Tag
case {'README', 'TaskDescription', 'Instructions'}
tmp = objs(i).String;
if ndims(tmp) > 1 && size(tmp,1) > 1
tmp = reformatchartostring(tmp);
end
gInfo.(objs(i).Tag) = tmp;
case 'TaskName' % no space allowed for task name
gInfo.(objs(i).Tag) = strrep(objs(i).String,' ','');
case {'Authors', 'ReferencesAndLinks'}
gInfo.(objs(i).Tag) = split(objs(i).String, ', ');
case 'PowerLineFrequency'
tInfo.(objs(i).Tag) = str2double(objs(i).String{objs(i).Value});
case {'SoftwareFilters', 'HardwareFilters'}
tInfo.(objs(i).Tag) = [];
tInfo.(objs(i).Tag).FilterDescription.Description = objs(i).String;
otherwise
tInfo.(objs(i).Tag) = objs(i).String;
end
elseif isfield(tInfo,objs(i).Tag) % remove field if no longer has value
tInfo = rmfield(tInfo, objs(i).Tag);
end
end
end
% make sure it's struct datatype when empty
if isempty(gInfo)
gInfo = struct([]);
end
if isempty(tInfo)
tInfo = struct([]);
end
% update BIDS structure
bids.tInfo = tInfo;
bids.gInfo = gInfo;
EEG(a).BIDS = bids;
EEG(a).saved = 'no';
end
close(f);
end
function cancelCB(src, event)
close(f);
end
function preFill()
prevtInfo = gettInfo(EEG);
if ~isempty(prevtInfo)
objs = findall(f);
for i=1:numel(objs)
if ~isempty(objs(i).Tag) && isfield(prevtInfo, objs(i).Tag)
if strcmp(objs(i).Style, 'popupmenu') % dropdown
if ~isnan(prevtInfo.(objs(i).Tag))
objs(i).Value = find(strcmp(objs(i).String, num2str(prevtInfo.(objs(i).Tag)))); % set position of dropdown menu to the appropriate string
end
elseif strcmp(objs(i).Tag, 'HardwareFilters') || strcmp(objs(i).Tag, 'SoftwareFilters')
if ischar(prevtInfo.(objs(i).Tag)) % accommodate previous code
objs(i).String = prevtInfo.(objs(i).Tag);
else
try
objs(i).String = ['LowPassFilter-cutoff: ' prevtInfo.(objs(i).Tag).LowPassFilter.cutoff];
catch
try
objs(i).String = prevtInfo.(objs(i).Tag).FilterDescription.Description;
catch
objs(i).String = '';
end
end
end
else
objs(i).String = char(prevtInfo.(objs(i).Tag));
end
end
end
end
prevgInfo = getgInfo(EEG);
if ~isempty(prevgInfo)
objs = findall(f);
for i=1:numel(objs)
if ~isempty(objs(i).Tag) && isfield(prevgInfo, objs(i).Tag)
if strcmp(objs(i).Style, 'popupmenu') % dropdown
objs(i).Value = find(strcmp(objs(i).String, prevgInfo.(objs(i).Tag))); % set position of dropdown menu to the appropriate string
else
if iscell(prevgInfo.(objs(i).Tag)) %e.g., Authors & ReferencesAndLinks
tmp = sprintf('%s, ', prevgInfo.(objs(i).Tag){:}); % unpack multiple entries
objs(i).String = tmp(1:end-2); % remove trailing comma and space
else
objs(i).String = prevgInfo.(objs(i).Tag);
end
end
end
end
end
end
function tInfo = gettInfo(EEG)
hasBIDS = arrayfun(@(x) isfield(x,'BIDS') && ~isempty(x.BIDS),EEG);
if sum(hasBIDS) == 0 %if no BIDS found for any EEG
tInfo = struct([]);
else % at least one EEG has BIDS
if sum(hasBIDS) < numel(EEG) % not all have BIDS
warning('Not all EEG contains BIDS information.');
end
hastInfo = arrayfun(@(x) isfield(x,'BIDS') && isfield(x.BIDS,'tInfo') && ~isempty(x.BIDS.tInfo),EEG);
if sum(hastInfo) == 0
tInfo = struct([]);
else % at least one EEG has BIDS.tInfo
try
bids = [EEG(hastInfo).BIDS];
alltInfo = [bids.tInfo];
if numel(alltInfo) < numel(EEG)
tInfo = EEG(find(hastInfo,1)).BIDS.tInfo;
warning('Not all EEG contains tInfo structure. Using first available tInfo of EEG(%d)...',find(hastInfo,1));
else
tInfo = alltInfo(1);
fprintf('Using task info of the first dataset for all datasets...\n');
end
catch % field inconsistent
tInfo = EEG(find(hastInfo,1)).BIDS.tInfo;
warning('tInfo structures are inconsistent across datasets. Using first available tInfo of EEG(%d)...',find(hastInfo,1));
end
end
end
end
function gInfo = getgInfo(EEG)
hasBIDS = arrayfun(@(x) isfield(x,'BIDS') && ~isempty(x.BIDS),EEG);
if sum(hasBIDS) == 0 %if no BIDS found for any EEG
gInfo = struct([]);
else % at least one EEG has BIDS
if sum(hasBIDS) < numel(EEG) % not all have BIDS
warning('Not all EEG contains BIDS information.');
end
hasgInfo = arrayfun(@(x) isfield(x,'BIDS') && isfield(x.BIDS,'gInfo') && ~isempty(x.BIDS.gInfo),EEG);
if sum(hasgInfo) == 0
gInfo = struct([]);
else % at least one EEG has BIDS.gInfo
try
bids = [EEG(hasgInfo).BIDS];
allgInfo = [bids.gInfo];
if numel(allgInfo) < numel(EEG)
gInfo = EEG(find(hasgInfo,1)).BIDS.gInfo;
warning('Not all EEG contains gInfo structure. Using gInfo of EEG(%d)...',find(hasgInfo,1));
else
gInfo = allgInfo(1);
fprintf('Using tInfo of EEG(1)...\n');
end
catch % field inconsistent
gInfo = EEG(find(hasgInfo,1)).BIDS.gInfo;
warning('Inconsistence found in gInfo structures. Using gInfo of EEG(%d)...',find(hasgInfo,1));
end
end
end
end
function editedCB(src,event)
end
function default_readme(src, event)
[res, hist] = pop_comments(bids_template_README());
if ~isempty(hist)
readme_field = findobj('Tag', 'README');
readme_field.String = res;
end
end
function string_out = reformatchartostring(char_in)
char_in(1:end-1,end+1) = newline;
char_in = char_in';
string_out = char_in(:)';
end
end