ref: 54309f1cb25e5a65b834dab0e5ff711be3d812d1
dir: /sys/src/libc/port/frand.c/
#include <u.h>
#include <libc.h>
#define MASK 0x7fffffffL
#define NORM (1.0/(1.0+MASK))
double
frand(void)
{
double x;
do {
x = lrand() * NORM;
x = (x + lrand()) * NORM;
} while(x >= 1);
return x;
}