필터 지우기
필터 지우기

Calculate standard deviation for different groups

조회 수: 9 (최근 30일)
leonidas86
leonidas86 2018년 7월 23일
댓글: Guillaume 2018년 7월 23일
I want to plot a Measurement with a bar figure. Therefore I want to create different groups and calculate the standard deviation for each group. I have a vector "Measurement" which is sorted according to increasing values. I get group IDs for the Measurement values by the use of the histc function.
[~,Measure_ID]=histc(Measurement_x,0:200:max);
In the next step I try to calculate the standard deviation with the accumarray function.
group_std = accumarray(Measure_ID,Measurement_y,[],@std);
The std command uses the follow mathematical formula:
The problem is that accumarray calculates the arithmetic average for each group separately. But I want to see the standard deviation regarding to the global arithmetic average. Is there a way to solve my issue?
Version: 2012b
  댓글 수: 1
Jan
Jan 2018년 7월 23일
편집: Jan 2018년 7월 23일
Do you mean:
std(Measurement_y)
? What exactly is "standard deviation regarding to the global arithmetic average"?

댓글을 달려면 로그인하십시오.

채택된 답변

Jan
Jan 2018년 7월 23일
편집: Jan 2018년 7월 23일
If you want to set the x_bar values of the formula to mean(Measurement_y), why not implementing this as function?
function s = specialStd(x, m)
s = sqrt(sum((x - m) .^ 2) / (length(x) - 1));
end
and call it like:
m = mean(Measurement_x);
group_std = accumarray(Measure_ID, Measurement_y, [], @(x) specialStd(x, m));
  댓글 수: 1
Guillaume
Guillaume 2018년 7월 23일
specialStd, notexactlystd, I think we can agree that this thing shouldn't be called plain std!

댓글을 달려면 로그인하십시오.

추가 답변 (1개)

Guillaume
Guillaume 2018년 7월 23일
"The problem is that accumarray calculates the arithmetic average for each group separately".
It's not accumarray doing that, it's std, because that the definition of the standard eviation.
To do what you want, you'll have to implement your own standard deviation calculation:
whole_mean = mean(Mesurement_y);
group_notexactlystd = accumarray(Measure_ID, Measurement_y, [], @(v) sum((v - whole_mean).^2)/(numel(v)-1));

카테고리

Help CenterFile Exchange에서 Surfaces, Volumes, and Polygons에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by