Bio-MUST-Core
view release on metacpan or search on metacpan
lib/Bio/MUST/Core/SeqMask/Rates.pm view on Meta::CPAN
package Bio::MUST::Core::SeqMask::Rates;
# ABSTRACT: Evolutionary rates for sequence sites
$Bio::MUST::Core::SeqMask::Rates::VERSION = '0.252040';
use Moose;
use namespace::autoclean;
use autodie;
use feature qw(say);
# use Smart::Comments;
use Carp;
use Const::Fast;
use List::AllUtils qw(each_arrayref);
use POSIX;
extends 'Bio::MUST::Core::SeqMask';
use Bio::MUST::Core::Types;
use Bio::MUST::Core::Constants qw(:files);
use aliased 'Bio::MUST::Core::SeqMask';
# override superclass' Bool type
# Note: mask indices are as follow: [site]
# mask values are rates
has '+mask' => (
isa => 'ArrayRef[Num]',
);
# TODO: mask non-applicable methods from superclass? (Liskov principle)
sub min_rate {
my $self = shift;
return List::AllUtils::min @{ $self->mask };
}
sub max_rate {
my $self = shift;
return List::AllUtils::max @{ $self->mask };
}
sub delta_rates {
my $self = shift;
my $othr = shift;
# check that both rates objects are the same length
# potential bugs could come from constant sites etc
my $s_width = $self->mask_len;
my $o_width = $othr->mask_len;
carp "[BMC] Warning: Rates widths do not match: $s_width vs. $o_width!"
unless $s_width == $o_width;
my @deltas;
my $ea = each_arrayref [ $self->all_states ], [ $othr->all_states ];
while (my ($s_rate, $o_rate) = $ea->() ) {
push @deltas, 0 + ( sprintf "%.13f", abs( $s_rate - $o_rate ) );
} # Note: trick to get identical results across platforms
( run in 1.174 second using v1.01-cache-2.11-cpan-75ffa21a3d4 )