首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >沿着向量搜索并计算平均值。

沿着向量搜索并计算平均值。
EN

Stack Overflow用户
提问于 2015-06-06 17:36:42
回答 3查看 142关注 0票数 5

我有如下数据:

代码语言:javascript
复制
require(data.table)
DT <- data.table(x=c(19,19,19,21,21,19,19,22,22,22),
             y=c(53,54,55,32,44,45,49,56,57,58))

我想沿着x搜索,并计算y的平均值。但是,当使用时。

代码语言:javascript
复制
DT[, .(my=mean(y)), by=.(x)]

我得到了x的重合值的总体平均值,我想沿着x搜索,每次x变化时,我想计算一个新的平均值。对于所提供的示例,输出如下:

代码语言:javascript
复制
DTans <- data.table(x=c(19,21,19,22),
             my=c(54,38,47,57))
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-06-06 17:39:21

我们可以使用rleid创建另一个分组变量,获取'y‘的mean,并将'indx’赋值为NULL。

代码语言:javascript
复制
library(data.table) # v 1.9.5+
DT[, .(my = mean(y)), by = .(indx = rleid(x), x)][, indx := NULL]
#    x my
#1: 19 54
#2: 21 38
#3: 19 47
#4: 22 57

基准测试

代码语言:javascript
复制
set.seed(24)
foo <- function(x) sample(x, 1e7L, replace = TRUE)
DT  <- data.table(x = foo(100L), y = foo(10000L))

josilber <- function() {
    new.group <- c(1, diff(DT$x) != 0)
    res <- data.table(x = DT$x[new.group == 1], 
              my = tapply(DT$y, cumsum(new.group), mean))
}

Roland <- function() {
    DT[, .(my = mean(y), x = x[1]), by = cumsum(c(1, diff(x) != 0))]
}

akrun <- function() { 
    DT[, .(my = mean(y)), by = .(indx = rleid(x), x)][,indx := NULL]
}

bgoldst <- function() {
    with(rle(DT$x), data.frame(x = values, 
       my = tapply(DT$y, rep(1:length(lengths), lengths), mean)))
}

system.time(josilber())
#   user  system elapsed 
#159.405   1.759 161.110 

system.time(bgoldst())
#   user  system elapsed 
#162.628   0.782 163.380 

system.time(Roland())
#   user  system elapsed 
# 18.633   0.052  18.678 

system.time(akrun())
#   user  system elapsed 
# 1.242   0.003   1.246 
票数 10
EN

Stack Overflow用户

发布于 2015-06-06 17:42:06

您可以识别连续元素的组,然后确定每个元素的平均值和值:

代码语言:javascript
复制
(new.group <- c(1, diff(DT$x) != 0))
# [1] 1 0 0 1 0 1 0 1 0 0
DT[, list(x = x[1L], my = mean(y)), by = list(indx = cumsum(new.group))]
#    indx  x my
# 1:    1 19 54
# 2:    2 21 38
# 3:    3 19 47
# 4:    4 22 57
票数 3
EN

Stack Overflow用户

发布于 2015-06-06 17:48:01

代码语言:javascript
复制
with(rle(DT$x),data.frame(x=values,my=tapply(DT$y,rep(1:length(lengths),lengths),mean)));
##    x my
## 1 19 54
## 2 21 38
## 3 19 47
## 4 22 57
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30685733

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档