R/mkran.R

Defines functions mkran1 mkran

Documented in mkran mkran1

## Make random effects for mixed-effect models
mkran <- function(formula,data)
{
    ## decipher formula
    form.wk <- terms.formula(formula)[[2]]
    terms <- strsplit(deparse(form.wk),' \\+ ')[[1]]
    if (length(terms)>1) {
        form <- as.formula(paste("~",terms[1]))
        zzz <- mkran(form,data)
        for (i in 2:length(terms)) {
            form <- as.formula(paste("~",terms[i]))
            zzz <- mkran1(zzz,mkran(form,data))
        }
        return(zzz)
    }
    if (!("|"%in%strsplit(deparse(form.wk),'')[[1]]))
        stop("gss error in mkran: missing | in grouping formula")
    term.wk <- strsplit(deparse(form.wk),' \\| ')[[1]]
    with(data,{
        ## make matrix Z
        z2.wk <- eval(parse(text=term.wk[2]))
        if (!is.factor(z2.wk))
            stop(paste("gss error in mkran: ", term.wk[2], " should be a factor"))
        z <- NULL
        lvl.z2 <- levels(z2.wk)
        for (i in lvl.z2) z <- cbind(z,as.numeric(z2.wk==i))
        ## make sigma function
        if (term.wk[1]=="1") {
            init <- 0
            env <- length(levels(z2.wk))
            fun <- function(zeta,env) diag(10^(-zeta),env)
            sigma <- list(fun=fun,env=env)
        }
        else {
            z1.wk <- eval(parse(text=term.wk[1]))
            if (!is.factor(z1.wk))
                stop(paste("gss error in mkran: ", term.wk[1], " should be a factor"))
            ind <- lvl.wk <- NULL
            nz <- length(lvl.z2)
            nsig <- length(levels(z1.wk))
            for (i in levels(z1.wk)) {
                zz.wk <- z2.wk[z1.wk==i,drop=TRUE]
                ind <- c(ind,list((1:nz)[lvl.z2%in%levels(zz.wk)]))
                lvl.wk <- c(lvl.wk,levels(zz.wk))
            }
            if (max(table(lvl.wk)>1))
                stop("gss error in mkran: ", term.wk[2], " should be nested under ", term.wk[1])
            init <- rep(0, length(levels(z1.wk)))
            env <- list(size=nz,nsig=nsig,ind=ind)
            fun <- function(zeta,env) {
                wk <- rep(0,env$size)
                for (i in 1:env$nsig) wk[env$ind[[i]]] <- 10^(-zeta[i])
                diag(wk)
            }
            sigma <- list(fun=fun,env=env)
        }
        list(z=z,sigma=sigma,init=init)
    })
}

## Combine random effects for mixed-effect models
mkran1 <- function(ran1,ran2)
{
    z <- cbind(ran1$z,ran2$z)
    env <- list(sz1=dim(ran1$z)[2],sig1=ran1$sigma,nz1=length(ran1$init),
                sz2=dim(ran2$z)[2],sig2=ran2$sigma,nz2=length(ran2$init))
    fun <- function(zeta,env) {
        idx1 <- 1:env$sz1
        idx2 <- env$sz1+(1:env$sz2)
        sig <- matrix(0,env$sz1+env$sz2,env$sz1+env$sz2)
        sig[idx1,idx1] <- env$sig1$fun(zeta[1:env$nz1],env$sig1$env)
        sig[idx2,idx2] <- env$sig2$fun(zeta[env$nz1+(1:env$nz2)],env$sig2$env)
        sig
    }
    sigma <- list(fun=fun,env=env)
    list(z=z,sigma=sigma,init=c(ran1$init,ran2$init))
}

Try the gss package in your browser

Any scripts or data that you put into this service are public.

gss documentation built on Aug. 16, 2023, 9:07 a.m.