inst/scripts/twins-sampling.R

data("twinbmi",package="mets")
library(svylme)
library(lme4)
library(Matrix)
I_twin<-with(twinbmi, Matrix(outer(1:nrow(twinbmi),1:nrow(twinbmi),function(i,j) (id[i]==id[j]) & (i!=j))))
I_mz<-with(twinbmi, Matrix(outer(1:nrow(twinbmi),1:nrow(twinbmi),function(i,j) (id[i]==id[j]) & (zyg[i]=="MZ") & (i!=j))))

n<-nrow(I_twin)
Phi_env<-I_twin+Diagonal(n)
Phi_add<-I_twin/2+I_mz/2+Diagonal(n)
Phi_dom<-I_twin/4+I_mz*3/4+Diagonal(n)

dimnames(Phi_env)<-list(twinbmi$id,twinbmi$id)
dimnames(Phi_add)<-list(twinbmi$id,twinbmi$id)
dimnames(Phi_dom)<-list(twinbmi$id,twinbmi$id)


twinbmi$id2<-twinbmi$id
twinbmi$id3<-twinbmi$id

## sampling

## whole twins

twinbmi$dbmi<-with(twinbmi, ave(bmi,id, FUN=function(v) if (length(v)>1) abs(diff(v)) else 0))

dup<-duplicated(twinbmi$id)
uid<-twinbmi$id[!dup]
udbmi<-twinbmi$dbmi[!dup]
twinbmi$strata<-cut(twinbmi$dbmi, quantile(udbmi,(1:5)/5), include.lowest=TRUE) 
nsample<-c(50,50,150,400)
names(nsample)<-levels(twinbmi$strata)

results<-replicate(1000,{tryCatch({

insample<- twinbmi$id %in% uid[stratsample(twinbmi$strata[!dup], nsample)]
twinbmi$fpc<-1383
des<-svydesign(id=~id,data=twinbmi[insample,], strata=~strata, fpc=~fpc)



## environment
a<-svy2lme(bmi ~ age+gender+(1|id), design=des)
b<-lme4::lmer(bmi ~ age+gender+(1|id),data=twinbmi[insample,])
##svy2lme(bmi ~ age+gender+(1|id), design=des,all.pairs=TRUE,subtract.margins=TRUE)

## environment plus additive genetic
d<-svy2relmer(bmi ~ age+gender+(1|id)+(1|id2), design=des,relmat=list(id=Phi_env,id2=Phi_add))
e<-lme4qtl::relmatLmer(bmi ~ age+gender+(1|id)+(1|id2), data=twinbmi[insample,],relmat=list(id=Phi_env,id2=Phi_add))

r1<-list(a=c(coef(a),sqrt(unlist(coef(a, random=TRUE))[2:1])),
     b=c(fixef(b),c(sqrt(unlist(VarCorr(b)[1])),attr(VarCorr(b),"sc"))),
     d=c(coef(d),sqrt(unlist(coef(d, random=TRUE))[c(2,5,1)])),
     e=c(fixef(e),c(sqrt(unlist(VarCorr(e)[1:2])),attr(VarCorr(e),"sc")))
)

## individuals

twinbmi$keep<-rbinom(nrow(twinbmi), 1, .5)
twinsubsample <- subset(twinbmi[insample,], keep==1)
twinsubsample$fpc2<-2
iid<-1:nrow(twinsubsample)
des2<-svydesign(id=~id+iid,data=twinsubsample, strata=~strata, fpc=~fpc+fpc2)

## environment
A<-svy2lme(bmi ~ age+gender+(1|id), design=des2)
##lme4::lmer(bmi ~ age+gender+(1|id),data=twinsubsample)
B<-svy2lme(bmi ~ age+gender+(1|id), design=des2,all.pairs=TRUE,subtract.margins=TRUE)

## environment plus additive genetic
D<-svy2relmer(bmi ~ age+gender+(1|id)+(1|id2), design=des2,relmat=list(id=Phi_env,id2=Phi_add))
##lme4qtl::relmatLmer(bmi ~ age+gender+(1|id)+(1|id2), data=twinsubsample,relmat=list(id=Phi_env,id2=Phi_add))
E<-svy2relmer(bmi ~ age+gender+(1|id)+(1|id2), design=des2,relmat=list(id=Phi_env,id2=Phi_add),all.pairs=TRUE,subtract.margins=TRUE)


r2<-list(A=c(coef(A),sqrt(unlist(coef(A, random=TRUE))[2:1])),
     B=c(coef(B),sqrt(unlist(coef(B, random=TRUE))[2:1])),
     D=c(coef(D),sqrt(unlist(coef(D, random=TRUE))[c(2,5,1)])),
     E=c(coef(E),sqrt(unlist(coef(E, random=TRUE))[c(2,5,1)]))
)

c(r1,r2)
}, error=function(e) NULL)
})

save(results, file="twin-sampling.rda")
tslumley/svylme documentation built on Feb. 10, 2024, 11:01 p.m.