如何计算SAS中的累积乘积?

时间:2021-03-01 17:07:10

标签: sas

我需要创建一个变量,该变量取所有先前值的乘积,并包括当前 obs 中的值。

data temp;
input time cond_prob;
datalines;    
    1 1
    2 0.2
    3 0.3
    4 0.4
    5 0.6    
;
run;

最终数据应该是:

1 1
2 0.2 (1*0.2)
3 0.06 (0.2* 0.3)
4 0.024 (0.06 * 0.4
5 0.0144 (0.024 *0.6)

这看起来像一个简单的代码,但我无法让它工作。我可以做累积总和,但在使用相同逻辑时累积乘积不起作用。

1 个答案:

答案 0 :(得分:0)

使用 RETAIN 功能。 对于第一条记录,我将其设置为 1,因为任何乘以 1 的值都将保持不变。

data want;
set temp;

retain cum_product 1;

cum_product = cond_prob * cum_product;

run;