File Coverage

Bio/Seq/QualI.pm
Criterion Covered Total %
statement 10 89 11.2
branch 0 36 0.0
condition n/a
subroutine 4 18 22.2
pod 14 14 100.0
total 28 157 17.8


line stmt bran cond sub pod time code
1             #
2             # BioPerl module for Bio::Seq::QualI
3             #
4             # Please direct questions and support issues to
5             #
6             # Cared for by Chad Matsalla
7             #
8             # Copyright Chad Matsalla
9             #
10             # You may distribute this module under the same terms as perl itself
11              
12             # POD documentation - main docs before the code
13              
14             =head1 NAME
15              
16             Bio::Seq::QualI - Interface definition for a Bio::Seq::Qual
17              
18             =head1 SYNOPSIS
19              
20             # get a Bio::Seq::Qual compliant object somehow
21              
22             # to test this is a seq object
23              
24             $obj->isa("Bio::Seq::QualI")
25             || $obj->throw("$obj does not implement the Bio::Seq::QualI interface");
26              
27             # accessors
28              
29             $string = $obj->qual();
30             $substring = $obj->subqual(12,50);
31             $display = $obj->display_id(); # for human display
32             $id = $obj->primary_id(); # unique id for this object,
33             # implementation defined
34             $unique_key= $obj->accession_number();
35             # unique biological id
36              
37              
38              
39             =head1 DESCRIPTION
40              
41             This object defines an abstract interface to basic quality
42             information. PrimaryQual is an object just for the quality and its
43             name(s), nothing more. There is a pure perl implementation of this in
44             Bio::Seq::PrimaryQual. If you just want to use Bio::Seq::PrimaryQual
45             objects, then please read that module first. This module defines the
46             interface, and is of more interest to people who want to wrap their
47             own Perl Objects/RDBs/FileSystems etc in way that they "are" bioperl
48             quality objects, even though it is not using Perl to store the
49             sequence etc.
50              
51             This interface defines what bioperl consideres necessary to "be" a
52             sequence of qualities, without providing an implementation of
53             this. (An implementation is provided in Bio::Seq::PrimaryQual). If you
54             want to provide a Bio::Seq::PrimaryQual 'compliant' object which in
55             fact wraps another object/database/out-of-perl experience, then this
56             is the correct thing to wrap, generally by providing a wrapper class
57             which would inherit from your object and this Bio::Seq::QualI
58             interface. The wrapper class then would have methods lists in the
59             "Implementation Specific Functions" which would provide these methods
60             for your object.
61              
62              
63             =head1 FEEDBACK
64              
65             =head2 Mailing Lists
66              
67             User feedback is an integral part of the evolution of this and other
68             Bioperl modules. Send your comments and suggestions preferably to one
69             of the Bioperl mailing lists. Your participation is much appreciated.
70              
71             bioperl-l@bioperl.org - General discussion
72             http://bioperl.org/wiki/Mailing_lists - About the mailing lists
73              
74             =head2 Support
75              
76             Please direct usage questions or support issues to the mailing list:
77              
78             I
79              
80             rather than to the module maintainer directly. Many experienced and
81             reponsive experts will be able look at the problem and quickly
82             address it. Please include a thorough description of the problem
83             with code and data examples if at all possible.
84              
85             =head2 Reporting Bugs
86              
87             Report bugs to the Bioperl bug tracking system to help us keep track
88             the bugs and their resolution. Bug reports can be submitted via the
89             web:
90              
91             https://github.com/bioperl/bioperl-live/issues
92              
93             =head1 AUTHOR - Chad Matsalla
94              
95             This module is heavily based on Bio::Seq::PrimarySeq and is modeled after
96             or outright copies sections of it. Thanks Ewan!
97              
98             Email bioinformatics@dieselwurks.com
99              
100             =head1 APPENDIX
101              
102             The rest of the documentation details each of the object methods.
103             Internal methods are usually preceded with a _
104              
105             =cut
106              
107              
108             # Let the code begin...
109              
110              
111             package Bio::Seq::QualI;
112 5     5   36 use strict;
  5         15  
  5         139  
113 5     5   28 use Carp;
  5         10  
  5         295  
114              
115 5     5   28 use base qw(Bio::Root::RootI);
  5         10  
  5         4824  
116              
117             =head1 Implementation Specific Functions
118              
119             These functions are the ones that a specific implementation must
120             define.
121              
122             =head2 qual()
123              
124             Title : qual()
125             Usage : @quality_values = @{$obj->qual()};
126             Function: Returns the quality as a reference to an array containing the
127             quality values. The individual elements of the quality array are
128             not validated and can be any numeric value.
129             Returns : A reference to an array.
130             Status :
131              
132             =cut
133              
134             sub qual {
135 0     0 1 0 my ($self) = @_;
136 0 0       0 if( $self->can('throw') ) {
137 0         0 $self->throw("Bio::Seq::QualI definition of qual - implementing class did not provide this method");
138             } else {
139 0         0 confess("Bio::Seq::QualI definition of qual - implementing class did not provide this method");
140             }
141             }
142              
143             =head2 subqual($start,$end)
144              
145             Title : subqual($start,$end)
146             Usage : @subset_of_quality_values = @{$obj->subseq(10,40)};
147             Function: returns the quality values from $start to $end, where the
148             first value is 1 and the number is inclusive, ie 1-2 are the first
149             two bases of the sequence. Start cannot be larger than end but can
150             be equal.
151             Returns : A reference to an array.
152             Args : a start position and an end position
153              
154              
155             =cut
156              
157             sub subqual {
158 0     0 1 0 my ($self) = @_;
159              
160 0 0       0 if( $self->can('throw') ) {
161 0         0 $self->throw("Bio::Seq::QualI definition of subqual - implementing class did not provide this method");
162             } else {
163 0         0 confess("Bio::Seq::QualI definition of subqual - implementing class did not provide this method");
164             }
165              
166             }
167              
168             =head2 display_id()
169              
170             Title : display_id()
171             Usage : $id_string = $obj->display_id() _or_
172             $id_string = $obj->display_id($new_display_id);
173             Function: Returns the display id, aka the common name of the Quality
174             object.
175             The semantics of this is that it is the most likely string to be
176             used as an identifier of the quality sequence, and likely to have
177             "human" readability. The id is equivalent to the ID field of the
178             GenBank/EMBL databanks and the id field of the Swissprot/sptrembl
179             database. In fasta format, the >(\S+) is presumed to be the id,
180             though some people overload the id to embed other information.
181             Bioperl does not use any embedded information in the ID field,
182             and people are encouraged to use other mechanisms (accession field
183             for example, or extending the sequence object) to solve this.
184             Notice that $seq->id() maps to this function, mainly for
185             legacy/convience issues
186             Returns : A string
187             Args : If an arg is provided, it will replace the existing display_id
188             in the object.
189              
190              
191             =cut
192              
193             sub display_id {
194 0     0 1 0 my ($self) = @_;
195              
196 0 0       0 if( $self->can('throw') ) {
197 0         0 $self->throw("Bio::Seq::QualI definition of id - implementing class did not provide this method");
198             } else {
199 0         0 confess("Bio::Seq::QualI definition of id - implementing class did not provide this method");
200             }
201              
202             }
203              
204              
205             =head2 accession_number()
206              
207             Title : accession_number()
208             Usage : $unique_biological_key = $obj->accession_number(); _or_
209             $unique_biological_key = $obj->accession_number($new_acc_num);
210             Function: Returns the unique biological id for a sequence, commonly
211             called the accession_number. For sequences from established
212             databases, the implementors should try to use the correct
213             accession number. Notice that primary_id() provides the unique id
214             for the implementation, allowing multiple objects to have the same
215             accession number in a particular implementation. For sequences
216             with no accession number, this method should return "unknown".
217             Returns : A string.
218             Args : If an arg is provided, it will replace the existing
219             accession_number in the object.
220              
221             =cut
222              
223             sub accession_number {
224 0     0 1 0 my ($self,@args) = @_;
225              
226 0 0       0 if( $self->can('throw') ) {
227 0         0 $self->throw("Bio::Seq::QualI definition of seq - implementing class did not provide this method");
228             } else {
229 0         0 confess("Bio::Seq::QualI definition of seq - implementing class did not provide this method");
230             }
231              
232             }
233              
234              
235              
236             =head2 primary_id()
237              
238             Title : primary_id()
239             Usage : $unique_implementation_key = $obj->primary_id(); _or_
240             $unique_implementation_key = $obj->primary_id($new_prim_id);
241             Function: Returns the unique id for this object in this implementation.
242             This allows implementations to manage their own object ids in a
243             way the implementation can control clients can expect one id to
244             map to one object. For sequences with no accession number, this
245             method should return a stringified memory location.
246             Returns : A string
247             Args : If an arg is provided, it will replace the existing
248             primary_id in the object.
249              
250             =cut
251              
252             sub primary_id {
253 0     0 1 0 my ($self,@args) = @_;
254              
255 0 0       0 if( $self->can('throw') ) {
256 0         0 $self->throw("Bio::Seq::QualI definition of qual - implementing class did not provide this method");
257             } else {
258 0         0 confess("Bio::Seq::QualI definition of qual - implementing class did not provide this method");
259             }
260              
261             }
262              
263              
264             =head2 can_call_new()
265              
266             Title : can_call_new()
267             Usage : if( $obj->can_call_new ) {
268             $newobj = $obj->new( %param );
269             }
270             Function: can_call_new returns 1 or 0 depending on whether an
271             implementation allows new constructor to be called. If a new
272             constructor is allowed, then it should take the followed hashed
273             constructor list.
274             $myobject->new( -qual => $quality_as_string,
275             -display_id => $id,
276             -accession_number => $accession,
277             );
278             Example :
279             Returns : 1 or 0
280             Args :
281              
282              
283             =cut
284              
285             sub can_call_new{
286 0     0 1 0 my ($self,@args) = @_;
287             # we default to 0 here
288 0         0 return 0;
289             }
290              
291             =head2 qualat($position)
292              
293             Title : qualat($position)
294             Usage : $quality = $obj->qualat(10);
295             Function: Return the quality value at the given location, where the
296             first value is 1 and the number is inclusive, ie 1-2 are the first
297             two bases of the sequence. Start cannot be larger than end but can
298             be equal.
299             Returns : A scalar.
300             Args : A position.
301              
302             =cut
303              
304             sub qualat {
305 0     0 1 0 my ($self,$value) = @_;
306 0 0       0 if( $self->can('warn') ) {
307 0         0 $self->warn("Bio::Seq::QualI definition of qualat - implementing class did not provide this method");
308             } else {
309 0         0 warn("Bio::Seq::QualI definition of qualat - implementing class did not provide this method");
310             }
311 0         0 return '';
312             }
313              
314             =head1 Optional Implementation Functions
315              
316             The following functions rely on the above functions. A implementing
317             class does not need to provide these functions, as they will be
318             provided by this class, but is free to override these functions.
319              
320             All of revcom(), trunc(), and translate() create new sequence
321             objects. They will call new() on the class of the sequence object
322             instance passed as argument, unless can_call_new() returns FALSE. In
323             the latter case a Bio::PrimarySeq object will be created. Implementors
324             which really want to control how objects are created (eg, for object
325             persistence over a database, or objects in a CORBA framework), they
326             are encouraged to override these methods
327              
328             =head2 revcom
329              
330             Title : revcom
331             Usage : @rev = @{$qual->revcom()};
332             Function: Produces a new Bio::Seq::QualI implementing object which
333             is reversed from the original quality array.
334             The id is the same id as the original sequence, and the accession number
335             is also identical. If someone wants to track that this sequence has
336             been reversed, it needs to define its own extensions
337              
338             To do an inplace edit of an object you can go:
339              
340             $qual = $qual->revcom();
341              
342             This of course, causes Perl to handle the garbage collection of the old
343             object, but it is roughly speaking as efficient as an inplace edit.
344             Returns : A new (fresh) Bio::Seq::PrimaryQualI object
345             Args : none
346              
347             =cut
348              
349             sub revcom{
350 0     0 1 0 my ($self) = @_;
351             # this is the cleanest way
352 0         0 my @qualities = @{$self->qual()};
  0         0  
353 0         0 my @reversed_qualities = reverse(@qualities);
354 0         0 my $seqclass;
355 0 0       0 if($self->can_call_new()) {
356 0         0 $seqclass = ref($self);
357             } else {
358 0         0 $seqclass = 'Bio::Seq::PrimaryQual';
359             # Wassat?
360             # $self->_attempt_to_load_Seq();
361             }
362             # the \@reverse_qualities thing works simply because I will it to work.
363 0         0 my $out = $seqclass->new( '-qual' => \@reversed_qualities,
364             '-display_id' => $self->display_id,
365             '-accession_number' => $self->accession_number,
366             '-desc' => $self->desc()
367             );
368 0         0 return $out;
369             }
370              
371             =head2 trunc()
372              
373             Title : trunc
374             Usage : $subseq = $myseq->trunc(10,100);
375             Function: Provides a truncation of a sequence,
376             Returns : a fresh Bio::Seq::QualI implementing object
377             Args : Two integers denoting first and last base of the sub-sequence.
378              
379              
380             =cut
381              
382             sub trunc {
383 0     0 1 0 my ($self,$start,$end) = @_;
384              
385 0 0       0 if( !$end ) {
386 0 0       0 if( $self->can('throw') ) {
387 0         0 $self->throw("trunc start,end");
388             } else {
389 0         0 confess("[$self] trunc start,end");
390             }
391             }
392              
393 0 0       0 if( $end < $start ) {
394 0 0       0 if( $self->can('throw') ) {
395 0         0 $self->throw("$end is smaller than $start. if you want to truncated and reverse complement, you must call trunc followed by revcom. Sorry.");
396             } else {
397 0         0 confess("[$self] $end is smaller than $start. If you want to truncated and reverse complement, you must call trunc followed by revcom. Sorry.");
398             }
399             }
400              
401 0         0 my $r_qual = $self->subqual($start,$end);
402              
403 0         0 my $seqclass;
404 0 0       0 if($self->can_call_new()) {
405 0         0 $seqclass = ref($self);
406             } else {
407 0         0 $seqclass = 'Bio::Seq::PrimaryQual';
408             # wassat?
409             # $self->_attempt_to_load_Seq();
410             }
411 0         0 my $out = $seqclass->new( '-qual' => $r_qual,
412             '-display_id' => $self->display_id,
413             '-accession_number' => $self->accession_number,
414             '-desc' => $self->desc()
415             );
416 0         0 return $out;
417             }
418              
419              
420             =head2 translate()
421              
422             Title : translate()
423             Usage : $protein_seq_obj = $dna_seq_obj->translate
424             #if full CDS expected:
425             $protein_seq_obj = $cds_seq_obj->translate(undef,undef,undef,undef,1);
426             Function: Completely useless in this interface.
427             Returns : Nothing.
428             Args : Nothing.
429              
430             =cut
431              
432              
433             sub translate {
434 1     1 1 4 return 0;
435             }
436              
437              
438             =head2 id()
439              
440             Title : id()
441             Usage : $id = $qual->id()
442             Function: ID of the quality. This should normally be (and actually is in
443             the implementation provided here) just a synonym for display_id().
444             Example :
445             Returns : A string.
446             Args :
447              
448              
449             =cut
450              
451             sub id {
452 0     0 1   my ($self)= @_;
453 0           return $self->display_id();
454             }
455              
456             =head2 length()
457              
458             Title : length()
459             Usage : $length = $qual->length();
460             Function: Return the length of the array holding the quality values.
461             Under most circumstances, this should match the number of quality
462             values but no validation is done when the PrimaryQual object is
463             constructed and non-digits could be put into this array. Is this a
464             bug? Just enough rope...
465             Returns : A scalar (the number of elements in the quality array).
466             Args : None.
467              
468             =cut
469              
470             sub length {
471 0     0 1   my ($self)= @_;
472 0 0         if( $self->can('throw') ) {
473 0           $self->throw("Bio::Seq::QualI definition of length - implementing class did not provide this method");
474             } else {
475 0           confess("Bio::Seq::QualI definition of length - implementing class did not provide this method");
476             }
477             }
478              
479              
480             =head2 desc()
481              
482             Title : desc()
483             Usage : $qual->desc($newval);
484             $description = $seq->desc();
485             Function: Get/set description text for a qual object
486             Example :
487             Returns : value of desc
488             Args : newvalue (optional)
489              
490             =cut
491              
492             sub desc {
493 0     0 1   my ($self,$value) = @_;
494 0 0         if( $self->can('warn') ) {
495 0           $self->warn("Bio::Seq::QualI definition of desc - implementing class did not provide this method");
496             } else {
497 0           warn("Bio::Seq::QualI definition of desc - implementing class did not provide this method");
498             }
499 0           return '';
500             }
501              
502             # These methods are here for backward compatibility with the old, 0.5
503             # Seq objects. They all throw warnings that someone is using a
504             # deprecated method, and may eventually be removed completely from
505             # this object. However, they are important to ease the transition from
506             # the old system.
507              
508             =head1 Private functions
509              
510             These are some private functions for the PrimarySeqI interface. You do not
511             need to implement these functions
512              
513             =head2 _attempt_to_load_Seq
514              
515             Title : _attempt_to_load_Seq
516             Usage :
517             Function:
518             Example :
519             Returns :
520             Args :
521              
522              
523             =cut
524              
525             sub _attempt_to_load_Seq{
526 0     0     my ($self) = @_;
527              
528 0 0         if( $main::{'Bio::Seq::PrimaryQual'} ) {
529 0           return 1;
530             } else {
531 0           eval {
532 0           require Bio::Seq::PrimaryQual;
533             };
534 0 0         if( $@ ) {
535 0 0         if( $self->can('throw') ) {
536 0           $self->throw("Bio::Seq::PrimaryQual could not be loaded for $self\nThis indicates that you are using Bio::Seq::PrimaryQualI without Bio::Seq::PrimaryQual loaded and without providing a complete solution\nThe most likely problem is that there has been a misconfiguration of the bioperl environment\nActual exception\n\n$@\n");
537             } else {
538 0           confess("Bio::Seq::PrimarySeq could not be loaded for $self\nThis indicates that you are usnig Bio::Seq::PrimaryQualI without Bio::Seq::PrimaryQual loaded and without providing a complete solution\nThe most likely problem is that there has been a misconfiguration of the bioperl environment\nActual exception\n\n$@\n");
539             }
540 0           return 0;
541             }
542 0           return 1;
543             }
544              
545             }
546              
547              
548             =head2 qualtype()
549              
550             Title : qualtype()
551             Usage : if( $obj->qualtype eq 'phd' ) { /Do Something/ }
552             Function: At this time, this function is not used for
553             Bio::Seq::PrimaryQual objects. In fact, now it is a month later and
554             I just completed the Bio::Seq::SeqWithQuality object and this is
555             definitely deprecated.
556             Returns : Nothing. (not implemented)
557             Args : none
558             Status : Virtual
559              
560              
561             =cut
562              
563             sub qualtype {
564 0     0 1   my ($self,@args) = @_;
565 0 0         if( $self->can('throw') ) {
566             # $self->throw("Bio::Seq::QualI definition of qual - implementing class did not provide this method");
567 0           $self->throw("qualtypetype is not used with quality objects.");
568             } else {
569             # confess("Bio::Seq::QualI definition of qual - implementing class did not provide this method");
570 0           confess("qualtype is not used with quality objects.");
571             }
572              
573              
574             }
575              
576              
577              
578              
579             1;