R/models.r

Defines functions load.models create.model meffonym.get.model meffonym.add.model meffonym.models

Documented in meffonym.add.model meffonym.get.model meffonym.models

#' List names of available models
#'
#' @export
meffonym.models <- function(full=F) {
    if (!full) {
        ls(models.global)
    } else {
        filename <- system.file("models.csv", package=packageName())
        if (!file.exists(filename))
            stop("The list of models doesn't exist, something really bad has happened!")    
        path <- dirname(filename)
        read.csv(filename, stringsAsFactors=F)    
    }
}

#' Add or update set of available models
#'
#' @param name Name of the model.
#' @param variables Names of CpG sites included in the model.
#' @param coefficients Coefficients of the CpG sites in the model.
#' @param intercept Model intercept (Default: 0).
#' @param description Text description of the model, e.g. publication.
#'
#' @export
meffonym.add.model <- function(name, variables, coefficients, description, intercept=0) {
    cat(date(), "Adding model: ", name, "\n")
    model <- create.model(variables, coefficients, intercept=intercept, description=description)
    assign(name, model, envir=models.global)
    invisible(TRUE)
}

#' Retrieve model details
#'
#' @param name Name of the model.
#' @return Model details formatted as a named list.
#' 
#' @export
meffonym.get.model <- function(name) {
    stopifnot(name %in% meffonym.models())
    get(name, envir=models.global)
}

create.model <- function(vars, coefs, intercept, description) {
    model <- list()
    if (is.vector(coefs)) {
        stopifnot(length(vars) == length(coefs))
        names(coefs) <- vars
        model$intercept=intercept
        vars <- c('intercept', vars)
    } else {
        stopifnot(is.matrix(coefs) || is.data.frame(coefs))
        rownames(coefs) <- vars
    }
    model$vars <- vars
    model$coefs <- coefs
    model$description <- description
    model
}

load.models <- function(pkgname) {
    filename <- system.file("models.csv", package=pkgname)
    if (!file.exists(filename))
        return
    
    path <- dirname(filename)
    models <- read.csv(filename, stringsAsFactors=F)

    for (i in 1:nrow(models)) {
        filename <- file.path(path, models$filename[i])
        ##cat("loading", filename, " ...\n")
        coefs <- read.csv(filename, stringsAsFactors=F)
        if (ncol(coefs) == 2) {
            pred.vars <- coefs$pred.var
            coefs <- coefs$coef
            if (!any(grepl("intercept", pred.vars, ignore.case=T))) {
                pred.vars <- c("intercept", pred.vars)
                coefs <- c(0,coefs)
            }
            intercept <- coefs[1]
            pred.vars <- pred.vars[-1]
            coefs <- coefs[-1]
        }
        else {
            pred.vars <- coefs$pred.var
            coefs$cpg <- NULL
            intercept <- 0
        }
        meffonym.add.model(
            models$name[i],
            pred.vars,
            coefs,
            intercept=intercept,
            description=paste(paste(colnames(models), models[i,], sep=":"), collapse=","))
    }
}
perishky/meffonym documentation built on Nov. 8, 2024, 8:36 p.m.