comparison ribowaltz_plot.R @ 0:6d4c94373bba draft

planemo upload for repository https://github.com/galaxyproject/tools-iuc/tree/master/tools/ribowaltz commit ff002df702f544829d1b500ac4b517c1e70ad14d
author iuc
date Thu, 22 Sep 2022 20:30:54 +0000
parents
children 042cab870a39
comparison
equal deleted inserted replaced
-1:000000000000 0:6d4c94373bba
1 # setup R error handling to go to stderr
2 options(show.error.messages = FALSE, error = function() {
3 cat(geterrmessage(), file = stderr())
4 q("no", 1, FALSE)
5 })
6
7 # we need that to not crash galaxy with an UTF8 error on German LC settings.
8 loc <- Sys.setlocale("LC_MESSAGES", "en_US.UTF-8")
9 library("getopt")
10 options(stringAsFactors = FALSE, useFancyQuotes = FALSE)
11 args <- commandArgs(trailingOnly = TRUE)
12
13 # get options, using the spec as defined by the enclosed list.
14 # we read the options from the default: commandArgs(TRUE).
15 spec <- matrix(c(
16 "quiet", "q", 0, "logical",
17 "help", "h", 0, "logical",
18 "input_rdata", "i", 1, "character",
19 "params_rlength_distr", "r", 0, "character",
20 "params_rends_heat", "e", 0, "character",
21 "region_psite_plot", "R", 0, "logical",
22 "params_trint_periodicity", "t", 0, "character",
23 "params_metaplots", "m", 0, "character",
24 "params_codon_usage_psite", "u", 0, "character"
25 ), byrow = TRUE, ncol = 4)
26 opt <- getopt(spec)
27
28 # if help was asked for print a friendly message
29 # and exit with a non-zero error code
30 if (!is.null(opt$help)) {
31 cat(getopt(spec, usage = TRUE))
32 q(status = 1)
33 }
34
35 verbose <- is.null(opt$quiet)
36
37 library("riboWaltz")
38 library("jsonlite")
39
40 load(opt$input_rdata)
41
42 if (!is.null(opt$params_rlength_distr)) {
43 pdf("read_lengths.pdf")
44 json_rlength_distr <- fromJSON(opt$params_rlength_distr)
45 length_dist <- rlength_distr(
46 reads_psite_list,
47 sample = names(reads_psite_list),
48 cl = json_rlength_distr$cl,
49 multisamples = json_rlength_distr$multisamples,
50 plot_style = json_rlength_distr$plot_style
51 )
52 print(length_dist)
53 dev.off()
54 }
55
56 if (!is.null(opt$params_rends_heat)) {
57 pdf("read_ends_heatmap.pdf", height = 5 * length(reads_psite_list), width = 15)
58 json_rends_heat <- fromJSON(opt$params_rends_heat)
59 for (sample_name in names(reads_psite_list)) {
60 ends_heatmap <- rends_heat(
61 reads_psite_list,
62 annotation_dt,
63 sample = sample_name,
64 cl = json_rends_heat$cl,
65 utr5l = json_rends_heat$utr5l,
66 cdsl = json_rends_heat$cdsl,
67 utr3l = json_rends_heat$utr3l
68 )
69 print(ends_heatmap[["plot"]])
70 }
71 dev.off()
72 }
73
74 if (!is.null(opt$region_psite_plot)) {
75 pdf("psites_per_region.pdf", height = 12, width = 7 * length(reads_psite_list))
76 psite_region <- region_psite(reads_psite_list, annotation_dt, sample = names(reads_psite_list))
77 print(psite_region[["plot"]])
78 dev.off()
79 }
80
81 if (!is.null(opt$params_trint_periodicity)) {
82 pdf("trinucleotide_periodicity.pdf", height = 6 * length(reads_psite_list), width = 10)
83 json_trint_periodicity <- fromJSON(opt$params_trint_periodicity)
84 frames_stratified <- frame_psite_length(
85 reads_psite_list,
86 sample = names(reads_psite_list),
87 cl = json_trint_periodicity$cl,
88 region = json_trint_periodicity$region,
89 length_range = json_trint_periodicity$length_range
90 )
91 frames_stratified[["plot"]]
92 frames <- frame_psite_length(
93 reads_psite_list,
94 sample = names(reads_psite_list),
95 region = json_trint_periodicity$region,
96 length_range = json_trint_periodicity$length_range
97 )
98 print(frames[["plot"]])
99 dev.off()
100 }
101
102 if (!is.null(opt$params_metaplots)) {
103 pdf("metaplots.pdf", height = 5 * length(reads_psite_list), width = 24)
104 json_metaplots <- fromJSON(opt$params_metaplots)
105 metaprofile <- metaprofile_psite(
106 reads_psite_list,
107 annotation_dt,
108 sample = names(reads_psite_list),
109 multisamples = json_metaplots$multisamples,
110 plot_style = json_metaplots$plot_style,
111 length_range = json_metaplots$length_range,
112 frequency = json_metaplots$frequency,
113 utr5l = json_metaplots$utr5l,
114 cdsl = json_metaplots$cdsl,
115 utr3l = json_metaplots$utr3l,
116 plot_title = "sample.transcript.length_range"
117 )
118 print(metaprofile)
119 sample_list <- list()
120 for (sample_name in names(reads_psite_list)) {
121 sample_list[[sample_name]] <- c(sample_name)
122 }
123 metaheatmap <- metaheatmap_psite(
124 reads_psite_list,
125 annotation_dt,
126 sample = sample_list,
127 length_range = json_metaplots$length_range,
128 utr5l = json_metaplots$utr5l,
129 cdsl = json_metaplots$cdsl,
130 utr3l = json_metaplots$utr3l,
131 plot_title = "Comparison metaheatmap"
132 )
133 print(metaheatmap[["plot"]])
134 dev.off()
135 }
136
137 if (!is.null(opt$params_codon_usage_psite)) {
138 pdf("codon_usage.pdf", height = 6, width = 16)
139 json_codon_usage_psite <- fromJSON(opt$params_codon_usage_psite)
140 for (sample_name in names(reads_psite_list)) {
141 cu_barplot <- codon_usage_psite(
142 reads_psite_list,
143 annotation_dt,
144 sample = sample_name,
145 fastapath = json_codon_usage_psite$fastapath,
146 fasta_genome = FALSE,
147 frequency_normalization = json_codon_usage_psite$frequency
148 )
149 print(cu_barplot[["plot"]])
150 }
151 dev.off()
152 }