diff --git a/C/out/samples b/C/out/samples index ade23da3..2542aa2f 100755 Binary files a/C/out/samples and b/C/out/samples differ diff --git a/C/samples.c b/C/samples.c index eb292501..b1d2e96e 100644 --- a/C/samples.c +++ b/C/samples.c @@ -167,7 +167,7 @@ void mixture(float (*samplers[])(uint32_t*), float* weights, int n_dists, float* uint32_t** seeds = malloc(n_threads * sizeof(uint32_t*)); for (uint32_t i = 0; i < n_threads; i++) { seeds[i] = malloc(sizeof(uint32_t)); - *seeds[i] = i + 1; + *seeds[i] = i + 1; // xorshift can't start with 0 } #pragma omp parallel private(i, p1, sample_index, split_array_length) diff --git a/C/scratchpad/xorshift.c b/C/scratchpad/xorshift.c index 33a9d8d2..b476c702 100644 --- a/C/scratchpad/xorshift.c +++ b/C/scratchpad/xorshift.c @@ -13,7 +13,7 @@ uint32_t xorshift32(uint32_t* state) } float rand_xorshift32(uint32_t* state){ - return (float) xorshift32(state) / UINT32_MAX; + return (float) xorshift32(state) / (float) UINT32_MAX; } int main(){