NAME Algorithm::BestChoice - Choose the best VERSION Version 0.01 SYNOPSIS # Find my favorite food based on color my $chooser = Algorithm::BestChoice->new; $chooser->add( match => red, value => cherry, rank => 1 ) $chooser->add( match => red, value => apple, rank => 10 ) # Like apples $chooser->add( match => red, value => strawberry, rank => -5 ) # Don't like strawberries $chooser->add( match => purple, value => grape, rank => 20 ) # Delicious $chooser->add( match => yellow, value => banana ) $chooser->add( match => yellow, value => lemon rank => -5 ) # Too sour my $favorite; $favorite = $chooser->best( red ) # apple is the favorite red $favorite = $chooser->best( [ red, yellow, purple ] ) # grape is the favorite among red, yellow, and purple DESCRIPTION An Algorithm::BestChoice object is similar to a hash, except it returns a result based on a given key AND relative ranking. That is, you can associate multiple values with a single key, and differentiate them by using a rank (or weight). METHODS Algorithm::BestChoice->new Create and return a new Algorithm::BestChoice object $chooser->add( ... ) Add a possible choice to the chooser The arguments are: match The key for the choice, can be a string or a regular expression value The value to associate with the key (what is returned by ->best) rank An optional numeric weight, the default is 0 (>0 is better, <0 is worse) $value = $chooser->best( <criterion> ) Given criterion, ->best will return the value that 1. has a matching matcher and 2. has the highest rank AUTHOR Robert Krimen, "<rkrimen at cpan.org>" BUGS Please report any bugs or feature requests to "bug-algorithm-bestchoice at rt.cpan.org", or through the web interface at <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Algorithm-BestChoice>. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. SUPPORT You can find documentation for this module with the perldoc command. perldoc Algorithm::BestChoice You can also look for information at: * RT: CPAN's request tracker <http://rt.cpan.org/NoAuth/Bugs.html?Dist=Algorithm-BestChoice> * AnnoCPAN: Annotated CPAN documentation <http://annocpan.org/dist/Algorithm-BestChoice> * CPAN Ratings <http://cpanratings.perl.org/d/Algorithm-BestChoice> * Search CPAN <http://search.cpan.org/dist/Algorithm-BestChoice/> ACKNOWLEDGEMENTS COPYRIGHT & LICENSE Copyright 2009 Robert Krimen, all rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.