gpt4 book ai didi

r - 将分组模型重新应用到数据上

转载 作者:行者123 更新时间:2023-12-04 11:48:56 25 4
gpt4 key购买 nike

我适合这样的模特

groupedTrainingSet = group_by(trainingSet, geo);
models = do(groupedTrainingSet, mod = lm(revenue ~ julian, data=.))

grouptedTestSet = group_by(testSet, geo);
// TODO: apply model back to test set

模型看起来像的地方
 geo     mod
1 APAC <S3:lm>
2 LATAM <S3:lm>
3 ME <S3:lm>
7 ROW <S3:lm>
4 WE <S3:lm>
5 NA <S3:lm>

我想我应该能够再次应用 'do' 但我没有看到它......或者我可以做一些类似的事情
apply(trainingData, fitted =
predict(select(models, geo==geo)$mod, .));

但我不确定那里的语法。

最佳答案

这是一个 dplyr获得类似答案的方法,遵循@Mike.Gahan 使用的方法:

library(dplyr) 

iris.models <- iris %>%
group_by(Species) %>%
do(mod = lm(Sepal.Length ~ Sepal.Width, data = .))

iris %>%
tbl_df %>%
left_join(iris.models) %>%
rowwise %>%
mutate(Sepal.Length_pred = predict(mod,
newdata = list("Sepal.Width" = Sepal.Width)))

或者,如果您创建一个预测函数,您可以一步完成:
m <- function(df) {
mod <- lm(Sepal.Length ~ Sepal.Width, data = df)
pred <- predict(mod,newdata = df["Sepal.Width"])
data.frame(df,pred)
}

iris %>%
group_by(Species) %>%
do(m(.))

关于r - 将分组模型重新应用到数据上,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24356683/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com