annotate vcftools_main/VCFToolsStats/.svn/text-base/VCFToolsStats.pl.svn-base @ 11:f494c8d22725 draft default tip

planemo upload
author gandres
date Wed, 15 Jun 2016 09:40:02 -0400
parents 3b1436a9a6e5
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
1
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
2 #!/usr/bin/perl
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
3
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
4 use strict;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
5 use Switch;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
6 use Getopt::Long;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
7 use Bio::SeqIO;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
8
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
9 my $usage = qq~Usage:$0 <args> [<opts>]
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
10
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
11 where <args> are:
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
12
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
13 -i, --input <VCF input>
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
14 -o, --out <output basename>
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
15 ~;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
16 $usage .= "\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
17
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
18 my ($input,$out);
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
19
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
20 GetOptions(
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
21 "input=s" => \$input,
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
22 "out=s" => \$out
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
23 );
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
24
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
25
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
26 die $usage
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
27 if ( !$input);
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
28
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
29
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
30
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
31 my $nb_gene = `grep -c mRNA $input`;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
32 $nb_gene =~s/\n//g;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
33 my $nb_intergenic = `grep -c INTERGENIC $input`;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
34 $nb_intergenic =~s/\n//g;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
35
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
36 my $nb_intron = `grep -c INTRON $input`;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
37 $nb_intron =~s/\n//g;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
38 my $nb_UTR = `grep -c UTR $input`;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
39 $nb_UTR =~s/\n//g;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
40 my $nb_exon = $nb_gene - $nb_intron - $nb_UTR;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
41
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
42 my $nb_ns = `grep -c NON_SYNONYMOUS_CODING $input`;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
43 $nb_ns =~s/\n//g;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
44 my $nb_s = $nb_exon - $nb_ns;
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
45
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
46
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
47
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
48
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
49 #system("$VCFTOOLS_EXE --vcf $input --remove-filtered-all --out $out --hardy >>vcftools.log 2>&1");
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
50 system("vcftools --vcf $input --remove-filtered-all --out $out --het >>vcftools.log 2>&1");
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
51 system("vcftools --vcf $input --remove-filtered-all --out $out --TsTv-summary >>vcftools.log 2>&1");
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
52 system("vcftools --vcf $input --remove-filtered-all --out $out --missing-indv >>vcftools.log 2>&1");
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
53
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
54 open(my $G,">$out.annotation");
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
55 print $G "Genic $nb_gene\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
56 print $G "Intergenic $nb_intergenic\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
57 print $G "========\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
58 print $G "Intron $nb_intron\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
59 print $G "Exon $nb_exon\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
60 print $G "UTR $nb_UTR\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
61 print $G "========\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
62 print $G "Non-syn $nb_ns\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
63 print $G "Synonym $nb_s\n";
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
64 close($G);
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
65
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
66
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
67
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
68
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
69
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
70
3b1436a9a6e5 Uploaded
gandres
parents:
diff changeset
71