Mercurial > repos > mahtabm > ensembl
comparison variant_effect_predictor/Bio/EnsEMBL/Funcgen/Collection/ResultFeature.pm @ 0:1f6dce3d34e0
Uploaded
author | mahtabm |
---|---|
date | Thu, 11 Apr 2013 02:01:53 -0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:1f6dce3d34e0 |
---|---|
1 # | |
2 # Ensembl module for Bio::EnsEMBL::Funcgen::Collection::ResultFeature | |
3 # | |
4 =head1 LICENSE | |
5 | |
6 Copyright (c) 1999-2011 The European Bioinformatics Institute and | |
7 Genome Research Limited. All rights reserved. | |
8 | |
9 This software is distributed under a modified Apache license. | |
10 For license details, please see | |
11 | |
12 http://www.ensembl.org/info/about/code_licence.html | |
13 | |
14 =head1 CONTACT | |
15 | |
16 Please email comments or questions to the public Ensembl | |
17 developers list at <ensembl-dev@ebi.ac.uk>. | |
18 | |
19 Questions may also be sent to the Ensembl help desk at | |
20 <helpdesk@ensembl.org>. | |
21 | |
22 | |
23 =head1 NAME | |
24 | |
25 Bio::EnsEMBL::Funcgen::Collection::ResultFeature - A module to represent a lightweight ResultFeature collection | |
26 | |
27 =head1 SYNOPSIS | |
28 | |
29 use Bio::EnsEMBL::Funcgen::Collection::ResultFeature; | |
30 | |
31 my $rfeature = Bio::EnsEMBL::Funcgen::Collection::ResultFeature->new_fast({ | |
32 start => $start, | |
33 end => $end, | |
34 scores => [ $score ] | |
35 }); | |
36 | |
37 my @rfeatures = @{$rset->get_displayable_ResultFeatures_by_Slice($slice)}; | |
38 | |
39 foreach my $rfeature (@rfeatures){ | |
40 my $score = $rfeature->score(); | |
41 my $rf_start = $rfeature->start(); | |
42 my $rf_end = $rfeature->end(); | |
43 } | |
44 | |
45 =head1 DESCRIPTION | |
46 | |
47 This is a Collection feature which is designed to store compressed/collected | |
48 feature information for a defined window/bin size over a complete seq_region. | |
49 Or alternatively a single feature at the natural resolution i.e. window_size == 0. | |
50 The complete seq_region collections are cropped to provide a ResultFeature on any | |
51 given Slice. ResultFeatures are primarily stored in the result_feature table, | |
52 but can also be generated on the fly from unprocessed data in the array result | |
53 tables. | |
54 | |
55 | |
56 =head1 SEE ALSO | |
57 | |
58 Bio::EnsEMBL::Funcgen::DBSQL::ResultFeatureAdaptor | |
59 Bio::EnsEMBL::Funcgen::Collector::ResultFeature | |
60 | |
61 =cut | |
62 | |
63 | |
64 #This is distinct from a normal feature as the collection may have differen attributes and methods from the normal feature | |
65 #implementation. For example a Bio::EnsEMBL::Collection::Gene would only have summary information over several genes. | |
66 #Altho', unlikely that we'll ever collect genes. | |
67 | |
68 use strict; | |
69 use warnings; | |
70 | |
71 | |
72 package Bio::EnsEMBL::Funcgen::Collection::ResultFeature; | |
73 use base ('Bio::EnsEMBL::Feature');#@ISA | |
74 | |
75 #This needs to inherit from Bio::EnsEMBL::Collection | |
76 #Which can host some of the below methods | |
77 | |
78 #Reverted to hash implementation as we no longer deal with | |
79 #huge amounts of features due to collections. | |
80 #This enables use of transform/seq_region_start/end methods | |
81 #and enable us to store on slices that do not begin at 1 | |
82 #Altho need to remove code stipulating this | |
83 | |
84 | |
85 | |
86 #To do | |
87 #Can we move any of these methods to a base Collection class? | |
88 #Should probably now use normal new method with validation? | |
89 | |
90 =head2 new_fast | |
91 | |
92 Args : Array with attributes start, end, strand, scores, probe, result_set_id, window_size, slice IN THAT ORDER. | |
93 WARNING: None of these are validated, hence can omit some where not needed | |
94 Example : none | |
95 Description: Fast and list version of new. Only works if the code is very disciplined. | |
96 Returntype : Bio::EnsEMBL::Funcgen::ResultFeature | |
97 Exceptions : None | |
98 Caller : ResultSetAdaptor | |
99 Status : At Risk | |
100 | |
101 =cut | |
102 | |
103 sub new_fast { | |
104 #This is agnostic towards to type of reference | |
105 return bless ($_[1], $_[0]); | |
106 | |
107 } | |
108 | |
109 | |
110 | |
111 =head2 scores | |
112 | |
113 Example : my $score = $rf->score(); | |
114 Description: Getter of the scores attribute for ResultFeature | |
115 objects | |
116 Returntype : Arrayref. | |
117 Exceptions : None | |
118 Caller : General | |
119 Status : At Risk | |
120 | |
121 =cut | |
122 | |
123 sub scores { | |
124 return $_[0]->{scores}; | |
125 } | |
126 | |
127 | |
128 | |
129 =head2 probe | |
130 | |
131 Example : my $probe = $rf->probe(); | |
132 Description: Getter of the probe attribute for ResultFeature | |
133 objects | |
134 Returntype : Bio::EnsEMBL::Funcgen::Probe | |
135 Exceptions : None | |
136 Caller : General | |
137 Status : At Risk - This can only be used for Features with window 0. | |
138 | |
139 =cut | |
140 | |
141 #probe_id is currently not available in the result_feature table, so this would be a result/probe_feature query. | |
142 | |
143 sub probe { | |
144 return $_[0]->{probe}; | |
145 } | |
146 | |
147 | |
148 sub result_set_id { | |
149 return $_[0]->{result_set_id}; | |
150 } | |
151 | |
152 sub window_size { | |
153 return $_[0]->{window_size}; | |
154 } | |
155 | |
156 | |
157 sub get_min_max_scores{ | |
158 | |
159 if(! defined $_[0]->{'min_max_scores'}){ | |
160 my @sorted_scores = sort { $a <=> $b } @{$_[0]->{'scores'}}; | |
161 $_[0]->{'min_max_scores'} = [$sorted_scores[0], $sorted_scores[$#sorted_scores]]; | |
162 } | |
163 | |
164 return $_[0]->{'min_max_scores'}; | |
165 } | |
166 | |
167 | |
168 1; | |
169 |