R/modplot.R

Defines functions modTrack getTxDb genemodelOLD

genemodelOLD = function(sym, genome="hg19", annoResource=Homo.sapiens,
   getter=exonsBy, byattr="gene") {
 stopifnot(is.atomic(sym) && (length(sym)==1))
 if (!exists(dsa <- deparse(substitute(annoResource))))
    require(dsa, character.only=TRUE)
 num = select(annoResource, keys=sym, keytype="SYMBOL", 
    columns=c("ENTREZID", "SYMBOL"))$ENTREZID
 getter(annoResource, by=byattr)[[num]]
}

genemodel = function (key, keytype = "SYMBOL", annoResource = Homo.sapiens) 
{
    oblig = c("EXONCHROM", "EXONSTART", "EXONEND", "EXONSTRAND", 
        "EXONID")
    addrs = AnnotationDbi::select(annoResource, keys = key, keytype = keytype, 
        columns = oblig)
    ans = GRanges(addrs$EXONCHROM, IRanges(addrs$EXONSTART, addrs$EXONEND), 
        strand = addrs$EXONSTRAND, exon_id = addrs$EXONID)
    mcols(ans)[[keytype]] = key
    useq = unique(as.character(seqnames(ans)))
    si = seqinfo(annoResource)
    seqinfo(ans) = si[useq, ]
    ans
}


getTxDb = function(x) {
   if (is(x, "TxDb")) return(x)
   else if (is(x, "OrganismDb")) return(get(slot(x, "keys")[2,2]))
   else stop("getTxDb needs TxDb or OrganismDb") 
}
   #  TxDb.Hsapiens.UCSC.hg19.knownGene # PHONY ...
   # GeneRegionTrack fails for Homo.sapiens

modTrack = function(symbol,
   genome="hg19", annoResource=Homo.sapiens,
   getter=exonsBy, byattr="gene", expansion=0,
   collapseTranscripts="meta") {
 require(Gviz)
 m1 = genemodel(key=symbol, annoResource=annoResource)
 thechr = as.character(seqnames(m1)[1])
 st = min(start(m1)) - expansion
 en = max(end(m1)) + expansion
 GeneRegionTrack(getTxDb(annoResource), chromosome=thechr, start=st,
   end=en, showId=TRUE, collapseTranscripts=collapseTranscripts,
   geneSymbols=TRUE)
}


modPlot = function (symbol, genome = "hg19", annoResource = Homo.sapiens, 
    getter = exonsBy, byattr = "gene", 
    expansion = 0, collapseTranscripts = "meta", useGeneSym = 
       TRUE, plot.it=TRUE, ... ) {
    require(orgdrb <- deparse(substitute(annoResource)), character.only = TRUE)
#
# now value annoResource has global state, OrganismDb instance
#
    tr = modTrack(symbol, genome, annoResource, getter, byattr, 
        expansion, collapseTranscripts)
    entrez = tr@range$gene
  if (useGeneSym) {
    syms = select(annoResource, keys = entrez, keytype = "ENTREZID", 
        columns = "SYMBOL")$SYMBOL
    tr@range$symbol = syms
    }
    fin = list(tr, GenomeAxisTrack())
    curc = as.character(seqnames(tr@range)[1])
    fin[[1]]@name = paste0(symbol, " (", curc, ")")
    if (plot.it) plotTracks(fin, ...)
    invisible(fin)
}
genomicsclass/ph525x documentation built on July 16, 2022, 1:37 p.m.