Use of CELLFUN instead of FOR loop
8 次查看(过去 30 天)
显示 更早的评论
I have a 21x40 cell array with each cell containing a vector of variable length. I want to merge all of the cells in each column. I can achieve this using a FOR loop such as
A = 21x40 cell array
for n = 1:40
merge = cat(2,A{:,n})
end
How can I do this with, for example, CELLFUN or in some other way without using a FOR loop? Thanks a lot for any help.
0 个评论
采纳的回答
Azzi Abdelmalek
2013-6-9
编辑:Azzi Abdelmalek
2013-6-9
A=num2cell(rand(21,40)) % Example
out=arrayfun(@(x) cat(2,A{:,x}),1:size(A,2),'un',0)
2 个评论
Jan
2013-6-10
This is a fast and short method. The "merge{n}= cat(2,A{:,n})" approach inside a loop is 50% faster.
更多回答(1 个)
Azzi Abdelmalek
2013-6-9
for n = 1:40
merge = cat(2,A{:,n})
end
is the same then
merge = cat(2,A{:,40})
4 个评论
Azzi Abdelmalek
2013-6-9
编辑:Azzi Abdelmalek
2013-6-9
Your for loop should be: (merge{n} instead of merge)
for n = 1:40
merge{n}= cat(2,A{:,n})
end
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Loops and Conditional Statements 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!