Bio::Tools::CodonTable::_codon_is: simplify with use all()
[bioperl-live.git] / bin / bp_gccalc
blob20c6d2b83f58b38c27e904eb4eddf55f74ae5176
1 #!/usr/bin/perl
3 use strict;
4 use warnings;
6 use Bio::SeqIO;
7 use Bio::Tools::SeqStats;
8 use Getopt::Long;
9 my $format = 'fasta';
10 my $file;
11 my $help =0;
12 my $aggregate;
13 GetOptions(
14 'f|format:s' => \$format,
15 'i|in:s' => \$file,
16 'h|help|?' => \$help,
17 'a|aggregate!'=> \$aggregate,
21 my $USAGE = "usage: gccalc.pl -f format -i filename\n";
22 if( $help ) {
23 die $USAGE;
26 $file = shift unless $file;
27 my $seqin;
28 if( defined $file ) {
29 print "Could not open file [$file]\n$USAGE" and exit unless -e $file;
30 $seqin = new Bio::SeqIO(-format => $format,
31 -file => $file);
32 } else {
33 $seqin = new Bio::SeqIO(-format => $format,
34 -fh => \*STDIN);
36 my ($total_base, $total_gc);
37 while( my $seq = $seqin->next_seq ) {
38 next if( $seq->length == 0 );
39 if( $seq->alphabet eq 'protein' ) {
40 warn("gccalc does not work on amino acid sequences ...skipping this seq");
41 next;
44 my $seq_stats = Bio::Tools::SeqStats->new('-seq'=>$seq);
45 my $hash_ref = $seq_stats->count_monomers(); # for DNA sequence
46 print "Seq: ", $seq->display_id, " ";
47 print $seq->desc if $seq->desc;
48 print " Len:", $seq->length, "\n";
49 $total_base += $seq->length;
50 $total_gc += $hash_ref->{'G'} + $hash_ref->{'C'};
51 printf "GC content is %.4f\n", ($hash_ref->{'G'} + $hash_ref->{'C'}) /
52 $seq->length();
54 foreach my $base (sort keys %{$hash_ref}) {
55 print "Number of bases of type ", $base, "= ", $hash_ref->{$base},"\n";
57 print "--\n";
59 if( $aggregate ) {
60 printf "Total GC content is %.4f out of %d bases\n", $total_gc / $total_base, $total_base;
62 # alternatively one could use code submitted by
63 # cckim@stanford.edu
65 sub calcgc {
66 my $seq = $_[0];
67 my @seqarray = split('',$seq);
68 my $count = 0;
69 foreach my $base (@seqarray) {
70 $count++ if $base =~ /[G|C]/i;
73 my $len = $#seqarray+1;
74 return $count / $len;
78 __END__
80 =head1 NAME
82 bp_gccalc - GC content of nucleotide sequences
84 =head1 SYNOPSIS
86 bp_gccalc [-f/--format FORMAT] [-h/--help] filename
88 bp_gccalc [-f/--format FORMAT] < filename
90 bp_gccalc [-f/--format FORMAT] -i filename
92 =head1 DESCRIPTION
94 This scripts prints out the GC content for every nucleotide sequence
95 from the input file.
97 =head1 OPTIONS
99 The default sequence format is fasta.
101 The sequence input can be provided using any of the three methods:
103 =over 3
105 =item unnamed argument
107 bp_gccalc filename
109 =item named argument
111 bp_gccalc -i filename
113 =item standard input
115 bp_gccalc < filename
117 =back
119 =head1 FEEDBACK
121 =head2 Mailing Lists
123 User feedback is an integral part of the evolution of this and other
124 Bioperl modules. Send your comments and suggestions preferably to
125 the Bioperl mailing list. Your participation is much appreciated.
127 bioperl-l@bioperl.org - General discussion
128 http://bioperl.org/wiki/Mailing_lists - About the mailing lists
130 =head2 Reporting Bugs
132 Report bugs to the Bioperl bug tracking system to help us keep track
133 of the bugs and their resolution. Bug reports can be submitted via the
134 web:
136 https://github.com/bioperl/bioperl-live/issues
138 =head1 AUTHOR - Jason Stajich
140 Email jason@bioperl.org
142 =head1 HISTORY
144 Based on script code (see bottom) submitted by cckim@stanford.edu
146 Submitted as part of bioperl script project 2001/08/06
148 =cut