index channel location error

3 次查看(过去 30 天)
chan1idx = find(strcmpi(channel1,{EEG.chanlocs.labels}));
chan2idx = find(strcmpi(channel2,{EEG.chanlocs.labels}));
Dear all, I am trying to direct the index of channel 1 to the corresponding value in my EEG.chanlocs file.
But I keep on getting this error:
Intermediate dot '.' indexing produced a comma-separated list with 20 values, but
it must produce a single value to perform subsequent indexing operations.
What should I change?
Thanks!!
  6 个评论
Walter Roberson
Walter Roberson 2021-7-2
Are the labels the same for all EEG entries?
Carmen Sergiou
Carmen Sergiou 2021-7-5
Yes, so they are all labeled, and I am trying to match the channels that I choose to calculate the phase-correlation between with the matching labels in my EEG.chanloc file.

请先登录,再进行评论。

采纳的回答

Walter Roberson
Walter Roberson 2021-7-7
channel1 = 'Fz';
EEG(1).chanlocs = struct('labels', {'Fp1', 'Fz', 'F3'}, 'sph_theta', {18, 0, 39})
EEG = struct with fields:
chanlocs: [1×3 struct]
EEG(2).chanlocs = struct('labels', {'Fp1', 'Fz', 'F3'}, 'sph_theta', {68, 44, 90});
EEG(3).chanlocs = struct('labels', {'Fp1', 'Fz', 'F3'}, 'sph_theta', {-17, 23, 45});
fields = {EEG(1).chanlocs.labels}
fields = 1×3 cell array
{'Fp1'} {'Fz'} {'F3'}
[found_channel1, idx] = ismember(channel1, fields)
found_channel1 = logical
1
idx = 2
So now if found_channel1 is true then idx is valid and is the field number of channel1 in EEG(:).chanlocs .
This assumes that the channel labels are exactly the same for all EEG(K).chanlocs .
extracted_info = cell2mat(arrayfun(@(S) S.chanlocs(idx), EEG, 'uniform', 0))
extracted_info = 1×3 struct array with fields:
labels sph_theta
{extracted_info.labels}
ans = 1×3 cell array
{'Fz'} {'Fz'} {'Fz'}
[extracted_info.sph_theta]
ans = 1×3
0 44 23
  1 个评论
Carmen Sergiou
Carmen Sergiou 2021-7-7
Thank you so so much!! I have replicated all your steps and also for channel 2 and it works.

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 EEG/MEG/ECoG 的更多信息

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by