首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >具有交叉随机效应的`nlme`

具有交叉随机效应的`nlme`
EN

Stack Overflow用户
提问于 2018-08-03 20:29:11
回答 1查看 1.4K关注 0票数 7

我试图拟合一个交叉的非线性随机效应模型,作为线性随机效应模型,,如提到的在这个问题上,以及在这个邮寄名单邮寄中使用nlme软件包。不过,不管我尝试了什么,我都会犯错误。下面是一个例子

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

#####
# simulate data
set.seed(18112003)
na <- 30
nb <- 30

sigma_a <- 1
sigma_b <- .5
sigma_res <- .33

n <- na*nb

a <- gl(na,1,n)
b <- gl(nb,na,n)
u <- gl(1,1,n)

x <- runif(n, -3, 3)

y_no_noise <- x + sin(2 * x)
y <- 
  x + sin(2 * x) + 
  rnorm(na, sd = sigma_a)[as.integer(a)] + 
  rnorm(nb, sd = sigma_b)[as.integer(b)] + 
  rnorm(n, sd = sigma_res)

#####
# works in the linear model where we know the true parameter
fit <- lme(
  # somehow we found the right values
  y ~ x + sin(2 * x), 
  random = list(u = pdBlocked(list(pdIdent(~ a - 1), pdIdent(~ b - 1)))))
vv <- VarCorr(fit)
vv2 <- vv[c("a1", "b1"), ]
storage.mode(vv2) <- "numeric"
print(vv2,digits=4)
#R    Variance StdDev
#R a1    1.016 1.0082
#R b1    0.221 0.4701

#####
# now try to do the same with `nlme`
fit <- nlme(
  y ~ c0 + sin(c1),
  fixed = list(c0 ~ x, c1 ~ x - 1),
  random = list(u = pdBlocked(list(pdIdent(~ a - 1), pdIdent(~ b - 1)))), 
  start = c(0, 0.5, 1))
#R Error in nlme.formula(y ~ a * x + sin(b * x), fixed = list(a ~ 1, b ~  : 
#R    'random' must be a formula or list of formulae 

lme示例类似于“S和S+中的混合效应模型”的第163-166页,其中只有2个随机效应,而不是3个。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-11 10:15:32

我应该用一个用help("nlme")写的双面公式。

代码语言:javascript
复制
fit <- nlme(
  y ~ c0 + c1 + sin(c2),
  fixed = list(c0 ~ 1, c1 ~ x - 1, c2 ~ x - 1),
  random = list(u = pdBlocked(list(pdIdent(c0 ~ a - 1), pdIdent(c1 ~ b - 1)))), 
  start = c(0, 0.5, 1))

# fixed effects estimates
fixef(fit)
#R c0.(Intercept)           c1.x           c2.x 
#R     -0.1788218      0.9956076      2.0022338

# covariance estimates
vv <- VarCorr(fit)
vv2 <- vv[c("c0.a1", "c1.b1"), ]
storage.mode(vv2) <- "numeric"
print(vv2,digits=4)
#R       Variance StdDev
#R c0.a1   0.9884 0.9942
#R c1.b1   0.2197 0.4688
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51679728

复制
相关文章

相似问题

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