首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >具有多项式项的lmer模型的边际效应计算

具有多项式项的lmer模型的边际效应计算
EN

Stack Overflow用户
提问于 2020-01-10 01:11:48
回答 1查看 498关注 0票数 1

我试图用lme4量化混合模型中变量的影响大小,但我似乎无法让它与创建两个变量之间的非线性交互的poly()函数一起工作。

代码语言:javascript
运行
复制
library(lme4)
library(lmerTest)
library(readr)

mydata <- read_csv("https://raw.githubusercontent.com/HaydenSchilling/Example_code_and_data/master/example_data2.csv")

m1 <- lmer(CPUE.standardised ~ poly(cbind(X135_degree_winds.standardised, 
       X45_degree_winds.standardised), degree = 2) + 
       Estuary_Type * Drought_Months + (1|Estuary), data = mydata)

anova(m1)
summary(m1)

library(ggeffects)
ggpredict(m1, terms = "X135_degree_winds.standardised")

最后一行给出了错误:

错误:无法在.data中找到列cbind。调用rlang::last_error()查看回溯跟踪

我尝试过ggeffectssjPlot包,但都遇到了cbind命令的问题,或者找不到指定的变量。如果有人有任何解决办法,我将非常感激!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-01-12 22:25:31

根据我收到的评论回答我自己的问题。问题在于我在多项式中的cbind命令。解决方案是将模型结构更改为不包括cbind

一个与原问题中的模型等价的模型是:

代码语言:javascript
运行
复制
m2 <- lmer(CPUE.standardised ~ poly(X135_degree_winds.standardised, degree = 2) + 
   poly(X45_degree_winds.standardised, degree = 2) + 
   X135_degree_winds.standardised:X45_degree_winds.standardised+ 
   Estuary_Type * Drought_Months + (1|Estuary), data = mydata)

这样就可以计算边际效应。

还建议改进模型结构如下:

代码语言:javascript
运行
复制
poly(X135_degree_winds.standardised, degree = 2)*
 poly(X45_degree_winds.standardised, degree = 2)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59674317

复制
相关文章

相似问题

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