In row mean of consecutive columns up to end
2 次查看(过去 30 天)
显示 更早的评论
Hello everyboby, I have a matrix A=1×100. Now I want to find the mean of row for each consecutive five columns up to last. that is Answer=mean(1-5 columns), mean(6-10 columns), mean(11-15columns),…. mean(96-100 columns). As a result I want to get one row vector containing 20 columns. I tried as mean(A(1,1:5:100)) but not get the desired result.
0 个评论
回答(2 个)
Akira Agata
2017-2-28
编辑:Akira Agata
2017-2-28
I think splitapply function will help. Please try the following code.
A = rand(1,100); % Example
group = reshape(repmat([1:20],5,1),1,100);
result = splitapply(@mean,A,group);
1 个评论
Image Analyst
2017-2-28
Cool! I was going to suggest blockproc() as an alternative, but that's only in the Image Processing Toolbox. It looks like they've put this general purpose function, splitapply(), into base MATLAB since version R2015b. (I guess I should read or remember the release notes.) It could even be applied to do any arbitrary function on arbitrary-sized arrays using any group criteria that you want.
Roger Stafford
2017-2-28
编辑:Image Analyst
2017-2-28
A = rand(1,100);
M = mean(reshape(A,5,[]),1);
2 个评论
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Resizing and Reshaping Matrices 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!