我有一个矩阵m,并绘制了第三列的直方图。我搜索前100个柱子中的峰值,得到频率为a,柱子的索引为b。现在,我需要索引为b的存储箱的边缘。我怎样才能得到它们呢?
nbins = 1000;
histo = histogram(m(:,3),nbins,'Orientation','horizontal');
[a,b] = max(histo.Values(1:100))发布于 2017-01-06 20:30:34
我可以想到两种简单的方法来做到这一点:
function q41505566
m = randn(10000,5);
nBins = 1000;
% Option 1: using histcounts:
[N,E] = histcounts(m(:,3),nBins);
disp(E(find(N(1:100) == max(N(1:100)),1,'first')+[0 1])); % find() returns the left bin edge
% Option 2: using BinEdges:
histo = histogram(m(:,3),nBins,'Orientation','horizontal');
[a,b] = max(histo.Values(1:100));
disp(histo.BinEdges(b:b+1));如果你需要一个“花招”的解释,请说出来。
https://stackoverflow.com/questions/41505566
复制相似问题