Mercurial > repos > cpt > cpt_psm_prep
diff lib/CPT/Bio/RBS/Algo/Naive.pm @ 1:d724f34e671d draft default tip
planemo upload commit 94b0cd1fff0826c6db3e7dc0c91c0c5a8be8bb0c
author | cpt |
---|---|
date | Mon, 05 Jun 2023 02:50:07 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/lib/CPT/Bio/RBS/Algo/Naive.pm Mon Jun 05 02:50:07 2023 +0000 @@ -0,0 +1,103 @@ +package CPT::Bio::RBS::Algo::Naive; +use Moose; +with 'CPT::Bio::RBS::Algo'; +use CPT::Bio::RBS_Object; + +my @SDs = ( + 'aggaggt', + 'ggaggt', + 'aggagg', + 'aggag', + 'gaggt', + 'ggagg', + 'aggt', + 'gggt', + 'gagg', + 'gggg', + 'agga', + 'ggag', + 'gga', + 'gag', + 'agg', + 'ggt', +); + +sub predict { + my ( $self, %params ) = @_; + my $upstream = $params{sequence}; + my $only_best = $params{return_best}; + + my $length = length($upstream); + + my @results = (); + foreach my $rbs ( @SDs ){ + while ($upstream =~ /$rbs/g) { + # Position of regex match + my $loc = $-[0]; + # Seq before RBS + my $before = substr($upstream,0, $loc); + # Seq after RBS + my $after = substr($upstream, $loc + length($rbs)); + my $rbs_o = CPT::Bio::RBS_Object->new( + upstream => sprintf('%s %s %s', $before , uc($rbs) , $after), + score => $self->score_match($rbs, length($after)), + rbs_seq => uc($rbs), + separation => length($after), + ); + push( @results, $rbs_o ); + } + } + @results = sort { $b->score() <=> $a->score() } @results; + if (@results) { + if($only_best){ + return ($results[0]); + }else{ + return @results; + } + } + else { + return ( + CPT::Bio::RBS_Object->new( + upstream =>$upstream, + score => '-1', + rbs_seq => 'None', + separation => -1, + ) + ); + } +} + +sub score_match { + my ($self, $match, $dist) = @_; + return length($match); +} + +1; + +__END__ + +=pod + +=encoding UTF-8 + +=head1 NAME + +CPT::Bio::RBS::Algo::Naive + +=head1 VERSION + +version 1.99.4 + +=head1 AUTHOR + +Eric Rasche <rasche.eric@yandex.ru> + +=head1 COPYRIGHT AND LICENSE + +This software is Copyright (c) 2014 by Eric Rasche. + +This is free software, licensed under: + + The GNU General Public License, Version 3, June 2007 + +=cut