首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用mgcv进行变量选择

使用mgcv进行变量选择
EN

Stack Overflow用户
提问于 2016-07-25 22:58:40
回答 1查看 4.2K关注 0票数 5

有没有一种方法可以自动选择R中的GAM变量,类似于step?我已经阅读了step.gamselection.gam的文档,但是我还没有看到一个可以工作的代码的答案。此外,我还尝试了method= "REML"select = TRUE,但都没有从模型中删除无关紧要的变量。

我的理论是,我可以创建一个步骤模型,然后使用这些变量来创建GAM,但这似乎在计算上并不有效。

示例:

代码语言:javascript
复制
library(mgcv)

set.seed(0)
dat <- data.frame(rsp = rnorm(100, 0, 1), 
                  pred1 = rnorm(100, 10, 1), 
                  pred2 = rnorm(100, 0, 1), 
                  pred3 = rnorm(100, 0, 1), 
                  pred4 = rnorm(100, 0, 1))

model <- gam(rsp ~ s(pred1) + s(pred2) + s(pred3) + s(pred4),
             data = dat, method = "REML", select = TRUE)

summary(model)

#Family: gaussian 
#Link function: identity 

#Formula:
#rsp ~ s(pred1) + s(pred2) + s(pred3) + s(pred4)

#Parametric coefficients:
#            Estimate Std. Error t value Pr(>|t|)
#(Intercept)  0.02267    0.08426   0.269    0.788

#Approximate significance of smooth terms:
#            edf Ref.df     F p-value  
#s(pred1) 0.8770      9 0.212  0.1174  
#s(pred2) 1.8613      9 0.638  0.0374 *
#s(pred3) 0.5439      9 0.133  0.1406  
#s(pred4) 0.4504      9 0.091  0.1775  
---
#Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

#R-sq.(adj) =  0.0887   Deviance explained = 12.3%
#-REML = 129.06  Scale est. = 0.70996   n = 100
EN

回答 1

Stack Overflow用户

发布于 2016-07-26 02:38:06

Marra和Wood (2011,计算统计和数据分析55;2372-2387)比较了GAM中特征选择的各种方法。他们得出结论,在平滑度选择过程中增加一个惩罚项可以得到最好的结果。这可以在mgcv::gam()中通过使用select = TRUE参数/设置或以下任何变体激活:

代码语言:javascript
复制
model <- gam(rsp ~ s(pred1,bs="ts") + s(pred2,bs="ts") + s(pred3,bs="ts") + s(pred4,bs="ts"), data = dat, method = "REML")
model <- gam(rsp ~ s(pred1,bs="cr") + s(pred2,bs="cr") + s(pred3,bs="cr") + s(pred4,bs="cr"),
             data = dat, method = "REML",select=T)
model <- gam(rsp ~ s(pred1,bs="cc") + s(pred2,bs="cc") + s(pred3,bs="cc") + s(pred4,bs="cc"),
             data = dat, method = "REML")
model <- gam(rsp ~ s(pred1,bs="tp") + s(pred2,bs="tp") + s(pred3,bs="tp") + s(pred4,bs="tp"), data = dat, method = "REML")
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38571145

复制
相关文章

相似问题

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