滞后函数返回 NA

mar*_*c1s 5 r lag dplyr

有人对使用dplyr包的这种结果有解释吗?

我有一个 data.frame df

    library(dplyr)
    df = data_frame(
      'id' = c(1,2,2,2,2,3,3,3,3),
      'start' = c(881, 1611, 1611, 1642, 1764, 0, 0, 28, 59),
      'end' = c(1089, 1819, 1819, 1850, 1972, 208,  208,236, 267))
Run Code Online (Sandbox Code Playgroud)

那看起来像

    # Source: local data frame [9 x 3]
    #
    # id start   end
    # (dbl) (dbl) (dbl)
    # 1     1   881  1089
    # 2     2  1611  1819
    # 3     2  1611  1819
    # 4     2  1642  1850
    # 5     2  1764  1972
    # 6     3     0   208
    # 7     3     0   208
    # 8     3    28   236
    # 9     3    59   267
Run Code Online (Sandbox Code Playgroud)

在按分组分组id并在结束列中应用滞后后,我希望每个id.

    df %>% 
      group_by(id) %>%
      mutate(end.prev = lag(end))
Run Code Online (Sandbox Code Playgroud)

但我有

    # Source: local data frame [9 x 4]
    # Groups: id [3]
    # 
    # id start   end end.prev
    # (dbl) (dbl) (dbl)    (dbl)
    # 1     1   881  1089       NA
    # 2     2  1611  1819       NA
    # 3     2  1611  1819     1819
    # 4     2  1642  1850     1819
    # 5     2  1764  1972     1850
    # 6     3     0   208       NA
    # 7     3     0   208       NA  <- I don't understant this NA
    # 8     3    28   236       NA  <- Neither this one
    # 9     3    59   267       NA  <- nor this other
Run Code Online (Sandbox Code Playgroud)

我正在使用 cran dplyr 0.4.3 中可用的最新版本(我的 R 版本是 3.2.5)