-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathCopraRNA2.pl
executable file
·545 lines (462 loc) · 28.8 KB
/
CopraRNA2.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
#!/usr/bin/env perl
use strict;
use warnings;
use Getopt::Long;
use Cwd 'abs_path'; ## edit 2.0.5.1
my $COPRARNA_VERSION="2.1.3";
# License: MIT
# When using CopraRNA please cite:
# Patrick R. Wright, et al.
# Comparative genomics boosts target prediction for bacterial small RNAs
# Proc Natl Acad Sci USA, 2013, 110 (37), E3487–E3496.
# and/or
# Patrick R. Wright, et al.
# CopraRNA and IntaRNA: predicting small RNA targets, networks and interaction domains
# Nucleic Acids Research, 2014, 42 (W1), W119-W123.
# If you run into problems or have questions, please do not hesitate to
# contact us.
# Comparative prediction algorithm for sRNA targets (CopraRNA)
#
# Contributions by:
#
# Patrick R. Wright
# Jens Georg
# Martin Raden, nee Mann
# Rolf Backofen
# Steffen C. Lott
# Andreas S. Richter
# Florian Eggenhofer
# Robert Kleinkauf
# Dragos A. Sorescu
# Wolfgang R. Hess
# Stephan Klaehn
# Joerg Vogel
# Kai Papenfort
#####################################################
#### dependencies: (specified versions are tested and functional)
# bzip2 1.0.6 (for the core genome archive) // conda install bzip2
# gawk 4.1.3 // conda install gawk
# sed 4.2.2.165-6e76-dirty // conda install sed
# grep 2.14 // conda install grep
# GNU coreutils 8.25 // conda install coreutils
### Bio Software
# IntaRNA 2.1.0 // conda install intarna
# EMBOSS package 6.5.7 - distmat (creates distance matix from msa) // conda install emboss
# embassy-phylip 3.69.650 - fneighbor (creates tree from dist matrix) // conda install embassy-phylip
# ncbiblast-2.2.22 // conda install blast-legacy
# DomClust 1.2.8a // conda install domclust
# MAFFT 7.310 // conda install mafft
# clustalo 1.2.3 // conda install clustalo
# phantomjs 2.1.1-0 // conda install phantomjs
### Perl (5.22.0) Module(s): // conda install perl
# List::MoreUtils 0.413 // conda install perl-list-moreutils
# Parallel::ForkManager 1.17 // conda install perl-parallel-forkmanager
# Getopt::Long 2.45 // conda install perl-getopt-long
# Bio::SeqIO (bioperl 1.6.924) // conda install perl-bioperl
# Bio::DB::EUtilities 1.75 // conda install perl-bio-eutilities
# Cwd 3.56 // included in the conda perl installation
### R Package(s):
# R statistics 3.2.2 // conda install r-base==3.2.2
# seqinr 3.1_3 // conda install r-seqinr
# robustrankaggreg 1.1 // conda install r-robustrankaggreg
# pheatmap 1.0.8 // conda install r-pheatmap
### python 2.7.13 // conda install python
## packages:
# sys // available from conda python
# logging // available from conda python
# traceback // available from conda python
# suds.metrics (suds-jurko 0.6) // conda install suds-jurko
# suds (suds-jurko 0.6) // conda install suds-jurko
# suds.client (suds-jurko 0.6) // conda install suds-jurko
# datetime // available from conda python
#####################################################
#### changelog
# v2.1.3 : input sRNA file is kept, updated organisms-list
#
# v2.1.2 : added R downstream ooi false positive removal
#
# v2.1.1 : added input exceptions
# DAVID python code now py2 and py3 compatible
# changed coloring in evolutionary heatmap
# fixed issue for regions plots for sequences with non ATGC alphabet
#
# v2.1.0 : topcount default 200
# stopped tracking edits manually
#
# v2.0.6 : new p-value combination (no hard cutoff anymore // switching to integrated superior method)
# standard root function for weights is now 1 instead of 2.5 (no more weight reduction)
# added phylogeny output directory in clean output
# -cop2 option is now -cop1 since CopraRNA2 will be standard
# removed -pvcut option
# added -nooi option
# added gawk, sed, grep, tr, sort as dependencies
# added extended regions plots
# aux enrichment now also done for count specified by $enrich
# adding consensus prediction
# removed phantomjs bin // now installing it via conda
#
# v2.0.5.1 : major restructuring due to changed IntaRNA version (2.0.4)
# added IntaRNA --tAccW and --tAccL as parameters to CopraRNA
# adjusted update_kegg2refseq for new format of prokaryotes.txt
# added verbose terminal printing option
# added topcount option
# added pvalue cutoff option for CopraRNA 2
# now using Cwd 'abs_path' to make script path locations dynamic
# added warning for run directories that contain many files
# added websrv option to only output websrv files if explicitly called for
# added root option // applies this root function to weights both for CopraRNA1 and CopraRNA2 pvalue combination
# now calculating normalized IntaRNA energy scores internally in IntaRNA // adjusted CopraRNA accordingly
# added enrichment parameter
# added noclean parameter
#
# v2.0.5 : changed to using IntaRNA2.0 ui
# local mirror for .gbk changed to .gb because file ending in local mirror changed
# removed evir dependency by now sourcing the gev and pgev functions locally
# added MIT license
# v2.0.4.2 : now using Hartung.R to combine pvalues // no previous calculation of rho needed
# v2.0.4.1 : added new adjust_tags_clustered.R that now makes two files one for pold one for padj // also added rho calculation rho_script.R
# changed scale_clusters.pl to combine_clusters.pl // reimplementation
# weights are no longer subjected to the 2.5th root (only for CopraRNA2)
# v2.0.4 : major changes to the code preparing for CopraRNA2 benchmarking and publication (UPGMA tree for example)
# v2.0.3.2 : fixed issue with RefSeq IDs longer than 11 that chars caused job fail // changed DAVID parameters to "medium" from the webpage
# mirroring DAVID v6.7 specifically instead of DAVID v6.8
# v2.0.3.1 : changed DAVID-WS from perl to python client
# v2.0.3 : using local mirrors of old NCBI ID system for compatibility if available
# v2.0.2 : support of new NCBI ID system
# v2.0.1 : Iterative organism subset analysis enabled. Auxiliary enrichment output added. Minimal relative cluster size parameter added. IntaRNA parameters changed to -w 150 -L 100
# v1.3.0 : Potential outlier detection; evolutionary tree visualization; minor bugfix in weight calculation.
# v1.2.9 : Now using (Benjamini&Hochberg, 1995) for false discovery rate (fdr) estimation. Fixed issue where trees with branch lengths of zero would cause job failures.
# v1.2.8 : Fixed the issue where jobs with input organisms with exactly the same 16S sequences would fail
# v1.2.7 : Reimplementation of p-value joining (runtime reduction); Minor bugfix for heatmap drawing and regions plots
# v1.2.6 : Added heatmap pdf output
# v1.2.5 : Added functional enrichment heatmaps
# v1.2.4 : Changed DomClust parameters to standard MBGD parameters
# v1.2.3 : BLAST speedup
# v1.2.2 : Fixed issue with organism: 'sfd'
# v1.2.1 : RefSeq files now being downloaded from NCBI FTP
my $help = ""; ## edit 2.0.4
my $sRNAs_fasta = "input_sRNA.fa";
my $upstream = 200;
my $downstream = 100;
my $region = "5utr";
my $RelClusterSize = 0.5;
my $core_count = 1; # how many parallel processes are allowed
my $winsize = 150; # IntaRNA window size
my $maxbpdist = 100; # IntaRNA maximum base pair distance
my $cop1 = 0;
my $cons = 0; ## edit 2.0.6
my $nooi = 0; # if this is set to 1 then the standard prediction mode is CopraRNA 2 balanced else ooi ## edit 2.0.6
my $verbose = 0; ## edit 2.0.5.1
my $noclean = 0; ## edit 2.0.5.1
my $websrv = 0; ## edit 2.0.5.1
my $ooi_filt = 0; ## for copraRNA2_ooi_post_filtering.R
my $pvalcutoff = 0.15; # p-value cutoff for CopraRNA 2 // ## edit 2.0.5.1
my $topcount = 200; # amount of top predictions // ## edit 2.0.5.1
my $root = 1; # root function to apply to the weights // ## edit 2.0.5.1
my $enrich = 0; ## edit 2.0.5.1 // functional enrichment needs to be specifically turned on
## // this option also allows to specify how many top predictions to use for the enrichment
# get absolute path
my $ABS_PATH = abs_path($0); ## edit 2.0.5.1
# remove script name at the end
# match all non slash characters at the end of the string
$ABS_PATH =~ s|[^/]+$||g; ## edit 2.0.5.1
my $PATH_COPRA = $ABS_PATH; ## edit 2.0.4 // changed $versiondirectory to $PATH_COPRA in all scripts
GetOptions ( ## edit 2.0.4
'help|?' => \$help,
'srnaseq:s' => \$sRNAs_fasta,
'ntup:i' => \$upstream,
'ntdown:i' => \$downstream,
'cores:i' => \$core_count,
'region:s' => \$region, # one of "5utr", "3utr", "cds"
'rcsize:f' => \$RelClusterSize,
'winsize:i' => \$winsize, ## edit 2.0.5.1
'maxbpdist:i' => \$maxbpdist, ## edit 2.0.5.1
'cop1' => \$cop1, # switch for coprarna1, if set then coprarna1 is run // else only coprarna2
'verbose' => \$verbose, # switch for verbose output during computation
'websrv' => \$websrv, # switch for providing webserver output
'noclean' => \$noclean, # switch to prevent cleaning of files
'nooi' => \$nooi, # switch to set prediction mode to balanced mode
'topcount:i' => \$topcount, # amount of top predictions to return ## edit 2.0.5.1
'enrich:i' => \$enrich, # functional enrichment needs to be specifically turned on // also how many top preds to use for enrichment
'root:i' => \$root, # root function to apply to the weights ## edit 2.0.5.1
'cons:i' => \$cons, # consensus mode / 0=off, 1=ooi_cons, 2=overall_cons ## edit 2.0.6
'ooifilt:f' => \$ooi_filt, # for copraRNA2_ooi_post_filtering.R
);
if ($help) { ## edit 2.0.4 // added help and getopt
print "\nCopraRNA $COPRARNA_VERSION\n\n",
"CopraRNA is a tool for sRNA target prediction. It computes whole genome target predictions\n",
"by combination of distinct whole genome IntaRNA predictions. As input CopraRNA requires\n",
"at least 3 homologous sRNA sequences from 3 distinct organisms in FASTA format.\n",
"Furthermore, each organisms' genome has to be part of the NCBI Reference Sequence (RefSeq)\n",
"database (i.e. it should have exactly this NZ_* or this NC_XXXXXX format where * stands\n",
"for any character and X stands for a digit between 0 and 9). Depending on sequence length\n",
"(target and sRNA), amount of input organisms and genome sizes, CopraRNA can take up to 24h\n",
"or longer to compute. In most cases it is significantly faster. It is suggested to run CopraRNA\n",
"on a machine with at least 8 GB of memory.\n\n",
"CopraRNA produces a lot of file I/O. It is suggested to run CopraRNA in a dedicated\n",
"empty directory to avoid unexpected behavior.\n\n",
"The central result table is CopraRNA_result.csv. Further explanations concerning the files\n",
"in the run directory can be found in README.txt.\n\n",
"The following options are available:\n\n",
" --help this help\n\n",
" --srnaseq FASTA file with small RNA sequences (def:input_sRNA.fa)\n",
" --region region to scan in whole genome target prediction (def:5utr)\n",
" '5utr' for start codon\n",
" '3utr' for stop codon\n",
" 'cds' for entire transcript\n",
" --ntup amount of nucleotides upstream of '--region' to parse for targeting (def:200)\n",
" --ntdown amount of nucleotides downstream of '--region' to parse for targeting (def:100)\n",
" --cores amount of cores to use for parallel computation (def:1)\n",
" --rcsize minimum amount (%) of putative target homologs that need to be available \n",
" for a target cluster to be considered in the CopraRNA1 part (see --cop1) of the prediction (def:0.5)\n", ## edit 2.0.5.1
" --winsize IntaRNA target (--tAccW) window size parameter (def:150)\n", ## edit 2.0.5.1
" --maxbpdist IntaRNA target (--tAccL) maximum base pair distance parameter (def:100)\n",
" --cop1 switch for CopraRNA1 prediction (def:off)\n", ## edit 2.0.6
" --cons controls consensus prediction (def:0)\n", ## edit 2.0.6
" '0' for off\n", ## edit 2.0.6
" '1' for organism of interest based consensus\n", ## edit 2.0.6
" '2' for overall consensus based prediction\n", ## edit 2.0.6
" --verbose switch to print verbose output to terminal during computation (def:off)\n", ## edit 2.0.5.1
" --websrv switch to provide webserver output files (def:off)\n", ## edit 2.0.5.1
" --noclean switch to prevent removal of temporary files (def:off)\n", ## edit 2.0.5.1
" --enrich if entered then DAVID-WS functional enrichment is calculated with given amount of top predictions (def:off)\n", ## edit 2.0.5.1
" --nooi if set then the CopraRNA2 prediction mode is set not to focus on the organism of interest (def:off)\n", ## edit 2.0.6
" --ooifilt post processing filter for organism of interest p-value 0=off (def:0)\n",
" --root specifies root function to apply to the weights (def:1)\n",
" --topcount specifies the amount of top predictions to return and use for the extended regions plots (def:200)\n\n", ## edit 2.0.6
"Example call: CopraRNA2.pl -srnaseq sRNAs.fa -ntup 200 -ntdown 100 -region 5utr -enrich 200 -topcount 200 -cores 4\n\n",
"License: MIT\n\n",
"References: \n",
"1. Wright PR et al., Comparative genomics boosts target prediction for bacterial small RNAs\n Proc Natl Acad Sci USA, 2013, 110 (37), E3487–E3496\n",
"2. Wright PR et al., CopraRNA and IntaRNA: predicting small RNA targets, networks and interaction domains\n Nucleic Acids Research, 2014, 42 (W1), W119-W123\n",
"\n";
exit(0);
}
# input check
unless (-e $sRNAs_fasta) { ## edit 2.0.2
die("\nError: No input FASTA supplied!\nUse '-h' option for help.\n\n");
}
# rudimentary check for fasta
my $check_fa = `grep '>' $sRNAs_fasta`;
chomp $check_fa;
die("\nError: The input file ($sRNAs_fasta) supplied does not appear to be a FASTA file!\n\n") unless($check_fa);
# check for sequence count in input being more than 2
my $count_fa = `grep -c '>' $sRNAs_fasta`;
chomp $count_fa;
die("\nError: The input file ($sRNAs_fasta) seems to contain less than 3 sequences!\n\n") unless($count_fa>2);
# check for ooifilt <=1 and >= 0
die("\nError: ooifilt needs to be specified between 0 and 1. You set $ooi_filt\n\n") unless ($ooi_filt>=0 and $ooi_filt<=1);
# create warning for non empty run dir
my @dir_files = <*>; ## edit 2.0.5.1
my $file_count = scalar(@dir_files); ## edit 2.0.5.1
print "\nWarning: your run directory contains many files ($file_count). In general it is suggested to run CopraRNA in an empty directory to avoid unexpected behaviour.\n\n" if ($file_count > 10); ## edit 2.0.5.1
# check core count // if wrong set it to 1 // ## edit 2.0.4
if ($core_count <= 1) {
$core_count = 1;
}
# check region parameter ## edit 2.0.4
die ("\nError: -region parameter must be one of 5utr, 3utr or cds. You set '$region'.\n\n") unless ($region eq "5utr" or $region eq "3utr" or $region eq "cds");
# check cons paramter ## edit 2.0.6
die ("\nError: -cons parameter must be one of 0, 1 or 2. You set '$cons'.\n\n") unless ($cons eq 2 or $cons eq 1 or $cons eq 0);
# disallow nooi=1 and cons=1 combination
die ("\nError: -cons 1 can not be combined with -nooi 1. Set -cons to 0 or 2.\n\n") if ( ($cons eq 1) and $nooi );
# disallow consensus predictions with coprarna 1
die ("\nError: -cons must be 0 for -cop1 prediction. You set '$cons'.\n\n") if ( ( ($cons eq 1) and $cop1 ) or ( ($cons eq 2) and $cop1 ) );
# check for gaps
system "grep '-' $sRNAs_fasta > find_gaps.txt"; ## edit 2.0.2
if (-s "find_gaps.txt") { die("\nError: Gaps are present in sRNA sequences. Please delete them from the file and restart.\n\n"); } ## edit 2.0.2
# check for correct RefSeq formatted headers and their presence in the availibility table ## edit 2.0.4
my $headerIDs = `grep ">" $sRNAs_fasta | sed 's/>//g' | tr '\n' ';'`;
chop $headerIDs;
my @splitHeaderIDs = split(/;/,$headerIDs);
foreach(@splitHeaderIDs) {
die("\nError: $_ does not match correct RefSeq ID format (NZ_* or NC_XXXXXX where * stands for any character and X stands for a digit between 0 and 9).\n\n") unless ($_ =~ m/NC_\d{6}|NZ_.*/);
$_ =~ s/^\s+|\s+$//g;
my $availabilityCheck = `grep '$_' $PATH_COPRA/coprarna_aux/kegg2refseqnew.csv`;
die("\nError: '$_' is not present in the availability list and is thus not compatible with CopraRNA.\n\n") unless (length $availabilityCheck);
}
# check that maxbpdist ist smaller or equal to windowsize
die("\nError: The maximal basepair distance ($maxbpdist) is larger than the given window size ($winsize) but must be <= to the windows size. Please change the parameters accordingly.\n\n") if ($maxbpdist > $winsize); ## edit 2.0.5.1
# check for ntup + ntdown being >= $winsize because of IntaRNA parameters ## edit 2.0.5.1
my $sumUpDown = $upstream+$downstream;
if ($region eq "5utr" or $region eq "3utr") { ## edit 2.0.4.2
die("\nError: (-ntup + -ntdown) is $sumUpDown but must be >= $winsize (--winsize). Please change the parameters accordingly.\n\n") if ( $sumUpDown < $winsize ); ## edit 2.0.5.1
}
# check for correct range of 0.5 <= -rcsize <= 1.0 ## edit 2.0.5.1
die("\nError: -rcsize can only be specified between 0 and 1.0. You set '$RelClusterSize'.\n\n") unless ($RelClusterSize >= 0 and $RelClusterSize <= 1.0);
# check for duplicate IDs in FASTA header // not allowed ## edit 2.0.4
my $duplicate_fasta_header = `grep ">" $sRNAs_fasta | sort | uniq -d`;
chomp $duplicate_fasta_header;
die("\nError: Duplicate organisms ($duplicate_fasta_header) are present in $sRNAs_fasta.\n\n") if($duplicate_fasta_header);
# write input options to file ## edit 2.0.4
open WRITETOOPTIONS, ">", "CopraRNA_option_file.txt";
print WRITETOOPTIONS "sRNA FASTA:" . $sRNAs_fasta . "\n";
print WRITETOOPTIONS "nt upstream:" . $upstream . "\n";
print WRITETOOPTIONS "nt downstream:" . $downstream . "\n";
print WRITETOOPTIONS "region:" . $region . "\n";
print WRITETOOPTIONS "relative clustersize:" . $RelClusterSize . "\n";
print WRITETOOPTIONS "core count:" . $core_count . "\n";
print WRITETOOPTIONS "win size:" . $winsize . "\n";
print WRITETOOPTIONS "max bp dist:" . $maxbpdist . "\n";
print WRITETOOPTIONS "CopraRNA1:" . $cop1 . "\n";
print WRITETOOPTIONS "verbose:" . $verbose . "\n";
print WRITETOOPTIONS "websrv:" . $websrv . "\n";
print WRITETOOPTIONS "nooi:" . $nooi . "\n";
print WRITETOOPTIONS "top count:" . $topcount . "\n";
print WRITETOOPTIONS "root:" . $root . "\n";
print WRITETOOPTIONS "enrich:" . $enrich . "\n";
print WRITETOOPTIONS "noclean:" . $noclean . "\n";
print WRITETOOPTIONS "cons:" . $cons . "\n"; ## edit 2.0.6
print WRITETOOPTIONS "ooifilt:" . $ooi_filt . "\n"; ##
print WRITETOOPTIONS "version:CopraRNA $COPRARNA_VERSION\n"; ## edit 2.0.4.2
close WRITETOOPTIONS;
# end write options
# CopraRNA error log
system "touch err.log";
system "cp $sRNAs_fasta input_sRNA.fa" unless ($sRNAs_fasta eq "input_sRNA.fa");
$sRNAs_fasta = "input_sRNA.fa";
# format sRNA fasta - put sequence in 1 line
system $PATH_COPRA . "coprarna_aux/format_fasta.pl $sRNAs_fasta" . " > $sRNAs_fasta.temp";
system "mv $sRNAs_fasta.temp $sRNAs_fasta";
# build RefSeq input based on the sRNA input fasta (can only contain refseq IDs in header)
my $RefSeqIds = `grep '>' $sRNAs_fasta | sed 's/>//g' | tr '\n' ' '`;
# print org of interest
if ($verbose) {
my $ooi_rid = `grep ">" input_sRNA.fa | head -n1 | sed 's/>//g'`;
chomp $ooi_rid;
my $full_ooi = `grep '$ooi_rid' "$PATH_COPRA/coprarna_aux/CopraRNA_available_organisms.txt"`;
chomp $full_ooi;
print "\nOrganism of interest: $full_ooi\n\n";
}
# run homology_intaRNA.pl
print $PATH_COPRA . "coprarna_aux/homology_intaRNA.pl $sRNAs_fasta $upstream $downstream $region $RefSeqIds\n" if ($verbose);
system $PATH_COPRA . "coprarna_aux/homology_intaRNA.pl $sRNAs_fasta $upstream $downstream $region $RefSeqIds";
# get organism of interest
my $ncrnaRIDs = `grep ">" ncrna.fa | sed 's/>ncRNA_//g' | tr '\n' ' '`;
my @splitRID = split(/\s/, $ncrnaRIDs);
my $organismOfInterest = $splitRID[0];
chomp $organismOfInterest;
# final optimal IntaRNA result for organism of interest
my $MainFinalCSV = $organismOfInterest . "_upfromstartpos_" . $upstream . "_down_" . $downstream . "_opt.intarna.csv"; ## edit 2.0.5.1
if ($enrich) { ## edit 2.0.5.1
# add IntaRNA single organisms chart reports for aux enrichment // sort by p-value
print "Performing auxiliary enrichment\n" if ($verbose);
system "env LC_ALL=C sort -t';' -g -k36 $MainFinalCSV -o intarna_websrv_table.csv";
system $PATH_COPRA . "coprarna_aux/add_GI_genename_annotation_intarna.pl";
system $PATH_COPRA . "coprarna_aux/DAVIDWebService_IntaRNA_chartReport.py intarna_websrv_table_ncbi.csv $enrich > IntaRNA_chartReport.txt"; ## edit 2.0.6 // aux einrich for same amout as regular enrichment
system "grep -P 'geneIds\\s=|termName\\s=' IntaRNA_chartReport.txt | sed 's/^[ ]*//g' | sed 's/ = /=/g' | sed 's/, /,/g' | sed 's/\"//g' > IntaRNA_chartReport_grepped.txt"; ## edit 2.0.6 // no longer removing all spaces
system $PATH_COPRA . "coprarna_aux/find_single_specific_targets_in_termCluster.pl > org_of_interest_aux_enrichment.txt";
## edit 2.0.6 new aux table
system "echo 'locus_tag,start_tar,stop_tar,start_query,stop_query,energy,p-value,gene_name,gene_id,annotation,functional_terms' > aux_table.csv";
system "awk -F';' '{ print \$1\",\"\$9\",\"\$10\",\"\$11\",\"\$12\",\"\$15\",\"\$36\",\"\$37\",\"\$38\",\"\$39 }' intarna_websrv_table_ncbi.csv > intarna_websrv_table_ncbi_awk.csv";
my $aux_gids = `grep -oP ';\\d+\\(' org_of_interest_aux_enrichment.txt | sed 's/[;(]//g' | sort -u | tr '\n' ';'`;
chop $aux_gids; # remove trailing ';'
my @split_aux_gids = split(/;/, $aux_gids);
foreach(@split_aux_gids) {
system "grep -P ',$_,' intarna_websrv_table_ncbi_awk.csv | tr '\n' ',' >> aux_table.csv";
system "grep -P '$_' org_of_interest_aux_enrichment.txt | awk -F';' '{ print \$1 }' | tr '\n' ';' | sed 's/,/ /' | sed 's/.\$//' >> aux_table.csv";
system "echo >> aux_table.csv";
}
}
# output warnings
system "awk -F ';' '{if (\$2 > 0.5) { print toupper(\$1) \" may be overweighted. It has weight\"; printf(\"\%.2f\", \$2); print \". You should consider checking the 16S rDNA tree. We suggest removal of outliers from your input and restarting.\";} }' zscore.weight | tr '\n' ' ' > weights.warning"; ## edit 2.0.2
# check err.log // should be empty // err.log contains information on
# 1. not correctly downloaded RefSeq files
# 2. gene no CDS issue
# 3. wrong 16S counts
# 4. empty CopraRNA_result.csv
# 5. the exception in add_pval_to_csv_evdfit.R
# -s File has nonzero size (returns size in bytes).
if (-s "err.log") { die("\nError: CopraRNA failed. Check err.log for details.\n\n"); } ## edit 2.0.4 // added another check here at the bottom maybe we need some more check hooks in the new scripts
# create regions plots
print "Preparing interaction plots\n" if ($verbose);
system "R --slave -f " . $PATH_COPRA . "coprarna_aux/script_R_plots_8.R --args CopraRNA_result_all.csv $topcount 2> /dev/null > /dev/null"; ## edit 2.0.5.1 // changed input file and piping command line output to /dev/null for silencing // ## edit 2.0.6 new input file
# convert postscript files to PNG
# thumbnails png
if ($websrv) {
system "convert -size 170x170 -resize 170x170 -flatten -rotate 90 sRNA_regions_with_histogram.ps thumbnail_sRNA.png";
system "convert -size 170x170 -resize 170x170 -flatten -rotate 90 mRNA_regions_with_histogram.ps thumbnail_mRNA.png";
}
# blow up images png
system "convert -density '300' -resize '700' -flatten -rotate 90 sRNA_regions_with_histogram.ps sRNA_regions_with_histogram.png";
system "convert -density '300' -resize '700' -flatten -rotate 90 mRNA_regions_with_histogram.ps mRNA_regions_with_histogram.png";
# clean up
unless ($noclean) {
print "Cleaning run directory\n" if ($verbose);
system "rm enrichment.txt *DAVID* IntaRNA* intarna*" if ($enrich);
system "rm *IntaRNA1_ui* *top_targets*" if ($websrv);
system "rm *.gb";
system "rm *pvsample*" if ($cop1);
system "rm compatible.distmat.mapped";
system "rm err.log *anno* padj.csv";
system "rm *pvalues* ncRNA_*";
system "rm *.fa.intarna.sorted.csv *opt.intarna.csv";
system "rm gene_CDS_exception.txt find_gaps.txt distmat.out";
system "rm merged_refseq_ids.txt";
system "rm CopraRNA2_prep*";
system "rm fasta_temp_file fasta_temp_file_out";
#system "rm conservation_table.Rdata" unless ($cop1);
# fix warning "rm: missing operand Try 'rm --help' for more information." ## edit 2.0.1
my $temp_fasta_check = `find -regex ".*fa[0-9]+\$"`;
if ($temp_fasta_check) {
system 'find -regex ".*fa[0-9]+$" | xargs rm';
}
# blast files
system "rm all.fas" if (-e "all.fas");
system "rm all.fas.blast" if (-e "all.fas.blast");
system "rm all.fas.hom" if (-e "all.fas.hom");
system "rm all.fas.pin" if (-e "all.fas.pin");
system "rm all.fas.phr" if (-e "all.fas.phr");
system "rm all.fas.tit" if (-e "all.fas.tit");
system "rm all.fas.psq" if (-e "all.fas.psq");
system "rm all.fas.gene" if (-e "all.fas.gene");
system "rm error.log" if (-e "error.log");
system "rm formatdb.log" if (-e "formatdb.log");
system "rm N_chars_in_CDS.txt" if (-e "N_chars_in_CDS.txt");
# make subdirs for IntaRNA, FASTA, Enrichment, Phylogeny and regions plots ## edit 2.0.5.1 // 2.0.6
system "mkdir IntaRNA";
system "mv *.fa.intarna.csv IntaRNA";
system "mkdir Phylogeny";
system "mv compatible.* Phylogeny";
system "mv 16s_sequences.* Phylogeny";
system "mkdir FASTA";
system "rm aligned_sRNA.fa" unless ($cop1);
system "rm ncrna_aligned.fa";
system "mv *.fa FASTA";
system "mkdir Regions_plots";
system "mv *regions* Regions_plots";
system "mv thumbnail_* Regions_plots" if ($websrv);
if ($enrich) {
system "mkdir Enrichment";
system "mv copra_heatmap.html Enrichment";
system "mv copraRNA.json Enrichment";
system "mv enriched_heatmap_big* Enrichment";
system "mv termClusterReport.txt Enrichment";
system "rm org_of_interest_aux_enrichment.txt";
system "mv aux_table.csv Enrichment";
}
# all predictions types archive
unless ($cop1) {
system "mkdir all_predictions";
system "mv *csv all_predictions";
system "mv all_predictions/CopraRNA_result_all.csv .";
system "mv all_predictions/CopraRNA_result.csv .";
system "mv all_predictions/coprarna_websrv_table.csv ." if ($websrv);
}
# make an archive for the Rdata files
unless ($cop1) {
system "mkdir Rdata";
system "mv consensus_positions.Rdata Rdata";
system "mv conservation_table.Rdata Rdata";
system "mv interaction_positions.Rdata Rdata";
}
# zip evo_alignments folder to reduce file number
system "if [ -d evo_alignments ]; then zip -rmq evo_alignments evo_alignments 2>&1; fi";
# remove weights.warning if its empty
system "rm weights.warning" if (-z "weights.warning");
# remove target_alignments
system "rm -r target_alignments" unless ($cop1);
# remove CopraRNA 1 non generic name
system "rm CopraRNA1_final_all.csv CopraRNA1_final.csv" if ($cop1);
}