Mercurial > repos > artbio > small_read_size_histograms
view size_histogram.r @ 0:234b83159ea8 draft
planemo upload for repository https://github.com/ARTbio/tools-artbio/tree/master/tools/small_read_size_histograms commit ab983b2e57321e8913bd4d5f8fc89c3223c69869
author | artbio |
---|---|
date | Tue, 11 Jul 2017 11:44:36 -0400 |
parents | |
children |
line wrap: on
line source
## Setup R error handling to go to stderr options( show.error.messages=F, error = function () { cat( geterrmessage(), file=stderr() ); q( "no", 1, F ) } ) library(RColorBrewer) library(lattice) library(latticeExtra) library(grid) library(gridExtra) library(optparse) # Parse arguments option_list <- list( make_option(c("-g", "--global"), type="character", help="Whether distribution is plotted globally or by chromosome"), make_option(c("-s", "--size_distribution_tab"), type="character", help="Path to file with tabular size distribution"), make_option("--size_distribution_pdf", type="character", help="Path to file with size distribution plot"), make_option("--title", type="character", help="Title for readmaps and size distribution"), make_option("--ylabel", type="character", help="ylabel for readmaps and size distribution"), make_option("--yrange", type="integer", help="Y-axis range"), make_option("--rows_per_page", type="integer", help="rows_per_page") ) parser <- OptionParser(usage = "%prog [options] file", option_list=option_list) args = parse_args(parser) ##cheetahtemplate data frame implementation size=read.delim(args$size_distribution_tab, header=T, row.names=NULL) n_samples = length(unique (size$sample)) n_genes = length (unique (levels(size$gene))) if (args$yrange != 0) { # This is used for specifying the y-axis limits ylim=c(-args$yrange, args$yrange) } else { ylim="" } par.settings.size=list(layout.heights=list(top.padding=1, bottom.padding=1), strip.background = list(col = c("lightblue", "lightgreen")) ) smR.prepanel=function(x,y,...){; yscale=c(-max(abs(y)), max(abs(y)));list(ylim=yscale);} # use if one want y axis in the middle of the plot plot_size_distribution = function(df, ...) { bc= barchart(count~as.factor(size)|factor(sample, levels=unique(sample))+gene, data = df, origin = 0, horizontal=FALSE, group=polarity, stack=TRUE, col=c('red', 'blue'), cex=0.75, scales=list(y=list(tick.number=4, rot=90, relation="free", cex=0.5, alternating=T), x=list(cex=.6 ) ), xlab = "readsize in nucleotides", ylab = args$ylabel, main = args$title, par.strip.text = list(cex=0.75), as.table=TRUE, newpage = T, ...) combineLimits(update(useOuterStrips(bc, strip.left = strip.custom(par.strip.text = list(cex=0.5)) ), layout=c(n_samples,args$rows_per_page)), margin.x=F, margin.y=1) } # per_gene_size=lapply(genes, function(x) subset(size, gene==x)) # no object in this script if (args$global == "no") { width = 8.2677*n_samples/4 } else { width = 8.2677 } options(warn=-1) pdf(file=args$size_distribution_pdf, paper="special", height=11.69, width=width) if (ylim == "" && args$global=="no") { plot_size_distribution(size, par.settings=par.settings.size) } if (ylim != "" && args$global=="no") { plot_size_distribution(size, par.settings=par.settings.size, ylim=ylim) } if (ylim == "" && args$global=="yes") { bc= barchart(count~as.factor(size)|factor(sample, levels=unique(sample)), data = size, origin = 0, horizontal=FALSE, group=polarity, stack=TRUE, col=c('red', 'blue'), scales=list(y=list(tick.number=4, rot=90, relation="same"), cex=1), xlab = "readsize in nucleotides", ylab = args$ylabel, main = args$title, as.table=TRUE, newpage = T, aspect=0.5, strip = strip.custom(par.strip.text = list(cex = 1), which.given=1, bg="lightblue") ) bc } if (ylim != "" && args$global=="yes") { bc= barchart(count~as.factor(size)|factor(sample, levels=unique(sample)), data = size, origin = 0, horizontal=FALSE, group=polarity, stack=TRUE, col=c('red', 'blue'), scales=list(y=list(tick.number=4, rot=90, relation="same"), cex=1), xlab = "readsize in nucleotides", ylab = args$ylabel, ylim = ylim, main = args$title, as.table=TRUE, newpage = T, aspect=0.5, strip = strip.custom(par.strip.text = list(cex = 1), which.given=1, bg="lightblue") ) bc } devname=dev.off()