Some documentation for this app is also on my website.
This repository contains source code and setup instructions for PokerTexter, an SMS app that gives you an advantage when playing Texas Hold 'Em. Running the app will let you text the PokerTexter phone number with your cards and number of other players, and it texts you back some pre-flop statistics:
- % Chance of Winning
- % Chance of Tying
- Expected Unit Gain: suppose you bet $1, everyone else bets $1 each, and no further bets are made. The expected unit gain is the average amount of money you expect to win (with those two cards and that number of players).
For example: suppose you're playing Poker with three other people. You are dealt a nine of hearts and a seven of clubs. You message PokerTexter that you have a nine and a seven unsuited with three other players. It texts you back that your probability of winning the hand is 21.52%, your probability of tying is 2.82%, and your expected unit gain is -0.111. Since the expected unit gain is negative, i.e. on average you will lose $0.111 on a bet of $1, it would be unwise to play the hand.
- Some people play Poker suited, which is when Spades, Hearts, Clubs, and Diamonds are all ranked, and their ranking is used to break ties. PokerTexter does not support suited play.
- Though in theory, anywhere between 2 and 23 people can play Texas Hold 'Em, PokerTexter currently supports only between 2 and 10 players (these are standard numbers of players). Extending the script to support up to 23 players would be easy, but it hasn't been done yet because this use case seems exceedingly rare.
- To verify the results offered by this app, I cross-referenced the lookup tables against the Flash Poker Odds Calculator located here.
Following is a list of items in this repository and notes on what they're for:
destroy.sh
: destroys all created Heroku apps. If you're having trouble launching, then you may in the process create lots of apps. This script clears them up.launch.sh
: launches the Heroku app and scales it with one dyno [worker]. Once you've done this, you can use PokerTexter from your phone.lookup-tables/lookup-table-n
: this is a lookup table, mapping any starting hand (on a table with n players) to probabilities and expected gains.Procfile
: necessary for the Heroku app to run.requirements.txt
: requirements forrun-pokertexter.py
. Heroku needs the requirements, so as to install any necessary packages for the app.generate-lookup-tables
: folder containing code for generating the lookup tables. Items in here are not essential torun-pokertexter.py
.generate-lookup-tables/generate-lookup-table.py
: for a number of players n, generatelookup-table-n
. Relies on thedeuces
library.generate-lookup-tables/deuces
: the deuces library for fast poker hand evaluation.
Following are the steps you need to take to get PokerTexter to run. Note that these instructions are dated April 12, 2016: certain steps may change if either Twilio or Heroku adjust their product or infrastructure in any way.
- Make a Twilio account.
- Get a Twilio phone number. It's free.
- Register your personal mobile phone number with Twilio. You need to have "whitelisted" your number so you can communicate with the Twilio phone number. (I believe this restriction is in place to prevent abuse of Twilio's free service.)
- Make a Heroku account.
- Open up your terminal and download this repository:
git clone https://github.com/Datamine/PokerTexter
andcd
into it. - Install the Heroku Toolbelt and login to Heroku.
- While in
PokerTexter
, typeheroku create
. This creates a Heroku app. - Then type
git push heroku master
. Note that you do not have to take the usual prior steps ofgit init; git add *; git commit -m "asdf"
because you cloned a repository, which contains an already-setup.git
folder. - The previous step generates some printed output. Toward the bottom there will be a line reading something like
remote: http://lit-bastion-5032.herokuapp.com/ deployed to Heroku
. (The name betweenhttp://
and.herokuapp.com
is a unique identifier. Yours will be different.) This is the URL at which your Heroku app is accessible. - Go to your Twilio Numbers Page and click on your Twilio phone number. You'll get a page where you can set various settings for that number. Toward the bottom there will be a Messaging subheader, and a field Request URL. Copy-paste your Heroku app's URL (from the previous step) into this field and save your changes.
- Go back to your terminal, and type
heroku ps:scale web=1
to add a worker. - You can check the status of your app with
heroku logs --tail
. - Now you can use your personal mobile phone to send messages to your Twilio Phone Number (PokerTexter). You should always receive a response, even for incorrectly formatted input. If you're receiving responses: congratulations! You're all set up.
If you make any changes to run-pokertexter.py
or to any of the other files in PokerTexter
, you will need to relaunch the app for the changes to propagate. You can relaunch easily by typing ./launch
. No other steps will be necessary, unless you create a new Heroku app and thereby create a new Heroku app URL, in which case you'll need to amend your Twilio Numbers Page appropriately.
Send messages to PokerTexter in form RANK1 RANK2 SUITING OTHER_PLAYERS
, where:
RANK1
is the rank of your first card. Admissible ranks are {2,3,4,...,10,J,Q,K,A}. For the numberic cards, you can type in the numeral (e.g. "2") or write it out (e.g. "two"). For the non-numeric cards, you can write them out (e.g. "jack") or use the first letter (e.g. "j"). Capitalization doesn't matter.RANK2
is the rank of your second card. Similar to rank1.SUITING
describes whether or not your two cards share the same suit. If they do, you should writesuited
. If they do not, you should writeoffsuit
orunsuited
.OTHER_PLAYERS
is the number of other players, i.e. number of players in the round excluding yourself.
While the probabilities of winning and tying scale as you would expect in the number of players, the expected gains change sign in some cases. For example, if you're playing with nine other players, a 9-K offsuit has an expected gain of -0.0036. It would be inadvisable to play that hand. However, if you're playing with two other players, a 9-K offsuit has an expected gain of 0.184. You'd want to play that hand.
This instruction set assumes that you're using the Twilio free trial. Regrettably, to remind you that you're on their "free" tier, they prepend "Sent from your Twilio trial account -" to every text message that PokerTexter sends. You can immediately fix this by upgrading from Twilio free to Twilio Hobby, but that costs $7 a month.
There are some other limitations on the app because you're using both Twilio's and Heroku's free tiers. Heroku's free tier lets you run an app only for 18 hours out of 24. Realistically, this should not be a problem. If you want to run an app for more than 18 hours out of 24, you'll need to recreate it after 18 hours to avoid the limit. There are also a few limits to Twilio's free tier, though none that are immediately of concern.
The scope of this app is currently quite limited: it doesn't permit you to submit cards beyond your initial two. It is easily possible to also support additional known cards (e.g. cards on the table, known burned cards, etc.) but the usefulness of such features is limited because additional cards are made known only in the later stages of the game, when probability can be more easily intuitively approximated (it's easy to figure out your outs and their approximate odds), and the psychological aspect of the game becomes more important. Nonetheless, I aim to add such features in the near future.
The app currently does not compute ties correctly for more than two players. When any two hands on the table tie, the entire table is interpreted to have tied -- even though in reality, only the best two hands tie and split the pot. PokerTexter is currently written such that the entire table ties, i.e. everyone gets back their initial bet. Thankfully, ties are generally so rare such that expected gain is only minimally affected. However, this is by far the most serious flaw currently present in the software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.