accumulate in multiple array

1 view (last 30 days)
I have:
Temperature profiles array for 5 days. such that, temp(heigth,day). however, there are multiple profile in some days which makes the number of profile equal 11.
size of temp = (3650 by 11)
size of day = (1 by 11)
day=[1,1,1,2,2,3,3,3,4,4,5].
I want to:
average temperature for every similar days
such that:
dailyday=[1,2,3,4,5]
temp=(3650 by 5)

Accepted Answer

madhan ravi
madhan ravi on 17 May 2019
splitapply(@(x) mean(x,2),Temp,findgroups(Day))
  5 Comments
madhan ravi
madhan ravi on 17 May 2019
Edited: madhan ravi on 17 May 2019
C=splitapply(@(x) {mean(x,2)},Temp,findgroups(Day));
[C{:}]
%or
[~,~,c]=unique(Day);
C = accumarray(c,1:size(Temp,2),[],@(x){mean(Temp(:,x),2)});
[C{:}]
Kafayat Olayinka
Kafayat Olayinka on 17 May 2019
Worked perfectly. Thank you.

Sign in to comment.

More Answers (1)

Walter Roberson
Walter Roberson on 17 May 2019
[mean(temp(:,1:3),2), mean(temp(:,4:5)), mean(temp(:,6:8)), mean(temp(:,9:10)), temp(:,11)]
  1 Comment
Kafayat Olayinka
Kafayat Olayinka on 17 May 2019
Thanks. How should I write the loop assuming Days are more than 5 days and each day may have multiple temperature profiles. How should I average each temp profile per day?

Sign in to comment.

Categories

Find more on Graphics Performance in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!