rollapply
将函数应用于数组的滚动边距。但它会逐列执行此操作。也就是说,它不会向您的函数呈现数组,而是呈现向量 N 次(在您的情况下为 N=2)。
这是一个例子:
(m <- matrix(1:10, ncol=2))
## [,1] [,2]
## [1,] 1 6
## [2,] 2 7
## [3,] 3 8
## [4,] 4 9
## [5,] 5 10
我们将rollapply
a mean
,看看在每次迭代中传递了什么:
y <- rollapply(m, width=2, FUN=function(x) {print(x); mean(x)})
## [1] 1 2
## [1] 2 3
## [1] 3 4
## [1] 4 5
## [1] 6 7
## [1] 7 8
## [1] 8 9
## [1] 9 10
没有矩阵传递给函数,只有单个向量。 rollapply
然后将结果打包为正确形状的数组:
y
## [,1] [,2]
## [1,] 1.5 6.5
## [2,] 2.5 7.5
## [3,] 3.5 8.5
## [4,] 4.5 9.5
解决方法是在格洛腾迪克先生的评论中,传递by.column=FALSE
给rollapply
:
z <- rollapply(m, width=2, by.column=FALSE, FUN=function(x) {print(x); colMeans(x)})
## [,1] [,2]
## [1,] 1 6
## [2,] 2 7
## [,1] [,2]
## [1,] 2 7
## [2,] 3 8
## [,1] [,2]
## [1,] 3 8
## [2,] 4 9
## [,1] [,2]
## [1,] 4 9
## [2,] 5 10
在这里,每行两行的矩阵都被传递给函数。结果和上面一样:
z
## [,1] [,2]
## [1,] 1.5 6.5
## [2,] 2.5 7.5
## [3,] 3.5 8.5
## [4,] 4.5 9.5