如何在其他矩阵中捕获立即数更大的指数?

时间:2013-09-15 14:14:22

标签: matlab binning

考虑例子

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]

请帮忙。

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。

编辑:

Eitan指出IF cB不是单调的,那么就存在问题。但是,在这种情况下,任何解决方案都存在问题,因为解决方案不是唯一的。如果没有提供更多信息,例如您是否需要第一个或最后一个合格的索引,那么对于完全通用的cB,问题没有有效的答案。例如,如果我们有:

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)