各组累计最小值 [英] Cumulative minimum value by group
本文介绍了各组累计最小值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想计算给定组内的累积 min
。
I want to calculate cumulative min
within a given group.
我当前的数据帧:
Group <- c('A', 'A', 'A','A', 'B', 'B', 'B', 'B')
Target <- c(1, 0, 5, 0, 3, 5, 1, 3)
data <- data.frame(Group, Target))
我想要的输出:
Desired.Variable <- c(1, 0, 0, 0, 3, 3, 1, 1)
data <- data.frame(Group, Target, Desired.Variable))
对此将提供任何帮助!
推荐答案
cummin
按组的功能
data$output <- with(data, ave(Target, Group, FUN = cummin))
data
# Group Target output
#1 A 1 1
#2 A 0 0
#3 A 5 0
#4 A 0 0
#5 B 3 3
#6 B 5 3
#7 B 1 1
#8 B 3 1
dplyr
和 data.table
等价物是
library(dplyr)
data %>%
group_by(Group) %>%
mutate(output = cummin(Target))
library(data.table)
setDT(data)[, output := cummin(Target), by = (Group)]
这篇关于各组累计最小值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文