微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在 data.table 中的两列上滚动函数

如何解决在 data.table 中的两列上滚动函数

我有一个 data.table 如下 -

library(data.table)
dt = data.table(
  date = seq(as.Date("2015-12-01"),as.Date("2015-12-10"),by="days"),v1 = seq(1,10),v2 = c(5,rep(NA,9))
)
dt
          date v1 v2
 1: 2015-12-01  1  5
 2: 2015-12-02  2 NA
 3: 2015-12-03  3 NA
 4: 2015-12-04  4 NA
 5: 2015-12-05  5 NA
 6: 2015-12-06  6 NA
 7: 2015-12-07  7 NA
 8: 2015-12-08  8 NA
 9: 2015-12-09  9 NA
10: 2015-12-10 10 NA

我想滚动应用函数 qma 到 v1 的当前行值和 v2 的前一行值 qma <- function(x,y){(x+y+7)/2}

我相信一定有一种简单的方法可以使用 zoo::rollapplyr 或 data.table 在一行中做到这一点。

这是原始问题的后续问题R - Rolling sum of two columns in data.table

解决方法

对于这种递归计算,您可以在此处使用 Reduce :

library(data.table)

dt[,v2 := Reduce(qma,v1[-1],init = first(v2),accumulate = TRUE)]
dt

#          date v1       v2
# 1: 2015-12-01  1  5.00000
# 2: 2015-12-02  2  7.00000
# 3: 2015-12-03  3  8.50000
# 4: 2015-12-04  4  9.75000
# 5: 2015-12-05  5 10.87500
# 6: 2015-12-06  6 11.93750
# 7: 2015-12-07  7 12.96875
# 8: 2015-12-08  8 13.98438
# 9: 2015-12-09  9 14.99219
#10: 2015-12-10 10 15.99609

Reduceaccumulate = TRUE 一起使用时执行递归计算输出,其依赖于先前的输出。

举一个计算累计和的简单例子。

x <- 1:10
res <- Reduce(`+`,x,accumulate = TRUE)
res
#[1]  1  3  6 10 15 21 28 36 45 55

res[1]x[1]res[2]res[1] + x[2]res[3]res[2] + x[3],依此类推。

,

我们可以使用 accumulate 中的 purrr

library(dplyr)
library(purrr)
dt %>%
    mutate(v2 = accumulate(v1[-1],qma,.init = first(v2)))
#          date v1       v2
# 1: 2015-12-01  1  5.00000
# 2: 2015-12-02  2  7.00000
# 3: 2015-12-03  3  8.50000
# 4: 2015-12-04  4  9.75000
# 5: 2015-12-05  5 10.87500
# 6: 2015-12-06  6 11.93750
# 7: 2015-12-07  7 12.96875
# 8: 2015-12-08  8 13.98438
# 9: 2015-12-09  9 14.99219
#10: 2015-12-10 10 15.99609

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?