R/linest_get.R

Defines functions get_X.merMod get_X.default get_X .get_covariate_ave set_covariate_val get_vartypes set_xlevels get_contrasts.merMod get_contrasts.default get_contrasts get_xlevels.merMod get_xlevels.mer get_xlevels.default get_xlevels

Documented in get_contrasts get_contrasts.default get_contrasts.merMod get_vartypes get_X get_X.default get_xlevels get_xlevels.default get_xlevels.mer get_xlevels.merMod get_X.merMod set_covariate_val set_xlevels

## ######################################################################
##
## Auxillary functions for calculating contrasts, lsmeans etc
##
## Banff, August 2013, Søren Højsgaard
##
## ######################################################################

#' @title Auxillary functions for computing lsmeans, contrasts etc
#'
#' @description Auxillary functions for computing lsmeans, contrasts etc.
#'
#' @name linest-get
#'
#' @param obj An R object
#' @param xlev FIXME: to be described
#' @param at FIXME: to be described
#' @param covariateVal FIXME: to be described
#' @param newdata FIXME: to be described

#' @export
#' @rdname linest-get
get_xlevels <- function(obj){
  UseMethod("get_xlevels")
}

#' @export
#' @rdname linest-get
get_xlevels.default <- function(obj){
  obj$xlevels
}

#' @export
#' @rdname linest-get
get_xlevels.mer <- function(obj){
  ans <- lapply(obj@frame,levels)
  ans <- ans[unlist(lapply(ans, length))>0]

  nn <- names(attr(terms(obj), "dataClasses"))
  ii <- match(names(ans), nn)
  ii <- ii[!is.na(ii)]
  ans <- ans[nn[ii]]
  ans
}

#' @export
#' @rdname linest-get
get_xlevels.merMod <- function(obj){
  ##cat("get_xlevels.lmerMod\n")
  ans <- lapply(obj@frame,levels)
  ans <- ans[unlist(lapply(ans, length))>0]

  nn <-attr(terms(obj), "term.labels")
  ii <- match(names(ans), nn)
  ii <- ii[!is.na(ii)]
  ans <- ans[nn[ii]]
  ##print(ans)
  ans
}

#' @export
#' @rdname linest-get
get_contrasts <- function(obj){
  UseMethod("get_contrasts")
}

#' @export
#' @rdname linest-get
get_contrasts.default <- function(obj){
  obj$contrasts ## FIXME: check RL code
}

#' @export
#' @rdname linest-get
get_contrasts.merMod <- function(obj){
  attr(model.matrix(obj), "contrasts")
}

#' @export
#' @rdname linest-get
set_xlevels <- function(xlev, at){
  nam     <- names(xlev)
  nn      <- match(nam, names(at))
  nn      <- nn[!is.na(nn)]
  at.fact <- at[nn]
  xlev[names(at[nn])]   <- at.fact
  attr(xlev, "at.fact") <- at.fact
  xlev
}

#' @export
#' @rdname linest-get
get_vartypes <- function(obj){
    #cat("get_vartypes:\n")
    ## Common!!
    trms <- terms( model.frame( obj ))
    trms <- delete.response( trms )
    att  <- attributes( trms )
    #cat("factors:\n"); print(att$factors)
    if (length(att$factors) > 0){
        rhs.terms <- rownames(att$factors)[rowSums(att$factors) > 0]
        rhs.class <- att$dataClass[match(rhs.terms, names(att$dataClass))]
        nums      <- rhs.terms[rhs.class == "numeric"]
        ##print(list(rhs.terms=rhs.terms, rhs.class=rhs.class, nums=nums))
        fact      <- rhs.terms[rhs.class == "factor"]
    } else {
        nums <- character(0)
        rhs.class <- character(0)
        fact <- character(0)
    }

    ## END

    ## print("here")
    ## print(list(numeric=nums, factor=fact))
    list(numeric=nums, factor=fact)
}

#' @export
#' @rdname linest-get
set_covariate_val <- function(xlev, covariateVal){
  nam     <- names(xlev)
  nn      <- match(nam, names(covariateVal))
  nn      <- nn[!is.na(nn)]
  con.con <- covariateVal[nn]
  xlev[names(covariateVal[nn])] <- con.con
  xlev
}

.get_covariate_ave <- function(obj, at=NULL, tt=terms(obj)){
    ##cat(".get_covariate_ave:\n")
    ## Common!!
    trms <- terms( model.frame( obj ))
    trms <- delete.response( trms )
    att  <- attributes( trms )
    ##ff <<- att$factors
    if (length(att$factors)>0){
        rhs.terms <- rownames(att$factors)[rowSums(att$factors)>0]
        rhs.class <- att$dataClass[match(rhs.terms, names(att$dataClass))]
        nums      <- rhs.terms[rhs.class=="numeric"]
    } else {
        nums <- character(0)
        rhs.class <- character(0)
    }
    ##print(nums)
    ## END

    ## calculate average:
    ans  <- lapply(model.frame(obj)[,nums, drop=FALSE], mean)
    ##cat("ans:\n"); print(ans)
    nn   <- match(names(ans), names(at))
    nn   <- nn[!is.na(nn)]
    at.num <- at[nn]
    ans[names(at[nn])]  <- at.num
    ##cat("ans (after insertion of 'at' values):\n"); print(ans)
    attr(ans, "at.num") <- at.num
    ans
}



#' @export
#' @rdname linest-get
get_X <- function(obj, newdata, at=NULL){
  UseMethod("get_X")
}

#' @export
#' @rdname linest-get
#' 
get_X.default <- function(obj, newdata, at=NULL){
    ##cat("get_X.default\n"); print(newdata)
    tt <- terms(obj)
    Terms  <- delete.response(tt)

    offval <- NULL
    M <- attr(terms(formula(obj)), "factors")
    idx <- grep("offset\\(", rownames(M))

    if (length(idx) > 0){
        off    <- rownames(M)[idx]
        offvar <- gsub("offset\\((.*)\\)", "\\1\\", off)
        offval <-
            if (!is.null(at) && !is.null(at[offvar]))
                at[offvar]
            else 1
        d <- data.frame(rep(offval, nrow(newdata)))
        names(d) <- offvar
        newdata <- cbind(d, newdata)
    }

    mf  <- model.frame(Terms, newdata, xlev = get_xlevels(obj))
    X   <- model.matrix(Terms, mf, contrasts.arg = get_contrasts(obj))
    attr(X, "assign" )    <- NULL
    attr(X, "contrasts" ) <- NULL
    attr(X, "offset" )    <- offval
    X
}

#' @export
#' @rdname linest-get
get_X.merMod <- function(obj, newdata, at=NULL){
   tt <- terms(obj)
   Terms  <- delete.response(tt)
   mf  <- model.frame(Terms, newdata, xlev = get_xlevels(obj))
   X   <- model.matrix(Terms, mf, contrasts.arg = get_contrasts(obj))

   attr(X,"assign")     <- NULL
   attr(X, "contrasts") <- NULL
   X
}
hojsgaard/doBy documentation built on April 19, 2024, 12:05 a.m.