/
ft_datatype_freq.m
174 lines (155 loc) · 6.31 KB
/
ft_datatype_freq.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
function [freq] = ft_datatype_freq(freq, varargin)
% FT_DATATYPE_FREQ describes the FieldTrip MATLAB structure for freq data
%
% The freq data structure represents frequency or time-frequency decomposed
% channel-level data. This data structure is usually generated with the
% FT_FREQANALYSIS function.
%
% An example of a freq data structure containing the powerspectrum for 306 channels
% and 120 frequencies is
%
% dimord: 'chan_freq' defines how the numeric data should be interpreted
% powspctrm: [306x120 double] the power spectrum
% label: {306x1 cell} the channel labels
% freq: [1x120 double] the frequencies expressed in Hz
% cfg: [1x1 struct] the configuration used by the function that generated this data structure
%
% An example of a freq data structure containing the time-frequency resolved
% spectral estimates of power (i.e. TFR) for 306 channels, 120 frequencies
% and 60 timepoints is
%
% dimord: 'chan_freq_time' defines how the numeric data should be interpreted
% powspctrm: [306x120x60 double] the power spectrum
% label: {306x1 cell} the channel labels
% freq: [1x120 double] the frequencies, expressed in Hz
% time: [1x60 double] the time, expressed in seconds
% cfg: [1x1 struct] the configuration used by the function that generated this data structure
%
% Required fields:
% - freq, dimord, label or labelcmb
%
% Optional fields:
% - powspctrm, fouriesspctrm, csdspctrm, cohspctrm, time, grad, elec, cumsumcnt, cumtapcnt, trialinfo
%
% Deprecated fields:
% - <none>
%
% Obsoleted fields:
% - <none>
%
% Revision history:
%
% (2011/latest) The description of the sensors has changed, see FT_DATATYPE_SENS
% for further information.
%
% (2008) The presence of labelcmb in case of crsspctrm became optional,
% from now on the crsspctrm can also be represented as Nchan * Nchan.
%
% (2006) The fourierspctrm field was added as alternative to powspctrm and
% crsspctrm. The fields foi and toi were renamed to freq and time.
%
% (2003v2) The fields sgn and sgncmb were renamed into label and labelcmb.
%
% (2003v1) The initial version was defined.
%
% See also FT_DATATYPE, FT_DATATYPE_COMP, FT_DATATYPE_DIP, FT_DATATYPE_FREQ,
% FT_DATATYPE_MVAR, FT_DATATYPE_RAW, FT_DATATYPE_SOURCE, FT_DATATYPE_SPIKE,
% FT_DATATYPE_TIMELOCK, FT_DATATYPE_VOLUME
% Copyright (C) 2011, Robert Oostenveld
%
% This file is part of FieldTrip, see http://www.fieldtriptoolbox.org
% for the documentation and details.
%
% FieldTrip 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 3 of the License, or
% (at your option) any later version.
%
% FieldTrip 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 FieldTrip. If not, see <http://www.gnu.org/licenses/>.
%
% $Id$
% get the optional input arguments, which should be specified as key-value pairs
version = ft_getopt(varargin, 'version', 'latest');
if strcmp(version, 'latest')
version = '2011';
end
if isempty(freq)
return;
end
% do some sanity checks
assert(isfield(freq, 'freq') && (isfield(freq, 'label') || isfield(freq, 'labelcmb')), 'inconsistent freq data structure, some field is missing');
if isfield(freq, 'label')
% it could also be that it has labelcmb instead of label
assert(length(unique(freq.label))==length(freq.label), 'channel labels must be unique');
end
% ensure consistency between the dimord string and the axes that describe the data dimensions
freq = fixdimord(freq);
if ~isrow(freq.freq)
freq.freq = freq.freq';
end
if isfield(freq, 'label') && ~iscolumn(freq.label)
% this is not present if the dimord is chancmb_freq or chancmb_freq_time
freq.label = freq.label';
end
if isfield(freq, 'time') && ~isrow(freq.time)
freq.time = freq.time';
end
if ~isfield(freq, 'label') && ~isfield(freq, 'labelcmb')
ft_warning('data structure is incorrect since it has no channel labels');
end
switch version
case '2011'
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% ensure that the sensor structures are up to date
if isfield(freq, 'grad')
freq.grad = ft_datatype_sens(freq.grad);
end
if isfield(freq, 'elec')
freq.elec = ft_datatype_sens(freq.elec);
end
if isfield(freq, 'opto')
freq.opto = ft_datatype_sens(freq.opto);
end
if isfield(freq, 'foi') && ~isfield(freq, 'freq')
% this was still the case in early 2006
freq.freq = freq.foi;
freq = rmfield(freq, 'foi');
end
if isfield(freq, 'toi') && ~isfield(freq, 'time')
% this was still the case in early 2006
freq.time = freq.toi;
freq = rmfield(freq, 'toi');
end
if isfield(freq, 'cumtapcnt') && isvector(freq.cumtapcnt)
% ensure that it is a column vector
freq.cumtapcnt = freq.cumtapcnt(:);
end
if isfield(freq, 'cumsumcnt') && isvector(freq.cumsumcnt)
% ensure that it is a column vector
freq.cumsumcnt = freq.cumsumcnt(:);
end
% ensure that the structure has all required fields
% note that dimord is listed as required field, but it might also be xxxdimord, or dynamically determined with GETDIMORD
for required={'freq'}
assert(isfield(freq, required), 'required field "%s" is missing', required{:});
end
% either label or labelcmb should be present
assert(any(ismember({'label', 'labelcmb'}, fieldnames(freq))), 'required field "label" or "labelcmb" is missing');
case '2008'
% there are no known conversions for backward or forward compatibility support
case '2006'
% there are no known conversions for backward or forward compatibility support
case '2003v2'
% there are no known conversions for backward or forward compatibility support
case '2003v1'
% there are no known conversions for backward or forward compatibility support
otherwise
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
ft_error('unsupported version "%s" for freq datatype', version);
end