Rollapply在R中打破并重新开始?

时间:2014-02-21 18:41:28

标签: r rollapply

我的数据框看起来像

z<-data.frame(a=c(seq(1990,1995,1), 1997,1998,1999,2001,2002,2003), b=seq(90,101,1))

我使用功能

rollapply(b, 3, sd, align='right') 

计算标准差。

我想要做的是功能中断并开始计算标准偏差 如果连续几年之间存在差距,请再次。

编辑:

我的示例输出应如下所示:

enter code here       a   b    c
                 1  1990  90  NA
                 2  1991  91  NA
                 3  1992  92  sd(90,91,92)
                 4  1993  93  sd(93,92,91)
                 5  1994  94  sd(94,93,92)
                 6  1995  95  sd(95,94,93)
                 7  1997  96  NA
                 8  1998  97  NA
                 9  1999  98  sd(98,97,96)
                10  2001  99  NA
                11  2002  100 NA
                12  2003  101 sd(101,100,99)

2 个答案:

答案 0 :(得分:2)

我认为这可以满足您的需求:

my.roll <- function(x) rollapply(x, 3, sd, align='right', fill=NA, na.rm=T)
z$sd <- ave(z$b, c(0, cumsum(diff(z$a) - 1)), FUN=my.roll) 

产地:

      a   b sd
1  1990  90 NA
2  1991  91 NA
3  1992  92  1
4  1993  93  1
5  1994  94  1
6  1995  95  1
7  1997  96 NA
8  1998  97 NA
9  1999  98  1
10 2001  99 NA
11 2002 100 NA
12 2003 101  1

请注意每个间隔后面的前两个条目是NA,因为您的窗口中至少需要三个值。

基本上,我们在这里做的是使用cumsumdiff来确定连续年份的块,然后我们可以使用ave来应用sd每个街区。请注意,如果您重复多年(例如1997年显示2次或更多次),或者您的数据未按年份排序,这将会中断。

答案 1 :(得分:1)

将data.frame转换为动物园对象z,并将其与所有年份的网格g合并,包括z中未找到的网格。将rollapplyr应用于此并提取原始时间:

library(zoo)

z <- read.zoo(DF, FUN = identity)
g <- merge(z, zoo(, start(z):end(z)))
r <- rollapplyr(g, 3, sd, fill = NA)[I(time(z))]

,并提供:

> r
1990 1991 1992 1993 1994 1995 1997 1998 1999 2001 2002 2003 
  NA   NA    1    1    1    1   NA   NA    1   NA   NA    1 

r是一个动物园对象,time(r)是时间,coredata(r)是数据。

注意:我们使用过:

DF <- structure(list(V1 = c(1990L, 1991L, 1992L, 1993L, 1994L, 1995L, 
  1997L, 1998L, 1999L, 2001L, 2002L, 2003L), V2 = 90:101), .Names = c("V1", 
  "V2"), class = "data.frame", row.names = c(NA, -12L))