Mean of values in acolumn depending on VARYING values of another column
조회 수: 2 (최근 30일)
이전 댓글 표시
Hi, I would like to calculate the mean of values in a coulmn, based on the values in another column. However, different from other questions asked previously on this forum, the values in the second column I need to use are not specific, but change. Please see attached file and hopefully it will be easier to get what I mean. Maybe I need to use a for loop running through all the values of the second column? Thank you!
댓글 수: 0
채택된 답변
Dyuman Joshi
2023년 10월 4일
in =readmatrix('Book2.xlsx');
disp(in)
out = accumarray(in(:,2),in(:,1),[],@mean)
댓글 수: 14
Dyuman Joshi
2023년 10월 5일
Use the first output of unique()
format longg
in = readmatrix('Book3.xlsx');
[out1,~,idx] = unique(in(:,2))
out2 = accumarray(idx,in(:,1),[],@mean)
Concatenate them horizontally to get them in the same array
out = [out1 out2];
추가 답변 (1개)
Ken Garrard
2023년 10월 4일
You do not need a for loop.
Assumming that your data is in an Nx2 variable named, mydata.
% Select rows matching criteria in column 2
% For example, values in column 2 greater than one and less than five
hits = mydata(:,2) > 1 & mydata(:,2) < 5;
% Mean of values from column 1
mean(mydata(hits,1))
ans =
12.7273
댓글 수: 0
참고 항목
카테고리
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!