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:

http://www.perlfoundation.org/artistic_license_2_0