Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8124545
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 6, 20262026-06-06T06:29:08+00:00 2026-06-06T06:29:08+00:00

I have a project which uses php’s mt_rand() to generate different random integers but

  • 0

I have a project which uses php’s mt_rand() to generate different random integers but I have recently gained access to a stream of real random bits. I am having trouble figuring out how to create a function similar to mt_rand(), where I can get a random integer between two values, from my stream of bits. How can I achieve this?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-06T06:29:11+00:00Added an answer on June 6, 2026 at 6:29 am

    I have come up with a method but not sure if its the most efficient way in terms of bits used (code is untested, just demonstrating theory):

    function RandomInteger($min, $max)
    {
        $range = ($max - $min) + 1;
        $bitsNeeded = ceil( log($range, 2) );
        $number = ReadBitsAndConvertToInteger($bitsNeeded);
        if ($number < $range)
            return $number + $min;
        else if ($number > $range)
            return RandomInteger($min, $max);
    }
    

    As you can see, there will be a chance the function is repeated, which means more bits will be used, thats why I’m not sure if its the most efficent way, in terms of bits used, to do it.

    Pr(repeat) = (2^bitsNeeded - range) / (2^bitsNeeded)

    Therefore, 0 < Pr(repeat) < 0.5

    So in the worst case that the chance of having to repeat is almost 0.5, it starts to get quite unlikely that it would need to be repeated more than 10 or so times, with the average being just under 2 times. Obviously at lower chances of having to repeat , these numbers get lower.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a spring project which uses different libraries, packed as multiple jars. One
I have a maven project which uses wsgen to generate XSD files from the
I have a project which uses a large library residing in its own repository.
I have a C# project A which uses a .net wrapper DLL and a
I have a maven project A which uses jar files of another project B
I have a Visual Studio project which uses nmake to call a Python file
I have just begun working on a project which uses Mercurial as a version
I have a DLL project in VS 2008 Pro which uses OpenMP. I use
i have a java ee project which has a text file that uses a
Imagine you have a PlayN game which uses Guice bindings in its core project:

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.