NAME

Bio::Protease::Role::WithCache - A role that adds optional memoization of ProteaseI methods

VERSION

version 1.112980

SYNOPSIS

package My::Protease;
use Moose;
with qw(Bio::ProteaseI Bio::Protease::Role::WithCache);

sub _cuts { ... }

# Done, all ProteaseI methods now support optional caching
# through the 'has_cache' and 'cache' attributes

1;

ATTRIBUTES

use_cache

Turn caching on, trading memory for speed. Defaults to 0 (no caching). Useful when any method is being called several times with the same argument.

my $p = Bio::Protease->new( specificity => 'trypsin', use_cache => 0 );
my $c = Bio::Protease->new( specificity => 'trypsin', use_cache => 1 );

my $substrate = 'MAAEELRKVIKPR' x 10;

$p->digest( $substrate ) for (1..1000); # time: 5.11s
$c->digest( $substrate ) for (1..1000); # time: 0.12s

cache

The cache object, which has to do the Cache::Ref::Role::API role. Uses Cache::Ref::LRU by default with a cache size of 5000, but you can set this to your liking at construction time:

my $p = Bio::Protease->new(
    use_cache   => 1,
    cache       => Cache::Ref::Random->new( size => 50 ),
    specificity => 'trypsin'
);

AUTHOR

Bruno Vecchi <vecchi.b gmail.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2011 by Bruno Vecchi.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.