r - 多子集延迟

标签 r plyr lag

我相信 ddply 是我完成任务所需的工具,而且我在获得正确结果时遇到了一些困难。我已经阅读了几个小时关于 ddply 的文章,并尝试了不同的代码,但我自己没有进一步了解。
这是一个示例数据框

station <- c(rep("muc",13), rep("nbw", 17))
year <- c(rep(1994,4),rep(1995,4),rep(1996,5),rep(1994,5), rep(1995,4), rep(1996,4), rep(1997, 4))
depth <- c(rep(c("HUM","31-60","61-90","91-220"),2), rep(c("HUM","0-30", "31-60","61-90","91-220"),2),rep(c("HUM","0-30", "31-60","91-220"),1),rep(c("HUM","0-30", "31-60","61-90"),2))
doc <- c(80, 10, 3, 2,70, 15, 5, 5,70, 20, 5, 5, 2, 40, 10, 3, 2, 1,50, 15, 5, 2, 45, 20, 2, 1,35, 8, 2, 1)

df <-data.frame(station,year,depth,doc)
df

深度是指土壤深度(HUM=腐殖质层),doc 是测量的土壤深度溶解有机碳 (doc)。请注意,并非每年都有针对文档的测量,并且缺少一些深度类。这很烦人,但经常出现在我的数据集中。
使用 ddply 我想向该数据框中添加一列,以便对于每个深度,返回上述土壤层的文档,并且应该给出 HUM NA,因为腐殖质层顶部没有任何东西。
举个例子:
depth   doc  doc_m1
HUM     80   NA
31-60   10   80
61-90   3    10
91-220  2    3

在数据框中,这当然应该针对每年和每个深度进行计算。我想避免 which 和 for 循环,似乎 ddply 适合于此,但是我没有运气获得滞后命令来使用 ddply。
这是我得到的代码(显然不是很远):
doc <- ddply(df, .(year), transform,
      doc_m1 = ????)

有人有建议吗?
提前致谢!

最佳答案

如果您的数据集中的深度已经按正确顺序排列(如您的示例中所示),您可以这样做:

doc2 <- ddply(df, .(station, year), transform,
      doc_m1 = c(NA, doc[-length(doc)]))

注意我也在车站分组。这给出:
> head(doc2, 10)
   station year  depth doc doc_m1
1      muc 1994    HUM  80     NA
2      muc 1994  31-60  10     80
3      muc 1994  61-90   3     10
4      muc 1994 91-220   2      3
5      muc 1995    HUM  70     NA
6      muc 1995  31-60  15     70
7      muc 1995  61-90   5     15
8      muc 1995 91-220   5      5
9      muc 1996    HUM  70     NA
10     muc 1996   0-30  20     70

如果它们尚未按深度排序,则将深度作为具有正确顺序的级别的因子,然后据此进行排序。那么这种方法应该有效。

关于r - 多子集延迟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9497365/

相关文章:

java - 如果你在 R 中创建了一个函数,你如何使用 Renjin 在 Java 中调用它?

r - 组合取消分类因子变量

r - R 中 ddply 的小计

r - 如何使用数据表获取 R 中自上次日期(滞后)以来的时间差?

ios - iPad 中 UITableView 中的 CALayer setCornerRadius 滞后?

r - 如何在 R 中将逗号和冒号分隔的列拆分为相应的列?

r - 如何在 R 中编写最大似然例程?

r - 数据框子集内的计算 [R]

r - 将列表中的 data.frames 堆叠到单个 data.frame 中,将名称(列表)保留为额外的列

java - (Java) 在控制台中逐个字母地打印文本 - ft. Lag