Skip to main content

PH Evaluator - an efficient Poker Hand Evaluator based on a Perfect Hash algorithm

Project description

PH Evaluator Python package (phevaluator)

Description

PH Evaluator is designed for evaluating poker hands with more than 5 cards. Instead of traversing all the combinations, it uses a perfect hash algorithm to get the hand strength from a pre-computed hash table, which only costs very few CPU cycles and considerably small memory (~100kb for the 7 card evaluation). With slight modification, the same algorithm can be also applied to evaluating Omaha poker hands.

Installation

The library requires Python 3.

  • with pip
    pip install .
    

Using the library

The main function is the evaluate_cards function.

from phevaluator import evaluate_cards

p1 = evaluate_cards("9c", "4c", "4s", "9d", "4h", "Qc", "6c")
p2 = evaluate_cards("9c", "4c", "4s", "9d", "4h", "2c", "9h")

# Player 2 has a stronger hand
print(f"The rank of the hand in player 1 is {p1}") # 292
print(f"The rank of the hand in player 2 is {p2}") # 236

The function can take both numbers and card strings (with format like: 'Ah' or '2C'). Usage examples can be seen in examples.py.

Test

There are 1000 random examples tested for each type of hand (5 cards, 6 cards, and 7 cards). The examples are stored in json files the tests folder and were generated with the original C++ evaluator.

  • with current environment
    python3 -m unittest discover -v
    

Development

  • recommended to format with black before commit

    check where to correct (without formatting)

    black . --diff --color
    

    format all

    black .
    

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

phevaluator-0.5.0.tar.gz (105.1 kB view hashes)

Uploaded Source

Built Distributions

phevaluator-0.5.1-py3-none-any.whl (107.6 kB view hashes)

Uploaded Python 3

phevaluator-0.5.0.0-py3-none-any.whl (107.6 kB view hashes)

Uploaded Python 3

phevaluator-0.5.0-py3-none-any.whl (105.0 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page