r - 使用glmnet之前如何进行所有交互

标签 r formula interaction glmnet

我有一个8列的x矩阵。我想运行glmnet进行套索回归。我知道我需要打电话:

glmnet(x, y, family = "binomial", ...). 


但是,如何使x也考虑所有单向交互?我是否必须手动重新制作数据框:如果是,是否有更简单的方法?我想我希望使用R公式来做一些事情。

最佳答案

是的,有一种方便的方法。其中的两个步骤很重要。

library(glmnet)
# Sample data
data <- data.frame(matrix(rnorm(9 * 10), ncol = 9))
names(data) <- c(paste0("x", 1:8), "y")
# First step: using .*. for all interactions
f <- as.formula(y ~ .*.)
y <- data$y
# Second step: using model.matrix to take advantage of f
x <- model.matrix(f, data)[, -1]
glmnet(x, y)

关于r - 使用glmnet之前如何进行所有交互,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27580267/

相关文章:

r - 将函数应用于同一组中的所有对

r - 如何在R中使用公式排除主要效应但保留相互作用

excel - 在excel上具有多个条件的平均值

html - 有没有一种方法可以轻松确定 Canvas 中绘制的形状已被单击?

R st_join 返回具有点属性的多边形

r - 使用 r 中的自定义颜色按因子着色图

python - 分析化学方程式,在Python中将括号外的子索引相乘

c - 使用嵌套 ifelse 语句在计算中排除某些条件变量

java - Spring MVC中Controller层和Service层如何实现正确的交互

c# - Xamarin.Forms 中没有交互性的覆盖层