X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=lib%2Fgauss.c;h=1d24e187ab733793fa4ece4dc50c8c15a5efa332;hb=5857e8e0f53e81bd7096209fe5cabf91ce74b853;hp=cd8b6e3e491a8669b3d5cad6e92c80567d656acb;hpb=50d795a5b72ea43ee125012a2aec7e4cfad20de9;p=fio.git diff --git a/lib/gauss.c b/lib/gauss.c index cd8b6e3e..1d24e187 100644 --- a/lib/gauss.c +++ b/lib/gauss.c @@ -1,6 +1,5 @@ #include #include -#include #include "../hash.h" #include "gauss.h" @@ -15,7 +14,7 @@ static int gauss_dev(struct gauss_state *gs) return 0; r = __rand(&gs->r); - vr = gs->stddev * (r / (FRAND_MAX + 1.0)); + vr = gs->stddev * (r / (FRAND32_MAX + 1.0)); return vr - gs->stddev / 2; } @@ -38,16 +37,27 @@ unsigned long long gauss_next(struct gauss_state *gs) sum += dev; } - return __hash_u64(sum) % gs->nranges; + if (!gs->disable_hash) + sum = __hash_u64(sum); + + return sum % gs->nranges; } -void gauss_init(struct gauss_state *gs, unsigned long nranges, unsigned int d, +void gauss_init(struct gauss_state *gs, unsigned long nranges, double dev, unsigned int seed) { memset(gs, 0, sizeof(*gs)); - init_rand_seed(&gs->r, seed); + init_rand_seed(&gs->r, seed, 0); gs->nranges = nranges; - gs->stddev = d; - if (gs->stddev > nranges / 2) - gs->stddev = nranges / 2; + + if (dev != 0.0) { + gs->stddev = ceil((double) (nranges * 100.0) / dev); + if (gs->stddev > nranges / 2) + gs->stddev = nranges / 2; + } +} + +void gauss_disable_hash(struct gauss_state *gs) +{ + gs->disable_hash = true; }