annotate variant_effect_predictor/Bio/Search/Result/BlastResult.pm @ 0:1f6dce3d34e0

Uploaded
author mahtabm
date Thu, 11 Apr 2013 02:01:53 -0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
1 #-----------------------------------------------------------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
2 # $Id: BlastResult.pm,v 1.13 2002/12/24 15:48:41 jason Exp $
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
3 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
4 # BioPerl module Bio::Search::Result::BlastResult
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
5 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
6 # Cared for by Steve Chervitz <sac@bioperl.org>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
7 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
8 # You may distribute this module under the same terms as perl itself
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
9 #-----------------------------------------------------------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
10
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
11 # POD documentation - main docs before the code
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
12
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
13 =head1 NAME
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
14
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
15 Bio::Search::Result::BlastResult - A top-level BLAST Report object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
16
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
17 =head1 SYNOPSIS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
18
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
19 The construction of BlastResult objects is performed by
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
20 by the B<Bio::SearchIO::psiblast> parser.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
21 Therefore, you do not need to
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
22 use B<Bio::Search::Result::BlastResult>) directly. If you need to construct
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
23 BlastHits directly, see the new() function for details.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
24
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
25 For B<Bio::SearchIO> BLAST parsing usage examples, see the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
26 B<examples/search-blast> directory of the Bioperl distribution.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
27
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
28 =head1 DESCRIPTION
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
29
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
30 This module supports BLAST versions 1.x and 2.x, gapped and ungapped,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
31 and PSI-BLAST.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
32
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
33 =head1 DEPENDENCIES
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
34
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
35 Bio::Search::Result::BlastResult.pm is a concrete class that inherits from B<Bio::Root::Root> and B<Bio::Search::Result::ResultI>. It relies on two other modules:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
36
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
37 =over 4
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
38
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
39 =item B<Bio::Search::Hit::BlastHit>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
40
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
41 Encapsulates a single a single BLAST hit.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
42
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
43 =item B<Bio::Search::GenericDatabase>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
44
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
45 Provides an interface to a blast database metadata.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
46
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
47 =back
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
48
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
49 =head1 FEEDBACK
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
50
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
51 =head2 Mailing Lists
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
52
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
53 User feedback is an integral part of the evolution of this and other
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
54 Bioperl modules. Send your comments and suggestions preferably to one
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
55 of the Bioperl mailing lists. Your participation is much appreciated.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
56
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
57 bioperl-l@bioperl.org - General discussion
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
58 http://bio.perl.org/MailList.html - About the mailing lists
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
59
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
60 =head2 Reporting Bugs
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
61
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
62 Report bugs to the Bioperl bug tracking system to help us keep track
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
63 the bugs and their resolution. Bug reports can be submitted via email
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
64 or the web:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
65
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
66 bioperl-bugs@bio.perl.org
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
67 http://bugzilla.bioperl.org/
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
68
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
69 =head1 AUTHOR
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
70
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
71 Steve Chervitz E<lt>sac@bioperl.orgE<gt>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
72
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
73 See L<the FEEDBACK section | FEEDBACK> for where to send bug reports and comments.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
74
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
75 =head1 ACKNOWLEDGEMENTS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
76
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
77 This software was originally developed in the Department of Genetics
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
78 at Stanford University. I would also like to acknowledge my
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
79 colleagues at Affymetrix for useful feedback.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
80
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
81 =head1 COPYRIGHT
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
82
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
83 Copyright (c) 2001 Steve Chervitz. All Rights Reserved.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
84
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
85 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
86
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
87 =head1 DISCLAIMER
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
88
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
89 This software is provided "as is" without warranty of any kind.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
90
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
91 =head1 APPENDIX
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
92
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
93 The rest of the documentation details each of the object methods.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
94 Internal methods are usually preceded with a _
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
95
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
96 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
97
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
98
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
99 # Let the code begin...
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
100
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
101 package Bio::Search::Result::BlastResult;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
102
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
103 use strict;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
104
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
105 use Bio::Search::Result::ResultI;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
106 use Bio::Root::Root;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
107
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
108 use overload
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
109 '""' => \&to_string;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
110
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
111 use vars qw(@ISA $Revision );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
112
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
113 $Revision = '$Id: BlastResult.pm,v 1.13 2002/12/24 15:48:41 jason Exp $'; #'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
114 @ISA = qw( Bio::Root::Root Bio::Search::Result::ResultI);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
115
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
116 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
117 sub new {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
118 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
119 my ($class, @args) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
120 my $self = $class->SUPER::new(@args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
121 return $self;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
122 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
123
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
124 #sub DESTROY {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
125 # my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
126 # print STDERR "->DESTROYING $self\n";
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
127 #}
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
128
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
129
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
130 #=================================================
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
131 # Begin Bio::Search::Result::ResultI implementation
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
132 #=================================================
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
133
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
134 =head2 next_hit
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
135
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
136 See L<Bio::Search::Result::ResultI::next_hit()|Bio::Search::Result::ResultI> for documentation
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
137
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
138 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
139
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
140 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
141 sub next_hit {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
142 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
143 my ($self) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
144
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
145 unless(defined $self->{'_hit_queue'}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
146 $self->{'_hit_queue'} = [$self->hits()];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
147 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
148
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
149 shift @{$self->{'_hit_queue'}};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
150 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
151
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
152 =head2 query_name
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
153
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
154 See L<Bio::Search::Result::ResultI::query_name()|Bio::Search::Result::ResultI> for documentation
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
155
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
156 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
157
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
158 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
159 sub query_name {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
160 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
161 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
162 if (@_) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
163 my $name = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
164 $name =~ s/^\s+|(\s+|,)$//g;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
165 $self->{'_query_name'} = $name;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
166 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
167 return $self->{'_query_name'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
168 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
169
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
170 =head2 query_length
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
171
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
172 See L<Bio::Search::Result::ResultI::query_length()|Bio::Search::Result::ResultI> for documentation
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
173
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
174 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
175
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
176 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
177 sub query_length {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
178 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
179 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
180 if(@_) { $self->{'_query_length'} = shift; }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
181 return $self->{'_query_length'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
182 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
183
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
184 =head2 query_description
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
185
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
186 See L<Bio::Search::Result::ResultI::query_description()|Bio::Search::Result::ResultI> for documentation
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
187
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
188 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
189
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
190 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
191 sub query_description {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
192 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
193 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
194 if(@_) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
195 my $desc = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
196 defined $desc && $desc =~ s/(^\s+|\s+$)//g;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
197 # Remove duplicated ID at beginning of description string
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
198 defined $desc && $desc =~ s/^$self->{'_query_name'}//o;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
199 $self->{'_query_query_desc'} = $desc || '';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
200 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
201 return $self->{'_query_query_desc'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
202 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
203
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
204
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
205 =head2 analysis_method
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
206
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
207 See L<Bio::AnalysisResultI::analysis_method()|Bio::AnalysisResultI> for documentation
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
208
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
209 This implementation ensures that the name matches /blast/i.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
210
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
211 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
212
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
213 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
214 sub analysis_method {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
215 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
216 my ($self, $method) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
217 if($method ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
218 if( $method =~ /blast/i) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
219 $self->{'_analysis_prog'} = $method;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
220 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
221 $self->throw("method $method not supported in " . ref($self));
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
222 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
223 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
224 return $self->{'_analysis_prog'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
225 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
226
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
227 =head2 analysis_method_version
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
228
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
229 See L<Bio::AnalysisResultI::analysis_method_version()|Bio::AnalysisResultI> for documentation
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
230
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
231 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
232
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
233 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
234 sub analysis_method_version {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
235 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
236 my ($self, $version) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
237 if($version) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
238 $self->{'_analysis_progVersion'} = $version;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
239 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
240 return $self->{'_analysis_progVersion'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
241 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
242
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
243
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
244 =head2 analysis_query
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
245
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
246 See L<Bio::AnalysisResultI::analysis_query()|Bio::AnalysisResultI> for documentation
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
247
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
248 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
249
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
250 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
251 sub analysis_query {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
252 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
253
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
254 my ($self) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
255 if(not defined $self->{'_analysis_query'}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
256 require Bio::PrimarySeq;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
257 my $moltype = $self->analysis_method =~ /blastp|tblastn/i ? 'protein' : 'dna';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
258 $self->{'_analysis_query'} = Bio::PrimarySeq->new( -display_id => $self->query_name,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
259 -desc => $self->query_description,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
260 -moltype => $moltype
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
261 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
262 $self->{'_analysis_query'}->length( $self->query_length );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
263 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
264 return $self->{'_analysis_query'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
265 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
266
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
267 =head2 analysis_subject
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
268
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
269 Usage : $blastdb = $result->analyis_subject();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
270 Purpose : Get a Bio::Search::DatabaseI object containing
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
271 information about the database used in the BLAST analysis.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
272 Returns : Bio::Search::DatabaseI object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
273 Argument : n/a
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
274
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
275 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
276
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
277 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
278 sub analysis_subject {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
279 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
280 my ($self, $blastdb) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
281 if($blastdb) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
282 if( ref $blastdb and $blastdb->isa('Bio::Search::DatabaseI')) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
283 $self->{'_analysis_sbjct'} = $blastdb;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
284 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
285 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
286 $self->throw(-class =>'Bio::Root::BadParameter',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
287 -text => "Can't set BlastDB: not a Bio::Search::DatabaseI $blastdb"
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
288 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
289 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
290 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
291 return $self->{'_analysis_sbjct'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
292 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
293
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
294 =head2 next_feature
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
295
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
296 Title : next_feature
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
297 Usage : while( my $feat = $blast_result->next_feature ) { # do something }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
298 Function: Returns the next feature available in the analysis result, or
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
299 undef if there are no more features.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
300 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
301 Returns : A Bio::SeqFeatureI compliant object, in this case,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
302 each Bio::Search::HSP::BlastHSP object within each BlastHit.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
303 Args : None
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
304
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
305 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
306
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
307 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
308 sub next_feature{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
309 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
310 my ($self) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
311 my ($hit, $hsp);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
312 $hit = $self->{'_current_hit'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
313 unless( defined $hit ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
314 $hit = $self->{'_current_hit'} = $self->next_hit;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
315 return undef unless defined $hit;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
316 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
317 $hsp = $hit->next_hsp;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
318 unless( defined $hsp ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
319 $self->{'_current_hit'} = undef;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
320 return $self->next_feature;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
321 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
322 return $hsp || undef;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
323 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
324
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
325
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
326 sub algorithm { shift->analysis_method( @_ ); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
327 sub algorithm_version { shift->analysis_method_version( @_ ); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
328
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
329 =head2 available_parameters
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
330
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
331 Title : available_parameters
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
332 Usage : my @params = $report->available_paramters
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
333 Function: Returns the names of the available parameters
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
334 Returns : Return list of available parameters used for this report
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
335 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
336
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
337 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
338
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
339 sub available_parameters{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
340 return ();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
341 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
342
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
343
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
344 =head2 get_parameter
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
345
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
346 Title : get_parameter
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
347 Usage : my $gap_ext = $report->get_parameter('gapext')
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
348 Function: Returns the value for a specific parameter used
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
349 when running this report
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
350 Returns : string
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
351 Args : name of parameter (string)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
352
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
353 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
354
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
355 sub get_parameter{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
356 return '';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
357 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
358
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
359 =head2 get_statistic
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
360
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
361 Title : get_statistic
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
362 Usage : my $gap_ext = $report->get_statistic('kappa')
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
363 Function: Returns the value for a specific statistic available
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
364 from this report
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
365 Returns : string
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
366 Args : name of statistic (string)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
367
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
368 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
369
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
370 sub get_statistic{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
371 return '';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
372 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
373
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
374 =head2 available_statistics
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
375
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
376 Title : available_statistics
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
377 Usage : my @statnames = $report->available_statistics
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
378 Function: Returns the names of the available statistics
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
379 Returns : Return list of available statistics used for this report
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
380 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
381
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
382 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
383
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
384 sub available_statistics{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
385 return ();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
386 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
387
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
388 #=================================================
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
389 # End Bio::Search::Result::ResultI implementation
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
390 #=================================================
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
391
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
392
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
393 =head2 to_string
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
394
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
395 Title : to_string
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
396 Usage : print $blast->to_string;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
397 Function: Returns a string representation for the Blast result.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
398 Primarily intended for debugging purposes.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
399 Example : see usage
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
400 Returns : A string of the form:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
401 [BlastResult] <analysis_method> query=<name> <description> db=<database
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
402 e.g.:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
403 [BlastResult] BLASTP query=YEL060C vacuolar protease B, db=PDBUNIQ
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
404 Args : None
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
405
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
406 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
407
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
408 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
409 sub to_string {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
410 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
411 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
412 my $str = "[BlastResult] " . $self->analysis_method . " query=" . $self->query_name . " " . $self->query_description .", db=" . $self->database_name;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
413 return $str;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
414 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
415
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
416 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
417 sub database_name {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
418 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
419 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
420 my $dbname = '';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
421 if( ref $self->analysis_subject) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
422 $dbname = $self->analysis_subject->name;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
423 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
424 return $dbname;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
425 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
426
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
427 =head2 database_entries
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
428
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
429 Title : database_entries
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
430 Usage : $num_entries = $result->database_entries()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
431 Function: Used to obtain the number of entries contained in the database.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
432 Returns : a scalar integer representing the number of entities in the database
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
433 or undef if the information was not available.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
434 Args : [optional] new integer for the number of sequence entries in the db
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
435
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
436
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
437 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
438
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
439 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
440 sub database_entries {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
441 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
442 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
443 my $dbentries = '';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
444 if( ref $self->analysis_subject) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
445 $dbentries = $self->analysis_subject->entries;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
446 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
447 return $dbentries;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
448 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
449
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
450
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
451 =head2 database_letters
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
452
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
453 Title : database_letters
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
454 Usage : $size = $result->database_letters()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
455 Function: Used to obtain the size of database that was searched against.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
456 Returns : a scalar integer (units specific to algorithm, but probably the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
457 total number of residues in the database, if available) or undef if
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
458 the information was not available to the Processor object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
459 Args : [optional] new scalar integer for number of letters in db
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
460
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
461
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
462 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
463
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
464 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
465 sub database_letters {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
466 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
467 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
468 my $dbletters = '';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
469 if( ref $self->analysis_subject) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
470 $dbletters = $self->analysis_subject->letters;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
471 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
472 return $dbletters;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
473 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
474
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
475 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
476 sub hits {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
477 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
478 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
479 my @hits = ();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
480 if( ref $self->{'_hits'}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
481 @hits = @{$self->{'_hits'}};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
482 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
483 return @hits;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
484 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
485
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
486 =head2 add_hit
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
487
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
488 Usage : $blast->add_hit( $hit );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
489 Purpose : Adds a hit object to the collection of hits in this BLAST result.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
490 Returns : n/a
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
491 Argument : A Bio::Search::Hit::HitI object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
492 Comments : For PSI-BLAST, hits from all iterations are lumped together.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
493 For any given hit, you can determine the iteration in which it was
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
494 found by checking $hit->iteration().
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
495
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
496 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
497
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
498 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
499 sub add_hit {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
500 #---------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
501 my ($self, $hit) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
502 my $add_it = 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
503 unless( ref $hit and $hit->isa('Bio::Search::Hit::HitI')) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
504 $add_it = 0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
505 $self->throw(-class =>'Bio::Root::BadParameter',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
506 -text => "Can't add hit: not a Bio::Search::Hit::HitI: $hit"
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
507 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
508 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
509
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
510 # Avoid adding duplicate hits if we're doing multiple iterations (PSI-BLAST)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
511 # if( $self->iterations > 1 ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
512 # my $hit_name = $hit->name;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
513 # if( grep $hit_name eq $_, @{$self->{'_hit_names'}}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
514 # $add_it = 0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
515 # }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
516 # }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
517
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
518 if( $add_it ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
519 push @{$self->{'_hits'}}, $hit;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
520 push @{$self->{'_hit_names'}}, $hit->name;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
521 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
522 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
523
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
524
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
525 =head2 is_signif
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
526
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
527 Usage : $blast->is_signif();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
528 Purpose : Determine if the BLAST report contains significant hits.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
529 Returns : Boolean
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
530 Argument : n/a
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
531 Comments : BLAST reports without significant hits but with defined
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
532 : significance criteria will throw exceptions during construction.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
533 : This obviates the need to check significant() for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
534 : such objects.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
535
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
536 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
537
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
538 #------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
539 sub is_signif { my $self = shift; return $self->{'_is_significant'}; }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
540 #------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
541
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
542
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
543 =head2 matrix
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
544
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
545 Usage : $blast_object->matrix();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
546 Purpose : Get the name of the scoring matrix used.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
547 : This is extracted from the report.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
548 Argument : n/a
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
549 Returns : string or undef if not defined
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
550 Comments : TODO: Deprecate this and implement get_parameter('matrix').
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
551
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
552 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
553
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
554 #------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
555 sub matrix {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
556 #------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
557 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
558 if(@_) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
559 $self->{'_matrix'} = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
560 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
561 $self->{'_matrix'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
562 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
563
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
564
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
565 =head2 raw_statistics
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
566
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
567 Usage : @stats = $blast_result->raw_statistics();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
568 Purpose : Get the raw, unparsed statistical parameter section of the Blast report.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
569 This is the section at the end after the last HSP alignment.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
570 Argument : n/a
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
571 Returns : Array of strings
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
572
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
573 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
574
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
575 #------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
576 sub raw_statistics {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
577 #------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
578 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
579 if(@_) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
580 my $params = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
581 if( ref $params eq 'ARRAY') {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
582 $self->{'_raw_statistics'} = $params;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
583 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
584 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
585 $self->throw(-class =>'Bio::Root::BadParameter',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
586 -text => "Can't set statistical params: not an ARRAY ref: $params"
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
587 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
588 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
589 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
590 if(not defined $self->{'_raw_statistics'}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
591 $self->{'_raw_statistics'} = [];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
592 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
593
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
594 @{$self->{'_raw_statistics'}};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
595 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
596
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
597
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
598
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
599 =head2 no_hits_found
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
600
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
601 Usage : $nohits = $blast->no_hits_found( [iteration_number] );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
602 Purpose : Get boolean indicator indicating whether or not any hits
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
603 were present in the report.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
604
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
605 This is NOT the same as determining the number of hits via
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
606 the hits() method, which will return zero hits if there were no
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
607 hits in the report or if all hits were filtered out during the parse.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
608
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
609 Thus, this method can be used to distinguish these possibilities
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
610 for hitless reports generated when filtering.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
611
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
612 Returns : Boolean
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
613 Argument : (optional) integer indicating the iteration number (PSI-BLAST)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
614 If iteration number is not specified and this is a PSI-BLAST result,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
615 then this method will return true only if all iterations had
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
616 no hits found.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
617
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
618 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
619
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
620 #-----------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
621 sub no_hits_found {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
622 #-----------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
623 my ($self, $round) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
624
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
625 my $result = 0; # final return value of this method.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
626 # Watch the double negative!
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
627 # result = 0 means "yes hits were found"
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
628 # result = 1 means "no hits were found" (for the indicated iteration or all iterations)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
629
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
630 # If a iteration was not specified and there were multiple iterations,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
631 # this method should return true only if all iterations had no hits found.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
632 if( not defined $round ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
633 if( $self->{'_iterations'} > 1) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
634 $result = 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
635 foreach my $i( 1..$self->{'_iterations'} ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
636 if( not defined $self->{"_iteration_$i"}->{'_no_hits_found'} ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
637 $result = 0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
638 last;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
639 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
640 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
641 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
642 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
643 $result = $self->{"_iteration_1"}->{'_no_hits_found'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
644 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
645 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
646 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
647 $result = $self->{"_iteration_$round"}->{'_no_hits_found'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
648 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
649
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
650 return $result;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
651 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
652
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
653
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
654 =head2 set_no_hits_found
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
655
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
656 Usage : $blast->set_no_hits_found( [iteration_number] );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
657 Purpose : Set boolean indicator indicating whether or not any hits
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
658 were present in the report.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
659 Returns : n/a
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
660 Argument : (optional) integer indicating the iteration number (PSI-BLAST)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
661
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
662 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
663
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
664 #-----------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
665 sub set_no_hits_found {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
666 #-----------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
667 my ($self, $round) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
668 $round ||= 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
669 $self->{"_iteration_$round"}->{'_no_hits_found'} = 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
670 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
671
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
672
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
673 =head2 iterations
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
674
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
675 Usage : $num_iterations = $blast->iterations; (get)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
676 $blast->iterations($num_iterations); (set)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
677 Purpose : Set/get the number of iterations in the Blast Report (PSI-BLAST).
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
678 Returns : Total number of iterations in the report
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
679 Argument : integer (when setting)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
680
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
681 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
682
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
683 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
684 sub iterations {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
685 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
686 my ($self, $num ) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
687 if( defined $num ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
688 $self->{'_iterations'} = $num;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
689 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
690 return $self->{'_iterations'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
691 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
692
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
693
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
694 =head2 psiblast
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
695
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
696 Usage : if( $blast->psiblast ) { ... }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
697 Purpose : Set/get a boolean indicator whether or not the report
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
698 is a PSI-BLAST report.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
699 Returns : 1 if PSI-BLAST, undef if not.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
700 Argument : 1 (when setting)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
701
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
702 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
703
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
704 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
705 sub psiblast {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
706 #----------------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
707 my ($self, $val ) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
708 if( $val ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
709 $self->{'_psiblast'} = 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
710 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
711 return $self->{'_psiblast'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
712 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
713
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
714
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
715 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
716 __END__