How to split data set into multiple bins and perform condition statement on bins
7 ビュー (過去 30 日間)
古いコメントを表示
I have a logical data set and I am trying to divide it into 31 bins but my data points are not evenly distributing and I need it to be divided into 31 bins so that I can then run an if statement that counts the total number of ones in each bin and compares it to a condition.
0 件のコメント
回答 (1 件)
Matt J
2022 年 3 月 24 日
編集済み: Matt J
2022 年 3 月 24 日
Use the discretize() command.
to assign bin labels to each of your data points.
11 件のコメント
Matt J
2022 年 3 月 25 日
編集済み: Matt J
2022 年 3 月 25 日
So my example should give me a count of 3.
No, that would depnd on how the data is split into subsets. Even without randomization, a subset may contain no ones, like in the following, where the subsets are sequential.
Data = [0 0 0 1 0 1 1 0 1 1 1 0];
binLabels=[1 1 1 2 2 2 2 3 3 3 3 3];
numOnes=accumarray(binLabels',Data')
overallCount = sum(numOnes>=1)
Once again, because you haven't specified the details of the processing with enough care and detail, we get a result you don't expect. Perhaps you meant for the subsets to be interleaved. That does give your expected result:
binLabels=[1 2 3 1 2 3 1 2 3 1 2 3];
numOnes=accumarray(binLabels',Data')
overallCount = sum(numOnes>=1)
参考
カテゴリ
Help Center および File Exchange で Curve Fitting Toolbox についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!