Skip to main content

Historic frequency based random lotto number generator.

This example is a little program to generate random numbers based on historic lotto results. Each potential result pull is weighted based on past results.

The full project is available on GitHub here.

https://youtu.be/T_f01uwnN-A

First, we need to store the historic data. In this case I use an instance of SortedDictionary.


int totalBallsNeeded = 6; // 5 plus the extra shot
int doubleBallCount = 104; // 52 numbers times 2

SortedDictionary<int, int> lottoNumberFrequencyTable = new SortedDictionary<int, int>();
lottoNumberFrequencyTable.Add(1, 29);
lottoNumberFrequencyTable.Add(2, 34);
// Add more entries as needed
lottoNumberFrequencyTable.Add(52, 38);

There is a possible range of 01 to 52 lotto values. I pulled the frequency data from online sources. In this case the key is the lotto number and the value is the frequency.

After the data is stored, we do the actual random number generation with weighted frequency.

The array we link our random numbers to is twice as large as the total number of lotto possibilities. Inside two array index related to one lotto number.

That means for lotto #01 index 0 and index 1 will store the values 0 to 29.
For lotto #02 it will be associated to index 2 and index 3 with values 30 to 64.


// add up the total range of frequencies
int totalFrequencyCount = 0;

// an array that will hold frequency ranges for all possible balls
// eg: [0][1] is for ball 01 with two associated array entries: [0] = 0 and [1] = 29
// for ball 02 it would be [2] = 30 and [3] = 64 for that range
int[] frequencyBlocks = new int[doubleBallCount];

// keep track of which set of array entries we are working on
int frequencyBlocksCounter = 0;

foreach (KeyValuePair<int, int> entry in lottoNumberFrequencyTable.ToArray())
{
    // generate block of numbers for weighted RNG
    // the starting point value for this lotto number
    frequencyBlocks[frequencyBlocksCounter] = totalFrequencyCount++;

    // increment the total frequency count variable to prep for the next step
    totalFrequencyCount += entry.Value;

    // the ending point for this lotto number
    frequencyBlocks[frequencyBlocksCounter + 1] = totalFrequencyCount;

    // jump to the next set of array entries
    frequencyBlocksCounter += 2;
}

// fire up a random number generator
Random r = new Random();

// clear our result display text box
textBox1.Text = "";

// due to needing unique numbers, we need to track our successful pulls
int totalBallsSelected = 0;

// a place to store our successful pulls
List<int> selectedBallValues = new List<int>();

// get our six weighted random values with no duplicates
while (totalBallsSelected < totalBallsNeeded)
{
    // get a random number between 1 and the total sample size
    int randInRange = r.Next(1, totalFrequencyCount);

    // get a weighted random number result
    // loop through our custom array
    int currentBall = 1;

    for (int j = 0; j < doubleBallCount; j += 2)
    {
        // find which block of weighted frequency this random number should fit in
        // once found that range will relate back to a lotto number
        if (randInRange >= frequencyBlocks[j] && randInRange < frequencyBlocks[j + 1])
        {
            // don't allow duplicates
            if (!selectedBallValues.Contains(currentBall))
            {
                // save the successful pull into our result class instance
                selectedBallValues.Add(currentBall);
                totalBallsSelected++;
            }
            break; // exit the inner for loop after a successful pull
        }
        else
        {
            // after a successful pull, increment our total result counter
            currentBall++;
        }
    }
}

When we get a random number, it will fit into our double wide array. Looping through each time to find where in the array it should fit. Once that index is found it related back to the actual lotto number. This happens as long as it takes to get 6 entries that are unique.



Popular posts from this blog

ChatGPT is a new, and faster, way to do programming!

Currently ChatGPT is in a free “initial research preview” . One of its well known use cases at this point is generating software code. I’ve also just used it to write most of this article… Well, actually a future article about cleaning up SRT subtitle files of their metadata faster than I have been by hand with Notepad++ and its replace functionality. Update: I recorded a screencast of writing the SRT subtitle cleaner application loading and processing portion. I relied heavily on ChatGPT for code. It was a fun process! https://youtu.be/TkEW39OloUA ChatGPT, developed by OpenAI, is a powerful language model that can assist developers in a variety of tasks, including natural language processing and text generation. One such task that ChatGPT can help with is creating an SRT cleaner program. SRT, or SubRip Subtitle, files are commonly used to add subtitles to video files. However, these files can become cluttered with unnecessary information, such as timing lines or blank spaces. To clean...

Theme error in 2010s Android App after AppCompat Migration

I plan on releasing a lot of my old work as GPL open source, but most of it has aged to the point that it no longer functions, or if it does work it’s running in compatibility mode. Basically it’s no longer best practices. Not a good way to start off any new public GPL projects, in my opinion. The current project I’m working on is an Android app that calculates star trails meant to help photographers get or avoid that in their night time photos. For now I’m going to skip some of the import process because I didn’t document it exactly. It’s been mostly trial and error as I poke around Android Studio post import. The Android Studio import process… Removing Admob Google Play code before the project would run at all. After removing dependencies, it kind of worked, but when running it in the emulator it shows a pop-up message saying that the app was developed for an old version of Android. Going through the process of updating code to match current best practices… I had the IDE convert the ...

Printing to file in Linux WINE

I noticed that this post has been sitting as a draft since 2011. At this point I have no idea if it’s useful or what I was even doing, but I might as well make it public in case someone can find it helpful! So I’ve been trying to get one of those PDF print drivers working in WINE without success. I then came upon a process that might work. When printing you need to select the checkbox “Print to file” that creates a .prn file. Just Linux things... I was using a program that only has printing facilities, but I want to export around 100 pages of text and images. Once you have the .prn (postscript) file, you can do any number of things to it. In my case I want the postscript file to be converted to HTML. I am also considering PDF format because that has more conversion options to eventually get me to HTML or plain text. sudo apt-get install cups-pdf Or it looks like that package might have changed to this… sudo apt-get install printer-driver-cups-pdf Where PDFs would be generated in /home/...