考虑例子
a=rand(5,1)
b=rand(5,1);
bs=sum(b);
B=b./bs;
cB=cumsum(B)
%OUTPUT
a =
0.7803
0.3897
0.2417
0.4039
0.0965
cB =
0.0495
0.4030
0.7617
0.9776
1.0000
现在我希望cB中的数字位置立即大于a中的数字。 也就是说我想要对应于a中每个数字的5个位置。 所以我的输出应该是
P= [4;2;2;3;2]
请帮忙。
答案 0 :(得分:5)
其他人的建议是不错的,但两者都错过了重点,因为它们对于大问题效率低下。这是histc最好的工作。 (我承认histc显然不是解决这个问题的工具。我希望他们选择了一些更明显的名称,因为很少有人知道它.histc用于直方图,但也用于样条的评估。)
对于您的测试用例......
a = [0.7803 0.3897 0.2417 0.4039 0.0965];
cB = [0.0495 0.4030 0.7617 0.9776 1.0000];
[~,b] = histc(a,cB);
b = b + 1
b =
4 2 2 3 2
Histc返回目标下方元素的索引,因此您需要添加1。
编辑:
cB = [1 3 2 4];
a = 2.5;
有两种可能的解决方案可能会达到,因此索引为2或4.请注意,我必须在过去为客户提供完全解决此问题的解决方案,早在histc作为MATLAB中的工具提供之前很久。例如,在样条代码中,常见的问题是找到一个点落入的结间隔。当然,结必须按排序顺序排列。 (我将忽略复制中断的问题。)在样条代码中也存在一种情况,其中bin边缘不是按排序顺序,这是找到样条的反向值的情况,然后不需要单调的。在这种情况下,解决最合适的解决方案可能是合适的。只有客户才会做出这个决定。
由于cB在示例中生成严格单调,我只能假设单调性是这个问题的假设的一部分。
答案 1 :(得分:4)
试试这个:
pos = sum(bsxfun(@le, cB, a')) + 1
另一个(相当于一个循环):
pos = arrayfun(@(x) find(x < cB, 1, 'first'), a)