我想计算一列移动年度总和的大数据集。它必须是确切的一年,所以我不能将rollapply用作基于特定天数的日期而不是实际日期。根据日期移动总和
作为一个例子,我有以下代码:
dates = seq.Date(as.Date('2006-01-01'),as.Date('2007-12-31'),by='days')
num = 1:length(dates)
y = cbind(ld,num)
ld num
[1,] 13149 1
[2,] 13150 2
[3,] 13151 3
[4,] 13152 4
[5,] 13153 5
[6,] 13154 6
我想有柱NUM的轧一十年历史的总和。
我设法解决它的唯一方法是使用循环和数据框的子集。这不是很有效率,我希望有人能够告诉我如何使用嵌入函数来解释闰年,因为它更快。
使用嵌入函数,只要它不是闰年,我就有以下代码。
b = embed(y[,2],366)
sums = colSums(b)
a = ld[length(dates)-365:length(dates)]
final = cbind(dates = a, rollsum = rev(sums))
head(final)
dates rollsum
[1,] 13513 66795
[2,] 13514 67160
[3,] 13515 67525
[4,] 13516 67890
[5,] 13517 68255
[6,] 13518 68620
不要任何人有根据特定的日期计算移动和的更有效的方式,而不是天数?