滚动累计积
Rolling cumulative product
我有这样的数据
A B
1 1 1
2 3
3 5
4 7
我想在 B 列中计算以下滚动累积乘积。在 Excel 中,我将有以下公式
B2 = (1 + A2/10)*B1
到目前为止,我已经尝试使用一个辅助列,它是 1 + Ax/100 的结果,一个完全相同的列只是滞后 1,然后相互相乘。由于未应用滚动产品,这将不起作用。我也试过s.th喜欢
rollapply(columnm,1,FUN = prod, fill = NA, align = 'left')
不幸的是,它仍然不起作用。
我希望得到 B 的这些结果
A B
1 1 1
2 3 1.3
3 5 1.95
4 7 3.315
[编辑]
作为对原始问题的扩展,有没有一种方法可以在基于附加列的 ifelse 语句中执行相同的滚动乘积?
A B C
1 1 1 1
2 3 1 1
3 5 0
4 7 0
excel 相当于
C3 = IF(B3=0,(1+A3/10)*C2,1)
我无法为这种情况找到可接受的解决方案,因为它始终只引用 A 列中的数据,而我最终得到的结果与之前的解决方案相同。
我希望得到以下结果
A B C
1 1 1 1
2 3 1 1
3 5 0 1.5
4 7 0 2.55
提前致谢
这是你想要的吗?
A=c(1,3,5,7)
cumprod(c(1,(A[-1]/10+1)))
> cbind(A,B=cumprod(c(1,(A[-1]/10+1))))
A B
[1,] 1 1.000
[2,] 3 1.300
[3,] 5 1.950
[4,] 7 3.315
我有这样的数据
A B
1 1 1
2 3
3 5
4 7
我想在 B 列中计算以下滚动累积乘积。在 Excel 中,我将有以下公式
B2 = (1 + A2/10)*B1
到目前为止,我已经尝试使用一个辅助列,它是 1 + Ax/100 的结果,一个完全相同的列只是滞后 1,然后相互相乘。由于未应用滚动产品,这将不起作用。我也试过s.th喜欢
rollapply(columnm,1,FUN = prod, fill = NA, align = 'left')
不幸的是,它仍然不起作用。
我希望得到 B 的这些结果
A B
1 1 1
2 3 1.3
3 5 1.95
4 7 3.315
[编辑]
作为对原始问题的扩展,有没有一种方法可以在基于附加列的 ifelse 语句中执行相同的滚动乘积?
A B C
1 1 1 1
2 3 1 1
3 5 0
4 7 0
excel 相当于
C3 = IF(B3=0,(1+A3/10)*C2,1)
我无法为这种情况找到可接受的解决方案,因为它始终只引用 A 列中的数据,而我最终得到的结果与之前的解决方案相同。
我希望得到以下结果
A B C
1 1 1 1
2 3 1 1
3 5 0 1.5
4 7 0 2.55
提前致谢
这是你想要的吗?
A=c(1,3,5,7)
cumprod(c(1,(A[-1]/10+1)))
> cbind(A,B=cumprod(c(1,(A[-1]/10+1))))
A B
[1,] 1 1.000
[2,] 3 1.300
[3,] 5 1.950
[4,] 7 3.315