NAME
Poker::Eval - Deal, score, and calculate expected win rates of poker hands. Base class for specific game types.
VERSION
Version 0.02
SYNOPSIS
This is just a base class. Poker::Eval::Omaha shows a real example.
use Poker::Eval::Omaha; # Omaha style rules
use Poker::Score::High; # Highball scoring system
use feature qw(say);
# Object to represent a typical post flop situation
my $ev = Poker::Eval::Omaha->new(
scorer => Poker::Score::High->new,
hole_remaining => 0, # hole cards already dealt
community_remaining => 2, # turn and river yet to come
);
# shuffle deck
$ev->dealer->shuffle_deck;
# deal three community cards (post flop)
$ev->community_cards( $ev->deal_named(['5c','9h','Ks']));
# deal and score three separate hands
my $hand1 = $ev->best_hand($ev->deal_named(['Ts','Js','3d','4d']));
my $hand2 = $ev->best_hand($ev->deal_named(['5h','5s','6s','7s']));
my $hand3 = $ev->best_hand($ev->deal(4)); # random cards
# best combination (hole + community) in human-readable form
say $hand1->best_combo_flat;
# english name of best combination (e.g. 'Two Pair')
say $hand1->name;
# numerical score of best combination
say $hand1->score;
# hole cards in human-readable form
say $hand1->cards_flat;
# calculate expected win rate of each hand
$ev->calc_ev([$hand1, $hand2, $hand3]);
# expected win rate of each hand (as percent)
say $hand1->ev; say $hand2->ev; say $hand3->ev;
# hands 1, 2 and 3 win 13, 76, and 11 percent of the time respectively.
INTRODUCTION
Poker::Eval defines rules for evaluating poker hands. In Holdem for example, any combination of hole and community cards can be used to make the best hand, so Poker::Eval::Community is the correct subclass. But in Omaha, your best hand is made using EXACTLY two hole cards and EXACTLY three community cards, so Poker::Eval::Omaha is what you want. Other subclasses include Badugi, Chinese, and Wild.
Poker::Eval also provides methods for calculating expected win rates in specific situations. Poker::Score defines the scoring systme itself (e.g., highball, lowball 8 or better, lowball 2-7, lowball A-5, badugi, etc) See Poker::Score for a complete list.
SEE ALSO
Poker::Eval::Community, Poker::Eval::Omaha, Poker::Eval::Wild, Poker::Eval::Badugi, Poker::Eval::Chinese, Poker::Eval::Bitch, Poker::Eval::Badugi27, Poker::Score, Poker::Dealer
ATTRIBUTES
community_cards
Array ref of Poker::Card objects representing community cards
scorer
Required attribute that identifies the scoring system. Must be a Poker::Score object. See Poker::Score for available options.
dealer
Standard Poker::Dealer created by default (52 card deck with no wildcards). See Poker::Dealer for options.
simulations
Number of simulations to run when calculating expected win rate. A high number gives you a better estimate, but also take longer. 100 is the default.
hole_remaining
Number of hole cards remaining to be dealt in the game.
community_remaining
Number of community cards remaining to be dealt in the game.
METHODS
best_hand
Returns the best Poker::Hand you can make. See Poker::Hand
community_flat
Community cards in human-readable form.
deal
Alias for dealer->deal. See Poker::Dealer
deal_named
Alias for dealer->deal_named. See Poker::Dealer
calc_ev
Takes an array ref of Poker::Hands and calculates the expected win rate for each.
BUGS
Probably. Only developer tested so far.
AUTHOR
Nathaniel Graham, <ngraham at cpan.org>
LICENSE AND COPYRIGHT
Copyright 2016 Nathaniel Graham.
This program is free software; you can redistribute it and/or modify it under the terms of the the Artistic License (2.0). You may obtain a copy of the full license at: