R/plotExpression.R

Defines functions defMapFun getPlotExpressionColors plotExpressionGraph

Documented in defMapFun getPlotExpressionColors plotExpressionGraph

plotExpressionGraph <- function(graph, nodeEGmap, exprs, ENTREZIDenvir,
                                mapFun, log=FALSE, nodeAttrs=list(), ...) {
    require("Rgraphviz") || stop("Requires Rgraphviz to continue")
    .plot.graph <- selectMethod("plot", "graph")

    envll <- unlist(contents(ENTREZIDenvir))
    graphEGs <- unlist(lapply(nodeEGmap, function(x){x[1]}))
    graphAffys <- names(envll)[envll %in% graphEGs]

    if (missing(mapFun))
        mapFun <- defMapFun

    cols <- getPlotExpressionColors(graphAffys, exprs, mapFun, log)

    ## Vector of colors w/ affy's as names - need SYMs
    colAffys <- names(cols)
    colEGs <- envll[colAffys]
    colSyms <- names(graphEGs[graphEGs %in% colEGs])
    names(cols) <- colSyms
    nodeAttrs$fillcolor <- cols

    .plot.graph(graph, nodeAttrs=nodeAttrs, ...)
}


getPlotExpressionColors <- function(graphAffys, exprs, mapFun, log=FALSE) {

    if (missing(mapFun))
        mapFun <- defMapFun

    affyCols <- mapFun(exprs, log)

    affyCols[names(affyCols) %in% graphAffys]
}

defMapFun <- function(exprs, log=FALSE) {
    part1 <- 100
    part2 <- 500

    if (log) {
        part1 <- log2(part1)
        part2 <- log2(part2)
    }

    cols <- unlist(lapply(exprs, function(x) {
        if (x <= part1)
            "blue"
        else if (x <= part2)
            "green"
        else
            "red"
    }))

    cols
}

Try the geneplotter package in your browser

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

geneplotter documentation built on Nov. 8, 2020, 7:13 p.m.