annotate flowtext_scatterplot/getDensityPlots_text.R @ 0:cc2266d3e611 draft

Uploaded
author immport-devteam
date Mon, 27 Feb 2017 12:58:47 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
1 # Density Plot Module for Galaxy
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
2 # ggplot2
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
3 ######################################################################
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
4 # Copyright (c) 2016 Northrop Grumman.
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
5 # All rights reserved.
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
6 ######################################################################
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
7 #
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
8 # Version 1
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
9 # Cristel Thomas
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
10 #
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
11 #
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
12
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
13 library(ggplot2)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
14 library(grid)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
15 # Multiple plot function
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
16 # from http://www.cookbook-r.com/Graphs/Multiple_graphs_on_one_page_%28ggplot2%29/
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
17 # ggplot objects can be passed in ..., or to plotlist (as a list of ggplot objects)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
18 # - cols: Number of columns in layout
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
19 # - layout: A matrix specifying the layout. If present, 'cols' is ignored.
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
20 #
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
21 # If the layout is something like matrix(c(1,2,3,3), nrow=2, byrow=TRUE),
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
22 # then plot 1 will go in the upper left, 2 will go in the upper right, and
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
23 # 3 will go all the way across the bottom.
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
24 #
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
25 multiplot <- function(..., plotlist=NULL, file, cols=1, layout=NULL) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
26 # Make a list from the ... arguments and plotlist
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
27 plots <- c(list(...), plotlist)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
28 numPlots = length(plots)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
29
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
30 # If layout is NULL, then use 'cols' to determine layout
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
31 if (is.null(layout)) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
32 # Make the panel
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
33 # ncol: Number of columns of plots
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
34 # nrow: Number of rows needed, calculated from # of cols
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
35 layout <- matrix(seq(1, cols * ceiling(numPlots/cols)),
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
36 ncol = cols, nrow = ceiling(numPlots/cols))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
37 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
38
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
39 if (numPlots==1) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
40 print(plots[[1]])
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
41 } else {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
42 # Set up the page
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
43 grid.newpage()
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
44 pushViewport(viewport(layout = grid.layout(nrow(layout), ncol(layout))))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
45
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
46 # Make each plot, in the correct location
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
47 for (i in 1:numPlots) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
48 # Get the i,j matrix positions of the regions that contain this subplot
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
49 matchidx <- as.data.frame(which(layout == i, arr.ind = TRUE))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
50 print(plots[[i]], vp = viewport(layout.pos.row = matchidx$row,
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
51 layout.pos.col = matchidx$col))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
52 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
53 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
54 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
55
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
56 generateGraphFromText <- function(input, channels, output, plot_default, flag_pdf, pdf_out) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
57 fcs <- read.table(input, header = TRUE, sep = "\t", check.names = FALSE)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
58 ## marker names
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
59 markers <- colnames(fcs)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
60
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
61 if (plot_default) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
62 channels <- c(grep(colnames(fcs), pattern="Forward scatter", ignore.case=TRUE),
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
63 grep(colnames(fcs), pattern="Side scatter", ignore.case=TRUE))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
64 if (length(channels) == 0){
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
65 channels <- c(grep(colnames(fcs), pattern="FSC"),
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
66 grep(colnames(fcs), pattern="SSC"))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
67 if (length(channels) > 2) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
68 #get first FSC and corresponding SSC
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
69 channels <- c(grep(colnames(fcs), pattern="FSC-A"),
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
70 grep(colnames(fcs), pattern="SSC-A"))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
71 if (length(channels) == 0) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
72 channels <- c(grep(colnames(fcs), pattern="FSC-H"),
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
73 grep(colnames(fcs), pattern="SSC-H"))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
74 if (length(channels) == 0) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
75 channels <- c(grep(colnames(fcs), pattern="FSC-W"),
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
76 grep(colnames(fcs), pattern="SSC-W"))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
77 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
78 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
79 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
80 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
81 if (length(channels) == 0) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
82 warning('No forward/side scatter channels found, no plots will be generated.')
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
83 quit(save = "no", status = 10, runLast = FALSE)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
84 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
85 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
86
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
87 nb_markers <- length(channels)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
88
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
89 for (j in nb_markers) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
90 if (channels[j] > length(markers)){
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
91 warning('Please indicate markers between 1 and ', length(markers))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
92 quit(save = "no", status = 10, runLast = FALSE)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
93 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
94 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
95
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
96 plots <- list()
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
97 i <- 0
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
98 for (m in 1:(nb_markers - 1)) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
99 for (n in (m+1):nb_markers) {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
100 x <- fcs[,channels[m]]
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
101 y <- fcs[,channels[n]]
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
102 df <- data.frame(x = x, y = y,
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
103 d = densCols(x, y, colramp = colorRampPalette(rev(rainbow(10, end = 4/6)))))
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
104 p <- ggplot(df) +
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
105 geom_point(aes(x, y, col = d), size = 0.2) +
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
106 scale_color_identity() +
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
107 theme_bw() +
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
108 labs(x = markers[channels[m]]) +
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
109 labs(y = markers[channels[n]])
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
110 i <- i + 1
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
111 plots[[i]] <- p
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
112 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
113 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
114 png(output, type="cairo", width=800, height=800)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
115 multiplot(plotlist = plots, cols = 2)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
116 dev.off()
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
117 if (flag_pdf){
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
118 pdf(pdf_out, useDingbats=FALSE, onefile=TRUE)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
119 multiplot(plotlist = plots, cols = 2)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
120 dev.off()
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
121 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
122 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
123
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
124 args <- commandArgs(trailingOnly = TRUE)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
125 channels <- ""
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
126 flag_default <- FALSE
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
127 flag_pdf <- FALSE
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
128 pdf_output <- ""
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
129
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
130 if (args[3]=="None") {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
131 flag_default <- TRUE
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
132 } else {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
133 if (args[3] == "i.e.:1,3,4"){
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
134 flag_default <- TRUE
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
135 } else {
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
136 channels <- as.numeric(strsplit(args[3], ",")[[1]])
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
137 for (channel in channels){
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
138 if (is.na(channel)){
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
139 quit(save = "no", status = 11, runLast = FALSE)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
140 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
141 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
142 if (length(channels) == 1){
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
143 warning('Please indicate more than one marker to plot.')
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
144 quit(save = "no", status = 10, runLast = FALSE)
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
145 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
146 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
147 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
148
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
149 if (args[5] == "TRUE"){
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
150 pdf_output <- args[6]
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
151 flag_pdf <- TRUE
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
152 }
cc2266d3e611 Uploaded
immport-devteam
parents:
diff changeset
153 generateGraphFromText(args[2], channels, args[4], flag_default, flag_pdf, pdf_output)