Ich verwende das lme4
Paket in R, um eine logistische Modellierung mit gemischten Effekten durchzuführen.
Mein Verständnis war, dass die Summe aller zufälligen Effekte Null sein sollte.
Wenn ich mit Spielzeug lineare gemischte Modelle mache lmer
, sind die zufälligen Effekte normalerweise < was meine Überzeugung bestätigt, dass der
Aber in Spielzeug-Binomialmodellen (und in Modellen meiner realen Binomialdaten) ein Teil des Zufallseffekts zu ~ summiert 0,9.colSums(ranef(model)$groups) ~ 0
Sollte ich besorgt sein? Wie interpretiere ich das?
Hier ist ein lineares Spielzeugbeispiel
toylin<-function(n=30,gn=10,doplot=FALSE){
require(lme4)
x=runif(n,0,1000)
y1=matrix(0,gn,n)
y2=y1
for (gx in 1:gn)
{
y1[gx,]=2*x*(1+(gx-5.5)/10) + gx-5.5 + rnorm(n,sd=10)
y2[gx,]=3*x*(1+(gx-5.5)/10) * runif(1,1,10) + rnorm(n,sd=20)
}
c1=y1*0;
c2=y2*0+1;
y=c(t(y1[c(1:gn),]),t(y2[c(1:gn),]))
g=rep(1:gn,each=n,times=2)
x=rep(x,times=gn*2)
c=c(c1,c2)
df=data.frame(list(x=x,y=y,c=factor(c),g=factor(g)))
(m=lmer(y~x*c + (x*c|g),data=df))
if (doplot==TRUE)
{require(lattice)
df$fit=fitted(m)
plot1=xyplot(fit ~ x|g,data=df,group=c,pch=19,cex=.1)
plot2=xyplot(y ~ x|g,data=df,group=c)
print(plot1+plot2)
}
print(colMeans(ranef(m)$g))
m
}
In diesem Fall kommen die colMeans immer
Hier ist ein Beispiel für ein Binomialspielzeug (ich würde meine tatsächlichen Daten teilen, sie werden jedoch zur Veröffentlichung eingereicht, und ich bin mir nicht sicher, wie die Journalrichtlinie im Voraus lautet):
toybin<-function(n=100,gn=4,doplot=FALSE){
require(lme4)
x=runif(n,-16,16)
y1=matrix(0,gn,n)
y2=y1
for (gx in 1:gn)
{ com=runif(1,1,5)
ucom=runif(1,1,5)
y1[gx,]=tanh(x/(com+ucom) + rnorm(1)) > runif(x,-1,1)
y2[gx,]=tanh(2*(x+2)/com + rnorm(1)) > runif(x,-1,1)
}
c1=y1*0;
c2=y2*0+1;
y=c(t(y1[c(1:gn),]),t(y2[c(1:gn),]))
g=rep(1:gn,each=n,times=2)
x=rep(x,times=gn*2)
c=c(c1,c2)
df=data.frame(list(x=x,y=y,c=factor(c),g=factor(g)))
(m=lmer(y~x*c + (x*c|g),data=df,family=binomial))
if (doplot==TRUE)
{require(lattice)
df$fit=fitted(m)
print(xyplot(fit ~ x|g,data=df,group=c,pch=19,cex=.1))
}
print(colMeans(ranef(m)$g))
m
}
Jetzt liegen die colMeans manchmal über 0,3 und im Durchschnitt definitiv über dem linearen Beispiel.