10,000 Nights at a Casino – Using Python to test my Roulette Strategy

A few years ago, friends and I took a pit stop in Macau during a trip through Asia after our graduation.  While there, I came up with a fairly simple roulette strategy that I thought could work for someone with enough of a bankroll.  Since then, my friend Steve and I have argued about 15x about the validity of this strategy.  In fact, Steve even wrote a VBA program to prove that I was wrong.  Well, Steve, I wrote my own program this past rainy Sunday (to highlight my gambling prowess, this Sunday I also doubled up in Texas Hold ‘EM poker after flopping a full house with 7, 2 off suite – but that’s a story for another day).

The strategy is as follows: put $1 on black.  If you win, take your winnings off the table and put a new $1 bet down.  If you lose, then put $2 down, if you lose again, double it to $4, if you lose again, double it to $8, and keep doubling down until you win, then take all of your money off the table (your winnings will offest your previous string of losses and leave you with a $1 profit), and start again with a $1 bet.  Of course, the problem becomes, what happens when you lose 10 times in a row.  Well, I’m glad you asked.

First off, let’s analyze the probability of you losing that many times in a row.  There are 38 possibilities in a roulette wheel – numbers 1-36, 0, and 00.  So, your chances of not hitting your color are ((38-18)/38, or about 53%.  So, you don’t have a great chance of winning if you just play once.  But, what are the chances of you losing several times in a row?  The below table illustrates how low these odds become (‘Necessary Bet’ is the bet needed to recover losses and make $1.  The ‘Probability’ is the cumulative probability of losing n many times in a row.  See R1:T17 of the first tab of the excel I link to at the bottom of the post for the calculations):

Below is a graph of what your pay offs may look like.  Note that you are winning only $1 at a time until you eventually get really unlucky, somewhere around your 13,000th spin in this case, and lose money beyond your bankroll which forces you to quit and walk out of Macau penniless (but hopefully not indebted to some Asian Gangsters).  Notice how the blue bar suddenly drops to -$9,000…

This type of payoff structure is analogous to “picking up nickles in front of a steam roller.”  If you haven’t already, you should read When Genius Failed, the story of the demise of Long Term Capital Management.  LTCM was a hedge fund run by Nobel laureates who made thousands of tiny bets using computer programs in a strategy called statistical arbitrage, among others.  The hedge fund blew up as they thought the scenarios that would cause their fund to collapse would only occur once every few centuries (it only took a few years for the fund to meet its very spectacular end in one of the first “too big to fail” situations.  Fun fact: all Wall Street banks pitched in to help unwind the fund’s assets, and thus divert a systemic break in the economy, except for Bear Stearns who refused to help…).

Below is a zip file with three Python programs whose outputs are captured in the excel.  The programs assume that you start with $100, and can borrow up to $5,000 from your friend (except for the last one that assumes you can borrow $15,000).  So, just as LTCM relied on leverage to try to double down on their bets and save their fund, this strategy also relies on loans to stay afloat in bad times when the odds go against you.

The first program is what would happen if you sat down and played until you went bust.  I ran this program once, and you make about $6,000 before hitting some bad luck and going bust (this is shown in the line graph above).  The second program basically runs the first program 10,000 times in order to get an average payout.  However, this one assumes you are only willing to play 100 games in a row as even 100 games would probably take a very long time in reality.  The last program is the same as the second, except that the player can lose up to $15,000 before quitting, and, if they have played 100 games and are at a negative value at the 100th game, they will play until they either recoup their losses, or go bust and lose $15,000.  This last scenario actually yields a positive expected value of about $4 (see the third table of the excel file I link to at the end of the post.  Expected value is what you would expect to win, on average, if you played this strategy many times).  Here is the distribution of returns from spending 10,000 nights in the casino with your friend that has $15,000 he can loan you if need be.  Pay no attention to the long tails where you lose $8,000 – that’s like a 10 sigma event and would NEVER happen 🙂

Conclusion: is this an effective strategy?  Not really.  Even if you found a table that let you start with $1 bets, and you had the patience to sit down and do this, and you had the bankroll, it’s just not going to yield all that much cash over time.

Please feel free to look over my code and let me know if you come up with any other conclusions by modifying it!  Also – I’m not a programmer – these scripts were very easy to do and took me only a few hours to write all three and conduct all analysis because Python is super easy!  If you want to learn more, MIT has FREE courses on Python that you should check out.  Enjoy!

To quote a really great “anti-recruiter” LinkedIn profile describing time spent at a large quant hedge fund: “I earn above-market returns 95% of years by collecting theta, selling volatility in the form of financial derivatives, naked short put options, and in summary, collect nickels and dimes in front of steam rollers, hoping the black swans never appear during my lifetime.

Attachments:

The Excel: Roulette Output

Python programs: Roulette Programs

7,734 Replies to “10,000 Nights at a Casino – Using Python to test my Roulette Strategy”

  1. U-Etds NASIL ÜCRETSİZ KULLANIRIM

    Üç Adımda Hızlı Kullanım

    1 Dakikada Firma Kaydının Yapılması

    U-Etds Nedir Bölge bayilerimize ya da Firmamıza ulaşarak hızlıca sistemimize abone olun.

    E-Devlet Üzerinden IP Yetkilendirmesi
    Firma yetkilisi olarak, E-Devlet üzerinden IP
    yetkilendirmesi yaparak UETDS kullanıcı bilgilerini temin ediniz (Bayimizin yardımıyla).

    UETDS Kullanıcı Bilgilerini Sisteme Tanımlayınız
    Sistemimize giriş yaparak profil menüsünden UETDS kullanıcı bilgilerini tanımlayınız.
    Artık UETDS yük bildirimlerinizi kolaylıkla yapabilirsiniz.
    (Sistemimizin Kullanılması ve sisteme IP tanımlaması ile ilgili bayilerimizden gerekli eğitimi alabilir, ilgili
    videoları izleyebilirsiniz)

    U-Etds

  2. U-ETDS NE ZAMAN YÜRÜRLÜĞE GİRİYOR? U-ETDS ne zaman başlıyor?
    Ulaştırma Bakanlığının yayınladığı son genelgeye göre Karayolları taşımacılığında UETDS Eşya/Tehlikeli Madde yük bildirimleri Temmuz 2021 itibarıyla
    yürürlüğe girdi.

    Bu Tarihten itibaren UETDS kapsamı içerisinde bulunan Tehlikeli Madde taşıyan ve bir kısım Normal Yük taşıyan firmalar taşıdıkları yükleri UETDS sistemi üzerinden bildirmekle mükelleftirler.
    Cezai işlemlerin ise 2022 Ocak itibarıyla başlayacaktır.
    Bütün Normal Yük taşıyan şahıs firmaları
    Ocak 2022 itibarıyla U-ETDS kapsamına girecektir.

    U-Etds

  3. UETDS (Ulaştırma Elektronik Takip ve Denetim Sistemi) Nedir?

    UETDS (Ulaştırma Elektronik Takip ve Denetim Sistemi), ilk olarak 08.01.2018 tarih ve
    30295 sayılı Resmi Gazete’de yayımlanarak yürürlüğe girmiştir.
    Karayolu Taşıma Yönetmeliği (KTY) ile tanımlanmıştır.

    UETDS sistemi, 4925 sayılı Karayolu Taşıma
    Kanunu (KTK) ve KTY çerçevesinde taşımacılık faaliyetinde bulunan firmaları kapsar.
    Firmalar taşıdıkları eşya, kargo ve yolcu hareketlerinin elektronik olarak gerçek zamanlı takibi,
    değerlendirilmesi ve denetimi imkanlarının sağlanacağı bir sistemdir.

    U-Etds

  4. KİMLER BİLDİRİM YAPMAK ZORUNDA?

    U-Etds Nedir zaman başlıyor? Kimleri Kapsıyor?

    Ocak 2022 İtibarıyla:
    U-Etds sistemi, KTK ve KTY çerçevesinde ticari olarak faaliyet gösteren ve Normal yük ve Tehlikeli Madde taşıyan bütün şahıs ve tüzel kişilikli firmalar ve kooperatifler.

    Temmuz 2019 İtibarıyla:
    Tarifeli/Tarifesiz Yolcu taşımacılığı faaliyetleri yapan (A1, A2, B1, B2, D1 ve D2 belge sahipleri) bütün firmalar
    UETDS bildirimi yapmakla mükelleftirler.

    U-Etds Nedir

  5. Artık U-ETDS bildirimi yapmak çok kolay. Bizimle iletişime geçin. Hızlı bir şekilde ulaştırma bakanlığı ile ilgili prosedürleri gerçekleştirmenizde yardımcı olalım.
    Araç / Filo bilgilerinizi sizlere zahmet vermeden hemen sistemimizde tanımlayalım.

    Siz değerli müşterilerimize ise sistemimize girip yalnızca ve
    kolayca U-ETDS bildiriminizi yapmak kalsın. Sistemimizde bütün filonuzun bildirimlerini yönetebilir ve her bir
    araç için ayrı ayrı mobil erişim izni verebilirsiniz..!
    İsterseniz bütün bildirimleri bir merkezden yönetin isterseniz her bir araç için bildirim izni vererek
    iş yükünüzü azaltın.

    U-Etds

Comments are closed.