annotate variant_effect_predictor/Bio/Seq/SeqWithQuality.pm @ 3:d30fa12e4cc5 default tip

Merge heads 2:a5976b2dce6f and 1:09613ce8151e which were created as a result of a recently fixed bug.
author devteam <devteam@galaxyproject.org>
date Mon, 13 Jan 2014 10:38:30 -0500
parents 1f6dce3d34e0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
1 # $Id: SeqWithQuality.pm,v 1.17 2002/12/19 22:02:38 matsallac Exp $
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
2 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
3 # BioPerl module for Bio::Seq::QualI
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
4 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
5 # Cared for by Chad Matsalla <bioinformatics@dieselwurks.com
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
6 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
7 # Copyright Chad Matsalla
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
8 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
9 # You may distribute this module under the same terms as perl itself
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::Seq::SeqWithQuality - Bioperl object packaging a sequence with its quality
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 use Bio::PrimarySeq;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
20 use Bio::Seq::PrimaryQual;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
21
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
22 # make from memory
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
23 my $qual = Bio::Seq::SeqWithQuality->new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
24 ( -qual => '10 20 30 40 50 50 20 10',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
25 -seq => 'ATCGATCG',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
26 -id => 'human_id',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
27 -accession_number => 'AL000012',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
28 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
29
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
30 # make from objects
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
31 # first, make a PrimarySeq object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
32 my $seqobj = Bio::PrimarySeq->new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
33 ( -seq => 'atcgatcg',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
34 -id => 'GeneFragment-12',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
35 -accession_number => 'X78121',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
36 -alphabet => 'dna'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
37 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
38
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
39 # now make a PrimaryQual object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
40 my $qualobj = Bio::Seq::PrimaryQual->new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
41 ( -qual => '10 20 30 40 50 50 20 10',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
42 -id => 'GeneFragment-12',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
43 -accession_number => 'X78121',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
44 -alphabet => 'dna'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
45 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
46
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
47 # now make the SeqWithQuality object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
48 my $swqobj = Bio::Seq::SeqWithQuality->new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
49 ( -seq => $seqobj,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
50 -qual => $qualobj
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
51 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
52 # done!
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
53
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
54 $swqobj->id(); # the id of the SeqWithQuality object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
55 # may not match the the id of the sequence or
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
56 # of the quality (check the pod, luke)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
57 $swqobj->seq(); # the sequence of the SeqWithQuality object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
58 $swqobj->qual(); # the quality of the SeqWithQuality object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
59
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
60 # to get out parts of the sequence.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
61
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
62 print "Sequence ", $seqobj->id(), " with accession ",
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
63 $seqobj->accession, " and desc ", $seqobj->desc, "\n";
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
64
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
65 $string2 = $seqobj->subseq(1,40);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
66
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
67 =head1 DESCRIPTION
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
68
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
69 This object stores base quality values together with the sequence string.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
70
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
71 =head1 FEEDBACK
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
72
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
73 =head2 Mailing Lists
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
74
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
75 User feedback is an integral part of the evolution of this and other
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
76 Bioperl modules. Send your comments and suggestions preferably to one
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
77 of the Bioperl mailing lists. Your participation is much appreciated.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
78
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
79 bioperl-l@bioperl.org - General discussion
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
80 http://bio.perl.org/MailList.html - About the mailing lists
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
81
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
82 =head2 Reporting Bugs
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
83
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
84 Report bugs to the Bioperl bug tracking system to help us keep track
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
85 the bugs and their resolution. Bug reports can be submitted via email
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
86 or the web:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
87
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
88 bioperl-bugs@bio.perl.org
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
89 http://bugzilla.bioperl.org/
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
90
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
91 =head1 AUTHOR - Chad Matsalla
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
92
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
93 Email bioinformatics@dieselwurks.com
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
94
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
95 =head1 CONTRIBUTORS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
96
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
97 Jason Stajich, jason@bioperl.org
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
98
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
99 =head1 APPENDIX
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
100
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
101 The rest of the documentation details each of the object methods.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
102 Internal methods are usually preceded with a _
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
103
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
104 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
105
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
106
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
107 package Bio::Seq::SeqWithQuality;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
108
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
109 use vars qw(@ISA);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
110
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
111 use strict;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
112 use Bio::Root::Root;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
113 use Bio::Seq::QualI;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
114 use Bio::PrimarySeqI;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
115 use Bio::PrimarySeq;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
116 use Bio::Seq::PrimaryQual;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
117
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
118 @ISA = qw(Bio::Root::Root Bio::PrimarySeqI Bio::Seq::QualI);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
119
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
120 =head2 new()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
121
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
122 Title : new()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
123 Usage : $qual = Bio::Seq::SeqWithQuality ->new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
124 ( -qual => '10 20 30 40 50 50 20 10',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
125 -seq => 'ATCGATCG',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
126 -id => 'human_id',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
127 -accession_number => 'AL000012',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
128 -trace_indices => '0 5 10 15 20 25 30 35'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
129 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
130 Function: Returns a new Bio::Seq::SeqWithQual object from basic
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
131 constructors.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
132 Returns : a new Bio::Seq::PrimaryQual object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
133 Notes : Arguments:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
134 -qual can be a quality string (see Bio::Seq::PrimaryQual for more
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
135 information on this) or a reference to a Bio::Seq::PrimaryQual
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
136 object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
137 -seq can be a sequence string (see Bio::PrimarySeq for more
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
138 information on this) or a reference to a Bio::PrimaryQual object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
139 -seq, -id, -accession_number, -primary_id, -desc, -id behave like
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
140 this:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
141 1. if they are provided on construction of the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
142 Bio::Seq::SeqWithQuality they will be set as the descriptors for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
143 the object unless changed by one of the following mechanisms:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
144 a) $obj->set_common_descriptors() is used and both the -seq and
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
145 the -qual object have the same descriptors. These common
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
146 descriptors will then become the descriptors for the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
147 Bio::Seq::SeqWithQual object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
148 b) the descriptors are manually set using the seq(), id(),
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
149 desc(), or accession_number(), primary_id(),
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
150 2. if no descriptors are provided, the new() constructor will see
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
151 if the descriptor used in the PrimarySeq and in the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
152 PrimaryQual objects match. If they do, they will become
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
153 the descriptors for the SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
154
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
155 To eliminate ambiguity, I strongly suggest you set the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
156 descriptors manually on construction of the object. Really.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
157 -trace_indices : a space_delimited list of trace indices
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
158 (where would the peaks be drawn if this list of qualities
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
159 was to be plotted?)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
160
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
161 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
162
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
163 sub new {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
164 my ($class, @args) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
165 my $self = $class->SUPER::new(@args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
166 # default: turn OFF the warnings
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
167 $self->{supress_warnings} = 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
168 my($qual,$seq,$id,$acc,$pid,$desc,$given_id,$alphabet,$trace_indices) =
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
169 $self->_rearrange([qw(
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
170 QUAL
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
171 SEQ
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
172 DISPLAY_ID
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
173 ACCESSION_NUMBER
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
174 PRIMARY_ID
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
175 DESC
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
176 ID
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
177 ALPHABET
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
178 TRACE_INDICES
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
179 )],
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
180 @args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
181 # first, deal with the sequence and quality information
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
182 if ( defined $id && defined $given_id ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
183 if( $id ne $given_id ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
184 $self->throw("Provided both id and display_id constructor functions. [$id] [$given_id]");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
185 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
186 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
187 if( defined $given_id ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
188 $self->display_id($given_id);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
189 $id = $given_id;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
190 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
191 if (!$seq) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
192 my $id;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
193 unless ($self->{supress_warnings} == 1) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
194 $self->warn("You did not provide sequence information during the construction of a Bio::Seq::SeqWithQuality object. Sequence components for this object will be empty.");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
195 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
196 if (!$alphabet) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
197 $self->throw("If you want me to create a PrimarySeq object for your empty sequence <boggle> you must specify a -alphabet to satisfy the constructor requirements for a Bio::PrimarySeq object with no sequence. Read the POD for it, luke.");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
198 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
199 $self->{seq_ref} = Bio::PrimarySeq->new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
200 (
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
201 -seq => "",
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
202 -accession_number => $acc,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
203 -primary_id => $pid,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
204 -desc => $desc,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
205 -display_id => $id,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
206 -alphabet => $alphabet
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
207 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
208 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
209 elsif (ref($seq) eq "Bio::PrimarySeq" ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
210 $self->{seq_ref} = $seq;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
211 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
212
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
213 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
214 my $seqobj = Bio::PrimarySeq->new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
215 (
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
216 -seq => $seq,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
217 -accession_number => $acc,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
218 -primary_id => $pid,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
219 -desc => $desc,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
220 -display_id => $id,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
221 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
222 $self->{seq_ref} = $seqobj;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
223 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
224
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
225 if (!$qual) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
226 $self->{qual_ref} = Bio::Seq::PrimaryQual->new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
227 (
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
228 -qual => "",
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
229 -accession_number => $acc,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
230 -primary_id => $pid,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
231 -desc => $desc,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
232 -display_id => $id,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
233 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
234 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
235 elsif (ref($qual) eq "Bio::Seq::PrimaryQual") {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
236 $self->{qual_ref} = $qual;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
237 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
238 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
239 my $qualobj = Bio::Seq::PrimaryQual->new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
240 (
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
241 -qual => $qual,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
242 -accession_number => $acc,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
243 -primary_id => $pid,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
244 -desc => $desc,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
245 -display_id => $id,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
246 -trace_indices => $trace_indices
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
247 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
248 $self->{qual_ref} = $qualobj;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
249 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
250
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
251 # now try to set the descriptors for this object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
252 $self->_set_descriptors($qual,$seq,$id,$acc,$pid,$desc,$given_id,$alphabet);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
253 $self->length();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
254
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
255 return $self;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
256 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
257
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
258 =head2 _common_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
259
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
260 Title : _common_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
261 Usage : $common_id = $self->_common_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
262 Function: Compare the display_id of {qual_ref} and {seq_ref}.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
263 Returns : Nothing if they don't match. If they do return
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
264 {seq_ref}->display_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
265 Args : None.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
266
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
267 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
268
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
269 #'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
270 sub _common_id {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
271 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
272 return if (!$self->{seq_ref} || !$self->{qual_ref});
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
273 my $sid = $self->{seq_ref}->display_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
274 return if (!$sid);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
275 return if (!$self->{qual_ref}->display_id());
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
276 return $sid if ($sid eq $self->{qual_ref}->display_id());
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
277 # should this become a warning?
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
278 # print("ids $sid and $self->{qual_ref}->display_id() do not match. Bummer.\n");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
279 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
280
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
281 =head2 _common_display_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
282
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
283 Title : _common_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
284 Usage : $common_id = $self->_common_display_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
285 Function: Compare the display_id of {qual_ref} and {seq_ref}.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
286 Returns : Nothing if they don't match. If they do return
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
287 {seq_ref}->display_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
288 Args : None.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
289
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
290 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
291
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
292 #'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
293 sub _common_display_id {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
294 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
295 $self->common_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
296 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
297
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
298 =head2 _common_accession_number()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
299
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
300 Title : _common_accession_number()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
301 Usage : $common_id = $self->_common_accession_number();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
302 Function: Compare the accession_number() of {qual_ref} and {seq_ref}.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
303 Returns : Nothing if they don't match. If they do return
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
304 {seq_ref}->accession_number()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
305 Args : None.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
306
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
307 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
308
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
309 #'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
310 sub _common_accession_number {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
311 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
312 return if ($self->{seq_ref} || $self->{qual_ref});
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
313 my $acc = $self->{seq_ref}->accession_number();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
314 # if (!$acc) { print("the seqref has no acc.\n"); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
315 return if (!$acc);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
316 # if ($acc eq $self->{qual_ref}->accession_number()) { print("$acc matches ".$self->{qual_ref}->accession_number()."\n"); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
317 return $acc if ($acc eq $self->{qual_ref}->accession_number());
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
318 # should this become a warning?
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
319 # print("accession numbers $acc and $self->{qual_ref}->accession_number() do not match. Bummer.\n");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
320 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
321
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
322 =head2 _common_primary_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
323
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
324 Title : _common_primary_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
325 Usage : $common_primard_id = $self->_common_primary_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
326 Function: Compare the primary_id of {qual_ref} and {seq_ref}.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
327 Returns : Nothing if they don't match. If they do return
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
328 {seq_ref}->primary_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
329 Args : None.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
330
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
331 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
332
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
333 #'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
334 sub _common_primary_id {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
335 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
336 return if ($self->{seq_ref} || $self->{qual_ref});
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
337 my $pid = $self->{seq_ref}->primary_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
338 return if (!$pid);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
339 return $pid if ($pid eq $self->{qual_ref}->primary_id());
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
340 # should this become a warning?
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
341 # print("primary_ids $pid and $self->{qual_ref}->primary_id() do not match. Bummer.\n");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
342
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
343 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
344
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
345 =head2 _common_desc()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
346
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
347 Title : _common_desc()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
348 Usage : $common_desc = $self->_common_desc();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
349 Function: Compare the desc of {qual_ref} and {seq_ref}.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
350 Returns : Nothing if they don't match. If they do return
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
351 {seq_ref}->desc()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
352 Args : None.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
353
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
354 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
355
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
356 #'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
357 sub _common_desc {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
358 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
359 return if ($self->{seq_ref} || $self->{qual_ref});
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
360 my $des = $self->{seq_ref}->desc();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
361 return if (!$des);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
362 return $des if ($des eq $self->{qual_ref}->desc());
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
363 # should this become a warning?
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
364 # print("descriptions $des and $self->{qual_ref}->desc() do not match. Bummer.\n");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
365
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
366 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
367
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
368 =head2 set_common_descriptors()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
369
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
370 Title : set_common_descriptors()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
371 Usage : $self->set_common_descriptors();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
372 Function: Compare the descriptors (id,accession_number,display_id,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
373 primary_id, desc) for the PrimarySeq and PrimaryQual objects
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
374 within the SeqWithQuality object. If they match, make that
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
375 descriptor the descriptor for the SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
376 Returns : Nothing.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
377 Args : None.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
378
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
379 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
380
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
381 sub set_common_descriptors {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
382 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
383 return if ($self->{seq_ref} || $self->{qual_ref});
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
384 &_common_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
385 &_common_display_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
386 &_common_accession_number();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
387 &_common_primary_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
388 &_common_desc();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
389 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
390
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
391 =head2 alphabet()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
392
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
393 Title : alphabet();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
394 Usage : $molecule_type = $obj->alphabet();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
395 Function: Get the molecule type from the PrimarySeq object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
396 Returns : What what PrimarySeq says the type of the sequence is.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
397 Args : None.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
398
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
399 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
400
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
401 sub alphabet {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
402 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
403 return $self->{seq_ref}->alphabet();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
404 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
405
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
406 =head2 display_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
407
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
408 Title : display_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
409 Usage : $id_string = $obj->display_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
410 Function: Returns the display id, aka the common name of the Quality
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
411 object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
412 The semantics of this is that it is the most likely string to be
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
413 used as an identifier of the quality sequence, and likely to have
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
414 "human" readability. The id is equivalent to the ID field of the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
415 GenBank/EMBL databanks and the id field of the Swissprot/sptrembl
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
416 database. In fasta format, the >(\S+) is presumed to be the id,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
417 though some people overload the id to embed other information.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
418 Bioperl does not use any embedded information in the ID field,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
419 and people are encouraged to use other mechanisms (accession
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
420 field for example, or extending the sequence object) to solve
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
421 this. Notice that $seq->id() maps to this function, mainly for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
422 legacy/convience issues.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
423 This method sets the display_id for the SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
424 Returns : A string
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
425 Args : If a scalar is provided, it is set as the new display_id for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
426 the SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
427 Status : Virtual
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
428
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
429 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
430
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
431 sub display_id {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
432 my ($obj,$value) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
433 if( defined $value) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
434 $obj->{'display_id'} = $value;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
435 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
436 return $obj->{'display_id'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
437
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
438 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
439
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
440 =head2 accession_number()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
441
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
442 Title : accession_number()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
443 Usage : $unique_biological_key = $obj->accession_number();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
444 Function: Returns the unique biological id for a sequence, commonly
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
445 called the accession_number. For sequences from established
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
446 databases, the implementors should try to use the correct
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
447 accession number. Notice that primary_id() provides the unique id
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
448 for the implemetation, allowing multiple objects to have the same
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
449 accession number in a particular implementation. For sequences
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
450 with no accession number, this method should return "unknown".
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
451 This method sets the accession_number for the SeqWithQuality
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
452 object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
453 Returns : A string (the value of accession_number)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
454 Args : If a scalar is provided, it is set as the new accession_number
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
455 for the SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
456 Status : Virtual
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
457
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
458
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
459 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
460
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
461 sub accession_number {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
462 my( $obj, $acc ) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
463
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
464 if (defined $acc) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
465 $obj->{'accession_number'} = $acc;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
466 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
467 $acc = $obj->{'accession_number'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
468 $acc = 'unknown' unless defined $acc;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
469 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
470 return $acc;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
471 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
472
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
473 =head2 primary_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
474
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
475 Title : primary_id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
476 Usage : $unique_implementation_key = $obj->primary_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
477 Function: Returns the unique id for this object in this implementation.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
478 This allows implementations to manage their own object ids in a
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
479 way the implementaiton can control clients can expect one id to
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
480 map to one object. For sequences with no accession number, this
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
481 method should return a stringified memory location.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
482 This method sets the primary_id for the SeqWithQuality
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
483 object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
484 Returns : A string. (the value of primary_id)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
485 Args : If a scalar is provided, it is set as the new primary_id for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
486 the SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
487
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
488 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
489
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
490 sub primary_id {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
491 my ($obj,$value) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
492 if ($value) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
493 $obj->{'primary_id'} = $value;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
494 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
495 return $obj->{'primary_id'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
496
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
497 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
498
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
499 =head2 desc()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
500
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
501 Title : desc()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
502 Usage : $qual->desc($newval); _or_
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
503 $description = $qual->desc();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
504 Function: Get/set description text for this SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
505 Returns : A string. (the value of desc)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
506 Args : If a scalar is provided, it is set as the new desc for the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
507 SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
508
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
509 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
510
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
511 sub desc {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
512 # a mechanism to set the disc for the SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
513 # probably will be used most often by set_common_features()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
514 my ($obj,$value) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
515 if( defined $value) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
516 $obj->{'desc'} = $value;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
517 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
518 return $obj->{'desc'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
519 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
520
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
521 =head2 id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
522
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
523 Title : id()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
524 Usage : $id = $qual->id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
525 Function: Return the ID of the quality. This should normally be (and
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
526 actually is in the implementation provided here) just a synonym
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
527 for display_id().
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
528 Returns : A string. (the value of id)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
529 Args : If a scalar is provided, it is set as the new id for the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
530 SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
531
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
532 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
533
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
534 sub id {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
535 my ($self,$value) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
536 if (!$self) { $self->throw("no value for self in $value"); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
537 if( defined $value ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
538 return $self->display_id($value);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
539 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
540 return $self->display_id();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
541 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
542
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
543 =head2 seq
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
544
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
545 Title : seq()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
546 Usage : $string = $obj->seq(); _or_
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
547 $obj->seq("atctatcatca");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
548 Function: Returns the sequence that is contained in the imbedded in the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
549 PrimarySeq object within the SeqWithQuality object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
550 Returns : A scalar (the seq() value for the imbedded PrimarySeq object.)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
551 Args : If a scalar is provided, the SeqWithQuality object will
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
552 attempt to set that as the sequence for the imbedded PrimarySeq
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
553 object. Otherwise, the value of seq() for the PrimarySeq object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
554 is returned.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
555 Notes : This is probably not a good idea because you then should call
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
556 length() to make sure that the sequence and quality are of the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
557 same length. Even then, how can you make sure that this sequence
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
558 belongs with that quality? I provided this to give you rope to
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
559 hang yourself with. Tie it to a strong device and use a good
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
560 knot.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
561
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
562 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
563
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
564 sub seq {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
565 my ($self,$value) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
566 if( defined $value) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
567 $self->{seq_ref}->seq($value);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
568 $self->length();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
569 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
570 return $self->{seq_ref}->seq();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
571 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
572
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
573 =head2 qual()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
574
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
575 Title : qual()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
576 Usage : @quality_values = @{$obj->qual()}; _or_
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
577 $obj->qual("10 10 20 40 50");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
578 Function: Returns the quality as imbedded in the PrimaryQual object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
579 within the SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
580 Returns : A reference to an array containing the quality values in the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
581 PrimaryQual object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
582 Args : If a scalar is provided, the SeqWithQuality object will
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
583 attempt to set that as the quality for the imbedded PrimaryQual
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
584 object. Otherwise, the value of qual() for the PrimaryQual
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
585 object is returned.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
586 Notes : This is probably not a good idea because you then should call
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
587 length() to make sure that the sequence and quality are of the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
588 same length. Even then, how can you make sure that this sequence
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
589 belongs with that quality? I provided this to give you a strong
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
590 board with which to flagellate yourself.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
591
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
592 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
593
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
594 sub qual {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
595 my ($self,$value) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
596
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
597 if( defined $value) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
598 $self->{qual_ref}->qual($value);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
599 # update the lengths
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
600 $self->length();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
601 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
602 return $self->{qual_ref}->qual();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
603 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
604
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
605
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
606
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
607 =head2 trace_indices()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
608
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
609 Title : trace_indices()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
610 Usage : @trace_indice_values = @{$obj->trace_indices()}; _or_
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
611 $obj->trace_indices("10 10 20 40 50");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
612 Function: Returns the trace_indices as imbedded in the Primaryqual object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
613 within the SeqWithQualiity object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
614 Returns : A reference to an array containing the trace_indice values in the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
615 PrimaryQual object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
616 Args : If a scalar is provided, the SeqWithuQuality object will
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
617 attempt to set that as the trace_indices for the imbedded PrimaryQual
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
618 object. Otherwise, the value of trace_indices() for the PrimaryQual
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
619 object is returned.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
620 Notes : This is probably not a good idea because you then should call
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
621 length() to make sure that the sequence and trace_indices are of the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
622 same length. Even then, how can you make sure that this sequence
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
623 belongs with that trace_indicex? I provided this to give you a strong
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
624 board with which to flagellate yourself.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
625
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
626 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
627
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
628 sub trace_indices {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
629 my ($self,$value) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
630
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
631 if( defined $value) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
632 $self->{qual_ref}->trace_indices($value);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
633 # update the lengths
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
634 $self->length();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
635 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
636 return $self->{qual_ref}->trace_indices();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
637 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
638
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 =head2 length()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
643
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
644 Title : length()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
645 Usage : $length = $seqWqual->length();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
646 Function: Get the length of the SeqWithQuality sequence/quality.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
647 Returns : Returns the length of the sequence and quality if they are
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
648 both the same. Returns "DIFFERENT" if they differ.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
649 Args : None.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
650
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
651 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
652
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
653 sub length {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
654 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
655 if (!$self->{seq_ref}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
656 unless ($self->{supress_warnings} == 1) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
657 $self->warn("Can't find {seq_ref} here in length().");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
658 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
659 return;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
660 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
661 if (!$self->{qual_ref}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
662 unless ($self->{supress_warnings} == 1) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
663 $self->warn("Can't find {qual_ref} here in length().");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
664 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
665 return;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
666 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
667 my $seql = $self->{seq_ref}->length();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
668
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
669 if ($seql != $self->{qual_ref}->length()) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
670 unless ($self->{supress_warnings} == 1) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
671 $self->warn("Sequence length (".$seql.") is different from quality length (".$self->{qual_ref}->length().") in the SeqWithQuality object. This can only lead to problems later.");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
672 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
673 $self->{'length'} = "DIFFERENT";
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
674 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
675 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
676 $self->{'length'} = $seql;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
677 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
678 return $self->{'length'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
679 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
680
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
681
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
682 =head2 qual_obj
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
683
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
684 Title : qual_obj($different_obj)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
685 Usage : $qualobj = $seqWqual->qual_obj(); _or_
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
686 $qualobj = $seqWqual->qual_obj($ref_to_primaryqual_obj);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
687 Function: Get the PrimaryQual object that is imbedded in the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
688 SeqWithQuality object or if a reference to a PrimaryQual object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
689 is provided, set this as the PrimaryQual object imbedded in the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
690 SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
691 Returns : A reference to a Bio::Seq::SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
692
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
693 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
694
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
695 sub qual_obj {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
696 my ($self,$value) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
697 if (defined($value)) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
698 if (ref($value) eq "Bio::Seq::PrimaryQual") {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
699 $self->{qual_ref} = $value;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
700
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
701 $self->debug("You successfully changed the PrimaryQual object within a SeqWithQuality object. ID's for the SeqWithQuality object may now not be what you expect. Use something like set_common_descriptors() to fix them if you care,");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
702 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
703 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
704 $self->debug("You tried to change the PrimaryQual object within a SeqWithQuality object but you passed a reference to an object that was not a Bio::Seq::PrimaryQual object. Thus your change failed. Sorry.\n");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
705 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
706 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
707 return $self->{qual_ref};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
708 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
709
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
710
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
711 =head2 seq_obj
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
712
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
713 Title : seq_obj()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
714 Usage : $seqobj = $seqWqual->qual_obj(); _or_
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
715 $seqobj = $seqWqual->seq_obj($ref_to_primary_seq_obj);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
716 Function: Get the PrimarySeq object that is imbedded in the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
717 SeqWithQuality object or if a reference to a PrimarySeq object is
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
718 provided, set this as the PrimarySeq object imbedded in the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
719 SeqWithQuality object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
720 Returns : A reference to a Bio::PrimarySeq object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
721
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
722 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
723
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
724 sub seq_obj {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
725 my ($self,$value) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
726 if( defined $value) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
727 if (ref($value) eq "Bio::PrimarySeq") {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
728 $self->debug("You successfully changed the PrimarySeq object within a SeqWithQuality object. ID's for the SeqWithQuality object may now not be what you expect. Use something like set_common_descriptors() to fix them if you care,");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
729 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
730 $self->debug("You tried to change the PrimarySeq object within a SeqWithQuality object but you passed a reference to an object that was not a Bio::PrimarySeq object. Thus your change failed. Sorry.\n");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
731 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
732 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
733 return $self->{seq_ref};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
734 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
735
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
736 =head2 _set_descriptors
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
737
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
738 Title : _set_descriptors()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
739 Usage : $seqWqual->_qual_obj($qual,$seq,$id,$acc,$pid,$desc,$given_id,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
740 $alphabet);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
741 Function: Set the descriptors for the SeqWithQuality object. Try to
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
742 match the descriptors in the PrimarySeq object and in the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
743 PrimaryQual object if descriptors were not provided with
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
744 construction.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
745 Returns : Nothing.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
746 Args : $qual,$seq,$id,$acc,$pid,$desc,$given_id,$alphabet as found
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
747 in the new() method.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
748 Notes : Really only intended to be called by the new() method. If
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
749 you want to invoke a similar function try
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
750 set_common_descriptors().
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
751
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
752 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
753
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
754
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
755 sub _set_descriptors {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
756 my ($self,$qual,$seq,$id,$acc,$pid,$desc,$given_id,$alphabet) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
757 my ($c_id,$c_acc,$c_pid,$c_desc);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
758 if (!$self->display_id()) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
759 if ($c_id = $self->_common_id() ) { $self->display_id($c_id); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
760 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
761 if ($self->{seq_ref}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
762 # print("Using seq_ref to set id to ".$self->{seq_ref}->display_id()."\n");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
763 # ::dumpValue($self->{seq_ref});
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
764 $self->display_id($self->{seq_ref}->id());
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
765 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
766 elsif ($self->{qual_ref}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
767 $self->display_id($self->{qual_ref}->id());
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
768 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
769 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
770 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
771 if ($acc) { $self->accession_number($acc); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
772 elsif ($c_acc = $self->_common_accession_number() ) { $self->accession_number($c_acc); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
773 if ($pid) { $self->primary_id($pid); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
774 elsif ($c_pid = $self->_common_primary_id() ) { $self->primary_id($c_pid); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
775 if ($desc) { $self->desc($desc); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
776 elsif ($c_desc = $self->_common_desc() ) { $self->desc($c_desc); }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
777 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
778
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
779 =head2 subseq($start,$end)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
780
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
781 Title : subseq($start,$end)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
782 Usage : $subsequence = $obj->subseq($start,$end);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
783 Function: Returns the subseq from start to end, where the first base
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
784 is 1 and the number is inclusive, ie 1-2 are the first two
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
785 bases of the sequence.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
786 Returns : A string.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
787 Args : Two positions.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
788
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
789 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
790
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
791 sub subseq {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
792 my ($self,@args) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
793 # does a single value work?
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
794 return $self->{seq_ref}->subseq(@args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
795 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
796
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
797 =head2 baseat($position)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
798
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
799 Title : baseat($position)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
800 Usage : $base_at_position_6 = $obj->baseat("6");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
801 Function: Returns a single base at the given position, where the first
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
802 base is 1 and the number is inclusive, ie 1-2 are the first two
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
803 bases of the sequence.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
804 Returns : A scalar.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
805 Args : A position.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
806
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
807 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
808
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
809 sub baseat {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
810 my ($self,$val) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
811 return $self->{seq_ref}->subseq($val,$val);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
812 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
813
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
814 =head2 subqual($start,$end)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
815
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
816 Title : subqual($start,$end)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
817 Usage : @qualities = @{$obj->subqual(10,20);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
818 Function: returns the quality values from $start to $end, where the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
819 first value is 1 and the number is inclusive, ie 1-2 are the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
820 first two bases of the sequence. Start cannot be larger than
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
821 end but can be equal.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
822 Returns : A reference to an array.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
823 Args : a start position and an end position
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
824
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
825 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
826
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
827 sub subqual {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
828 my ($self,@args) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
829 return $self->{qual_ref}->subqual(@args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
830 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
831
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
832 =head2 qualat($position)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
833
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
834 Title : qualat($position)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
835 Usage : $quality = $obj->qualat(10);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
836 Function: Return the quality value at the given location, where the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
837 first value is 1 and the number is inclusive, ie 1-2 are the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
838 first two bases of the sequence. Start cannot be larger than
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
839 end but can be equal.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
840 Returns : A scalar.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
841 Args : A position.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
842
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
843 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
844
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
845 sub qualat {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
846 my ($self,$val) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
847 return $self->{qual_ref}->qualat($val);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
848 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
849
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
850 =head2 sub_trace_index($start,$end)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
851
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
852 Title : sub_trace_index($start,$end)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
853 Usage : @trace_indices = @{$obj->sub_trace_index(10,20);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
854 Function: returns the trace index values from $start to $end, where the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
855 first value is 1 and the number is inclusive, ie 1-2 are the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
856 first two bases of the sequence. Start cannot be larger than
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
857 end but can be e_trace_index.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
858 Returns : A reference to an array.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
859 Args : a start position and an end position
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
860
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
861 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
862
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
863 sub sub_trace_index {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
864 my ($self,@args) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
865 return $self->{qual_ref}->sub_trace_index(@args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
866 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
867
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
868 =head2 trace_index_at($position)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
869
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
870 Title : trace_index_at($position)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
871 Usage : $trace_index = $obj->trace_index_at(10);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
872 Function: Return the trace_index value at the given location, where the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
873 first value is 1 and the number is inclusive, ie 1-2 are the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
874 first two bases of the sequence. Start cannot be larger than
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
875 end but can be etrace_index_.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
876 Returns : A scalar.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
877 Args : A position.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
878
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
879 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
880
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
881 sub trace_index_at {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
882 my ($self,$val) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
883 return $self->{qual_ref}->trace_index_at($val);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
884 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
885
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
886 =head2 to_string()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
887
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
888 Title : to_string()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
889 Usage : $quality = $obj->to_string();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
890 Function: Return a textual representation of what the object contains.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
891 For this module, this function will return:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
892 qual
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
893 seq
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
894 display_id
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
895 accession_number
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
896 primary_id
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
897 desc
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
898 id
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
899 length_sequence
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
900 length_quality
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
901 Returns : A scalar.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
902 Args : None.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
903
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
904 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
905
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
906 sub to_string {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
907 my ($self,$out,$result) = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
908 $out = "qual: ".join(',',@{$self->qual()})."\n";
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
909 foreach (qw(seq display_id accession_number primary_id desc id)) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
910 $result = $self->$_();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
911 if (!$result) { $result = "<unset>"; }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
912 $out .= "$_: $result\n";
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
913 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
914 return $out;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
915 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
916 1;