我有一列1000个随机数,我想计算一个窗口长度为10的滚动和,在Excel或R中,对于前10个观察,滚动和仍然应该用部分窗口长度来计算。不过,我没有在Excel或R中找到滚动和功能。
我目前在R中的尝试是使用循环。然而,循环工作正常,效率很低。请看下面我的尝试。
vector = as.vector(matrix(1,1000,nrow = 1))
for (i in 1:1000) {
if (i<11) {
rolling.sum[i]=sum(vector[1:i])
} else {
rolling.sum[i] = sum(vector[(i-10):i])
}
}
发布于 2017-10-11 21:35:33
我已经想出了一种在R中这样做的方法,它使用了动物园包中的rollapply函数。使用rollapply(),输入值向量作为第一个参数,窗口长度作为第二个参数,然后指示它应该是滚动和。最后一个参数指出,当窗口长度不够长时,它还计算部分和。请注意,宽度参数必须指定窗口是向前看还是向后看。例子如下:
vector = as.vector(matrix(1,1000,nrow = 1))
rolling.sum<<-rollapply(vector, width = list(-1:-10), sum, partial=T)
发布于 2015-10-05 08:21:49
为了保持标题的精神,在另一个单元格中随意使用,将1
(或您选择的不同的起始值)放在一个单元格中,> Editing,Series .,选择列in,Linear,输入1
作为步骤值:和(“在单元格旁边”)停止值:无论你想要什么限制/先例值,都行。
https://stackoverflow.com/questions/31924324
复制相似问题