ref: d091e9f0123b86ddabfd76d3637f49486b0b16df
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;
}