rollapply应用于xts对象

zsl*_*ius 3 r zoo xts

require(quantmod)
require(PerformanceAnalytics)
getSymbols('INTC')
x<- monthlyReturn(INTC)
rollapply(1+x,12,cumprod)
Run Code Online (Sandbox Code Playgroud)

给定上面的代码,我得到了这个错误

Error in array(r, dim = d, dimnames = if (!(is.null(n1 <- names(x[[1L]])) &  : 
  length of 'dimnames' [1] not equal to array extent
Run Code Online (Sandbox Code Playgroud)

我可以验证x的类确实是xts。

class(x)[1]“ xts”“ zoo”

我想rollapply适用于xts / zoo对象。我不确定如何在这里解决问题。

谢谢您的帮助。

更新资料

SessionInfo输出:

R version 2.15.3 (2013-03-01)
Platform: i686-pc-linux-gnu (32-bit)

locale:
 [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C               LC_TIME=en_US.UTF-8       
 [4] LC_COLLATE=en_US.UTF-8     LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
 [7] LC_PAPER=C                 LC_NAME=C                  LC_ADDRESS=C              
[10] LC_TELEPHONE=C             LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       

attached base packages:
[1] stats     graphics  grDevices utils     datasets  methods   base     

other attached packages:
[1] PerformanceAnalytics_1.1.0 quantmod_0.4-0             TTR_0.22-0                
[4] xts_0.9-3                  zoo_1.7-9                  Defaults_1.1-1            

loaded via a namespace (and not attached):
[1] grid_2.15.3     lattice_0.20-13 tools_2.15.3   
Run Code Online (Sandbox Code Playgroud)

Jos*_*ich 5

rollapply.xts假设函数为每个滚动窗口返回一个值。所以,你要么需要使用prodrollapply.xtscumprod有分流申请-结合的策略,这取决于你真正想做的事情。

rollapply(1+x,12,prod)
do.call(rbind, lapply(split(1+x,"years"), cumprod))
Run Code Online (Sandbox Code Playgroud)