annotate mirplant2/preProcess.pl @ 0:6006e58458ae draft

Uploaded
author adefelicibus
date Tue, 15 Mar 2016 15:10:44 -0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
1 #!/usr/bin/perl -w
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
2 #Filename:
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
3 #Author: Tian Dongmei
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
4 #Email: tiandm@big.ac.cn
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
5 #Date: 2014-12-2
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
6 #Modified:
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
7 #Description: RNA-seq data pre-process
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
8 my $version=1.00;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
9
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
10 use strict;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
11 use Getopt::Long;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
12 use threads;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
13 #use threads::shared;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
14 use File::Path;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
15 use File::Basename;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
16 #use RNA;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
17 #use Term::ANSIColor;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
18
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
19 my %opts;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
20 GetOptions(\%opts,"i:s@","tag:s@","format=s","phred:i","gfa=s","rfam:s","idx:s","idx2:s","mis:i","v:i","a:s","M:i","t:i","min:i","max:i","o:s","path:s","h");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
21 if (!(defined $opts{i} and defined $opts{format} and defined $opts{gfa} ) || defined $opts{h}) { #necessary arguments
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
22 &usage;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
23 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
24
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
25 my $time=&Time();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
26 print "miPlant program start:\n The time is $time!\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
27 print "Command line:\n $0 @ARGV\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
28
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
29 my $format=$opts{'format'};
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
30 if ($format ne "fastq" && $format ne "fq" && $format ne "fasta" && $format ne "fa") {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
31 #&printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
32 die "Parameter \"-format\" is error! Parameter is fastq, fq, fasta or fa\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
33 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
34
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
35 my $phred_qv=64;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
36 if (defined $opts{'phred'}) {$phred_qv=$opts{'phred'};}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
37
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
38 my @inputfiles=@{$opts{'i'}};
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
39 my @inputtags=@{$opts{'tag'}};
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
40
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
41 my $mypath=`pwd`;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
42 chomp $mypath;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
43
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
44 my $dir=defined $opts{'o'} ? $opts{'o'} : "$mypath/preProcess/";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
45
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
46
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
47 unless ($dir=~/\/$/) {$dir.="/";}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
48 if (not -d $dir) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
49 mkdir $dir;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
50 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
51 my $config=$dir."/input_config";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
52 open CONFIG,">$config";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
53 for (my $i=0;$i<@inputfiles;$i++) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
54 print CONFIG $inputfiles[$i],"\t",$inputtags[$i],"\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
55 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
56 close CONFIG;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
57
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
58 my $scipt_path=defined $opts{'path'} ? $opts{'path'} : "/Users/big/galaxy-dist/tools/myTools/";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
59
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
60 my $a="ATCTCGTATG"; #adapter
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
61 if (defined $opts{'a'}) {$a=$opts{'a'};}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
62
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
63 my $m=6; #adapter minimum mapped nt
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
64 if (defined $opts{'M'}) {$m=$opts{'M'};}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
65
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
66 my $t=1; #threads number
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
67 if (defined $opts{'t'}) {$t=$opts{'t'};}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
68
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
69 my $min_nt=19; # minimum reads length
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
70 if (defined $opts{'min'}) {$min_nt=$opts{'min'};}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
71
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
72 my $max_nt=28; #maximum reads length
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
73 if (defined $opts{'max'}) {$max_nt=$opts{'max'};}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
74
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
75 my $mis=0; #mismatch number for microRNA
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
76 if (defined $opts{'mis'}) {$mis=$opts{'mis'};}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
77
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
78 my $mis_rfam=0;# mismatch number for rfam
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
79 if (defined $opts{'v'}) {$mis_rfam=$opts{'v'};}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
80
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
81 my (@filein,@mark,@clean);
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
82 #&read_config();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
83 @filein=@inputfiles;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
84 @mark=@inputtags;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
85
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
86 &checkfa($opts{gfa});
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
87
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
88
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
89 ##### clip adpter --> clean data start
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
90 my $preprocess=$dir."preProcess_clean/";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
91 mkdir $preprocess;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
92 my $can_use_threads = eval 'use threads; 1';
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
93 if ($can_use_threads) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
94 # Do processing using threads
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
95 print "Do processing using threads\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
96 my @filein1=@filein; my @mark1=@mark;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
97 while (@filein1>0) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
98 my @thrs; my @res;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
99 for (my $i=0;$i<$t ;$i++) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
100 last if(@filein1==0);
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
101 my $in=shift @filein1;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
102 my $out=shift @mark1;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
103 push @clean,$preprocess.$out."_clips_adapter.fq";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
104 $thrs[$i]=threads->create(\&clips,$in,$out);
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
105 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
106 for (my $i=0;$i<@thrs;$i++) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
107 $res[$i]=$thrs[$i]->join();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
108 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
109 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
110 } else {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
111 # Do not processing using threads
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
112 print "Do not processing using threads\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
113 for (my $i=0;$i<@filein ;$i++) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
114 my $in=$filein[$i];
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
115 my $out=$mark[$i];
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
116 push @clean,$preprocess.$out."_clips_adapter.fq";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
117 &clips($in,$out);
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
118 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
119 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
120
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
121 ##### clip adpter --> clean data end
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
122
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
123 my $collapsed=$preprocess."collapse_reads.fa";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
124 my $data=$preprocess."collapse_reads_${min_nt}_${max_nt}.fa"; ## raw clean data
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
125 &collapse(\@clean,$collapsed); #collapse reads to tags
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
126
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
127 &filterbylength(); # filter <$min_nt && >$max_nt
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
128
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
129 print "The final clean data file is $data, only contains reads which length is among $min_nt\~$max_nt\n\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
130
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
131
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
132 $time=Time();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
133 print "$time: Genome alignment!\n\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
134 my $genome_map=$dir."genome_match";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
135 &genome($data);
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
136 #my $genome_map=&search($dir,"genome_match_");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
137 my $mapfile=$genome_map."/genome_mapped.bwt";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
138 my $mapfa=$genome_map."/genome_mapped.fa";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
139 my $unmap=$genome_map."/genome_not_mapped.fa";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
140
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
141 chdir $dir;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
142 my $pathfile="$dir/path.txt";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
143 open PA,">$pathfile";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
144 print PA "$config\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
145 print PA "$preprocess\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
146 print PA "$genome_map\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
147
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
148 if (defined $opts{'rfam'}) { #rfam mapping and analysis
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
149 $time=Time();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
150 print "$time: RNA annotate!\n\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
151 $time=~s/:/-/g;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
152 $time=~s/ /-/g;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
153 my $rfam_exp_dir=$dir."rfam_match";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
154 &rfam();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
155 #my $rfam_exp_dir=&search($dir,"rfam_match_");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
156 print PA "$rfam_exp_dir\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
157
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
158 my $tag=join "\\;" ,@mark;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
159 system("perl $scipt_path/count_rfam_express.pl -i $rfam_exp_dir/rfam_mapped.bwt -tag $tag -o rfam_non-miRNA_annotation.txt");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
160 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
161
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
162
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
163 close PA;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
164 system("perl $scipt_path/html_preprocess.pl -i $pathfile -format $format -min $min_nt -max $max_nt -o $dir/preprocessResult.html");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
165
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
166 $time=Time();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
167 print "$time: Program end!!\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
168
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
169 ############################## sub programs ###################################
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
170 sub genome{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
171 my ($file)=@_;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
172 if(defined $opts{'idx'}){
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
173 system("perl $scipt_path/matching.pl -i $file -g $opts{gfa} -r 1000 -v $mis -p $t -o $dir -index $opts{idx}") ;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
174 # print "\nmatching.pl -i $file -g $opts{gfa} -v $mis -p $t -r $hit -o $dir -index $opts{idx} -time $time\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
175 }else{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
176 system("perl $scipt_path/matching.pl -i $file -g $opts{gfa} -r 1000 -v $mis -p $t -o $dir") ;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
177 # print "\nmatching.pl -i $file -g $opts{gfa} -v $mis -p $t -r $hit -o $dir -time $time\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
178 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
179 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
180 sub rfam{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
181 if (defined $opts{'idx2'}) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
182 system("perl $scipt_path/rfam.pl -i $mapfa -ref $opts{rfam} -v $mis_rfam -p $t -o $dir -index $opts{idx2} ");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
183 # print "\nrfam.pl -i $data2 -ref $opts{rfam} -v $mis_rfam -p $t -o $dir -index $opts{idx2} -time $time\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
184 }else{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
185 system("perl $scipt_path/rfam.pl -i $mapfa -ref $opts{rfam} -v $mis_rfam -p $t -o $dir ");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
186 # print "\nrfam.pl -i $data2 -ref $opts{rfam} -v $mis_rfam -p $t -o $dir -time $time\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
187 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
188 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
189 sub filterbylength{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
190 my $tmpmark=join ",", @mark;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
191 system("perl $scipt_path/filterReadsByLength.pl -i $collapsed -o $data -min $min_nt -max $max_nt -mark $tmpmark");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
192 system("perl $scipt_path/Length_Distibution.pl -i $preprocess/reads_length_distribution.txt -o $preprocess/length.html");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
193 # print "\nfilterReadsByLength.pl -i $collapsed -o $data -min $min_nt -max $max_nt -mark $tmpmark\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
194
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
195 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
196 sub collapse{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
197 my ($ins,$data)=@_;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
198 my $str="";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
199 for (my $i=0;$i<@{$ins};$i++) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
200 $str .="-i $$ins[$i] ";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
201 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
202 system ("perl $scipt_path/collapseReads2Tags.pl $str -mark seq -o $data -format $format");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
203 # print "\ncollapseReads2Tags.pl $str -mark seq -o $data -format $format\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
204 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
205
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
206 sub clips{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
207 my ($in,$out)=@_;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
208 my $adapter=$preprocess.$out."_clips_adapter.fq";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
209 if($format eq "fq" || $format eq "fastq"){
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
210 system("fastx_clipper -a $a -M $m -Q $phred_qv -i $in -o $adapter") ;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
211 # print "\nfastx_clipper -a $a -M $m -Q $phred_qv -i $in -o $adapter\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
212 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
213 if($format eq "fa" || $format eq "fasta"){
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
214 system("fastx_clipper -a $a -M $m -i $in -o $adapter") ;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
215 # print "\nfastx_clipper -a $a -M $m -i $in -o $adapter\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
216 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
217 #my $clean=$preprocess.$out."_clean.fq";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
218 #system("filterReadsByLength.pl -i $adapter -o $clean -min $min_nt -max $max_nt ");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
219
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
220 return;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
221 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
222
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
223 sub read_config{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
224 open CON,"<$config";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
225 while (my $aline=<CON>) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
226 chomp $aline;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
227 my @tmp=split/\t/,$aline;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
228 push @filein,$tmp[0];
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
229 push @mark,$tmp[1];
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
230 &check_rawdata($tmp[0]);
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
231 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
232 close CON;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
233 if (@filein != @mark) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
234 #&printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
235 die "Maybe config file have some wrong!!!\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
236 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
237 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
238 sub check_rawdata{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
239 my ($fileforcheck)=@_;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
240 if (!(-s $fileforcheck)) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
241 #&printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
242 die "Can not find $fileforcheck, or file is empty!!!\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
243 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
244 if ($format eq "fasta" || $format eq "fa") {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
245 &checkfa($fileforcheck);
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
246 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
247 if ($format eq "fastq" || $format eq "fq") {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
248 &checkfq($fileforcheck);
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
249 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
250 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
251 sub checkfa{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
252 my ($file_reads)=@_;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
253 open N,"<$file_reads";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
254 my $line=<N>;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
255 chomp $line;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
256 if($line !~ /^>\S+/){
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
257 #printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
258 die "The first line of file $file_reads does not start with '>identifier'
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
259 Reads file $file_reads is not a valid fasta file\n\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
260 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
261 if(<N> !~ /^[ACGTNacgtn]*$/){
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
262 #printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
263 die "File $file_reads contains not allowed characters in sequences
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
264 Allowed characters are ACGTN
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
265 Reads file $file_reads is not a fasta file\n\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
266 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
267 close N;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
268 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
269 sub checkfq{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
270 my ($file_reads)=@_;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
271
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
272 open N,"<$file_reads";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
273 for (my $i=0;$i<10;$i++) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
274 my $a=<N>;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
275 my $b=<N>;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
276 my $c=<N>;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
277 my $d=<N>;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
278 chomp $a;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
279 chomp $b;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
280 chomp $c;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
281 chomp $d;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
282 if($a!~/^\@/){
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
283 #&printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
284 die "$file_reads is not a fastq file\n\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
285 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
286 if($b!~ /^[ACGTNacgtn]*$/){
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
287 #&printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
288 die "File $file_reads contains not allowed characters in sequences
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
289 Allowed characters are ACGTN
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
290 Reads file $file_reads is not a fasta file\n\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
291 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
292 if ($c!~/^\@/ && $c!~/^\+/) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
293 #&printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
294 die "$file_reads is not a fastq file\n\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
295 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
296 if ((length $b) != (length $d)) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
297 #&printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
298 die "$file_reads is not a fastq file\n\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
299 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
300 my @qv=split //,$d;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
301 for (my $j=0;$j<@qv ;$j++) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
302 my $q=ord($qv[$j])-64;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
303 if($q<0){$phred_qv=33;}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
304 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
305 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
306 close N;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
307 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
308
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
309 sub search{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
310 my ($dir,$str)=@_;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
311 opendir I,$dir;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
312 my @ret;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
313 while (my $file=readdir I) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
314 if ($file=~/$str/) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
315 push @ret, $file;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
316 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
317 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
318 closedir I;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
319 if (@ret != 1) {
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
320 #&printErr();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
321
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
322 die "Can not find directory or file which name has string: $str !!!\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
323 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
324 return $ret[0];
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
325 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
326
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
327 sub Time{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
328 my $time=time();
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
329 my ($sec,$min,$hour,$day,$month,$year) = (localtime($time))[0,1,2,3,4,5,6];
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
330 $month++;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
331 $year+=1900;
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
332 if (length($sec) == 1) {$sec = "0"."$sec";}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
333 if (length($min) == 1) {$min = "0"."$min";}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
334 if (length($hour) == 1) {$hour = "0"."$hour";}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
335 if (length($day) == 1) {$day = "0"."$day";}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
336 if (length($month) == 1) {$month = "0"."$month";}
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
337 #print "$year-$month-$day $hour:$min:$sec\n";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
338 return("$year-$month-$day $hour:$min:$sec");
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
339 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
340
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
341
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
342 sub usage{
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
343 print <<"USAGE";
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
344 Version $version
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
345 Usage:
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
346 $0 -i -format -gfa -index -rfam -a -M -min -max -mis -v -t -o -path
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
347 options:
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
348 -i input files, # raw data file, can be multipe eg. -i xxx.fq -i xxx .fq ...
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
349 -tag string # raw data file names, -tag xxx -tag xxx
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
350
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
351 -format string,#specific input rawdata file format : fastq|fq|fasta|fa
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
352 -phred int # phred quality number, default is 64
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
353
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
354 -path scirpt path
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
355
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
356 -gfa string, input file # genome fasta. sequence file
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
357 -idx string, genome file index, file-prefix #(must be indexed by bowtie-build) The parameter
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
358 string must be the prefix of the bowtie index. For instance, if
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
359 the first indexed file is called 'h_sapiens_37_asm.1.ebwt' then
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
360 the prefix is 'h_sapiens_37_asm'.##can be null
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
361
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
362 -rfam string, input file# rfam database file, microRNAs must not be contained in this file## if not define, rfam small RNA will not be count.
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
363 -idx2 string, rfam file index, file-prefix #(must be indexed by bowtie-build) The parameter
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
364 string must be the prefix of the bowtie index. For instance, if
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
365 the first indexed file is called 'h_sapiens_37_asm.1.ebwt' then
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
366 the prefix is 'h_sapiens_37_asm'.##can be null
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
367
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
368 -a string, ADAPTER string. default is ATCTCGTATG.
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
369 -M int, require minimum adapter alignment length of N. If less than N nucleotides aligned with the adapter - don't clip it.
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
370 -min int, reads min length,default is 19.
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
371 -max int, reads max length,default is 28.
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
372
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
373 -mis [int] number of allowed mismatches when mapping reads to genome, default 0
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
374 -v <int> report end-to-end hits w/ <=v mismatches; ignore qualities,default 0; used in rfam alignment
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
375
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
376 -t int, number of threads [1]
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
377
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
378 -o output directory# absolute path
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
379 -h help
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
380 USAGE
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
381 exit(1);
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
382 }
6006e58458ae Uploaded
adefelicibus
parents:
diff changeset
383