PokerOddsCalc is a simple poker hand evaluator that can simulate Texas Hold'em or Omaha poker variants. Most pure poker odds calculators written in Python currently either use a hashtable to store Card information as bits to enhance performance or use a strong OOP design, which sacrifices performance. The development goal of this project is to achieve relatively high simulation efficiency without the use of a hashtable.
Check out demo.ipynb to look at all the functions the tool supports or continue below for some brief examples.
install from github
$ pip install git+https://github.com/johnsoong216/PokerOddsCalc.git
In order to process data at a fast speed, all Card information are converted into numpy arrays to improve speed.
Card inputs are taken in the format of number: 23456789TJQKA followed by suit: dcsh.
To rank cards, we use a hexidecimal system to assign strength to the card from the most most significant card to the least significant card. There are 7462 distinct poker hands so we created an algorithm that transforms a hand into an integer value.
Firstly, we determine if the 5 card combination is suited/straight. This can quickly identify the type of several hands.
Then we work with numerical values of the cards where 2 to A are represented by integers from 2 to 14.
We sort the cards to quickly identify the card type.
First Step
Second Step
Third Step
Conclusion
Import Game
from PokerOddsCalc import HoldemTable, OmahaTable
Create a game, specify the number of players and the deck type (full deck or short deck)
ht = HoldemTable(num_players=5, deck_type='full') # Will Create Three Players: Player 1 - 5
Randomly Hand Out Cards by calling the next_round() function any step in the game, or Assign Manually
ht.add_to_hand(1, ['Td, 'Ad']) # Assign Player 1
ht.next_round() # Assign all other players randomly
Simulate to generate outcome, specify the number of scenarios and the odds calculation type (For more details please check demo.ipynb)
ht.simulate()
#
{'Player 1 Win': 50.31,
'Player 1 Tie': 3.84,
'Player 2 Win': 12.09,
'Player 2 Tie': 0.41,
'Player 3 Win': 11.4,
'Player 3 Tie': 3.84,
'Player 4 Win': 11.05,
'Player 4 Tie': 0.41,
'Player 5 Win': 11.31,
'Player 5 Tie': 0.41}
View Current Table, Current Hand or Current Result (if Game Ended)
ht.view_table()
ht.view_hand()
ht.view_result()