Skip subs/index values with accumarray

5 ビュー (過去 30 日間)
leonidas86
leonidas86 2018 年 6 月 7 日
コメント済み: Walter Roberson 2018 年 6 月 7 日
I created an index (groupID) for a vector A. The vector is sorted from the smallest value to the biggest one. The function and the groupID look like:
[~,groupID]=histc(A,0:5:100);
groupID = [1 1 3 3 3 5 5];
In the next step I want to calculate the average for every groupID. I did this as follows:
groupMeans = accumarray(groupID,A,[],@mean);
My problem is that accumarray fills in the output array for every skipped groupID (because e.g. 2 and 4 are missing in the index) a zero. I dont want these zeros in my output array. Is there a solution for this? My Matlab version is R2012b

採用された回答

Stephen23
Stephen23 2018 年 6 月 7 日
編集済み: Stephen23 2018 年 6 月 7 日
Use unique's third output to get the indices:
[uni,~,idx] = unique(groupID(:));
groupMeans = accumarray(idx,A,[],@mean);
[uni,groupMeans]
  5 件のコメント
Stephen23
Stephen23 2018 年 6 月 7 日
編集済み: Stephen23 2018 年 6 月 7 日
"How can I do this?"
The histc help explains how the second input defines the bin ranges. If you want to change the bin ranges to make wider bins then you need to change the vector that you used (to have a larger step size).
Walter Roberson
Walter Roberson 2018 年 6 月 7 日
In the original posting you used
histc(A,0:5:100);
This would create 21 bins, [0 5 10 15 20 ... 100]. To increase the width of your bins in this case you would use an increment larger than 5, such as 0:8:100 .
Note: more robust would be to use linspace(0, 100, N) where N is the number of bins you wanted.
hist() and histcounts() permit you to pass the number of bins directly.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeStructures についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by