How to do operations on nested cell array?
조회 수: 7 (최근 30일)
이전 댓글 표시
I have a nested cell array named 'events'.Each cell contains either 1 or more than 1 cells which in turn contains time series.
I want to write a code where, if the cell contains more than 1 cell arrays of time series, I want to find the standard deviation of each of those time series and retain only the time series with the highest standard deviation.
For ex: For the case of events {6,1} which contains 3 time series, I want to find the std of events{6,1}{1,1}, events{6,1}{2,1} and events{6,1}{3,1} and only retain the time series with the highest std and delete the rest.
How can I do this?
Thanks
댓글 수: 0
답변 (2개)
Walter Roberson
2020년 1월 16일
편집: Walter Roberson
2020년 1월 16일
for K = 1 : numel(events)
[~, idx] = max(cellfun(@std, events{K}));
Events{K} = events{K}(idx);
end
I would not bother trying to do it without a loop. It is possible, yes, but avoiding the loop requires calculating the std twice because inside the loop it is not possible to get at the second output of max()
Turlough Hughes
2020년 1월 16일
편집: Turlough Hughes
2020년 1월 16일
This should hopefully work but i ament able to test it myself right now as I'm away from my computer. The idea is to pass onecell at a time from the first level through a subfunction called myfun. myfun subsequently uses cellfun again to check each subcell, it finds the one with max standard deviation and should return that one.
EventsStdMax = cellfun(@(x) myfun(x),events,'UniformOutput',false)
function out = myfun(onecell)
[~,idx] = max(cellfun(@(x) std(x), onecell));
out = onecell{idx};
end
Edit: As Walter pointed out.
댓글 수: 6
Walter Roberson
2020년 1월 17일
No, according to your images , the first 27 entries in events are not timeseries and are instead cell arrays containing timeseries. But somewhere in events you have an entry which is not a cell array.
cellfun(@class, events, 'uniform', 0)
and look for one that does not say 'cell'
참고 항목
카테고리
Help Center 및 File Exchange에서 Creating and Concatenating Matrices에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!