io.rainfall.utils.ConcurrentPseudoRandom Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of rainfall-core Show documentation
Show all versions of rainfall-core Show documentation
Rainfall-core is the core of the Rainfall framework
/*
* Copyright 2014 Aurélien Broszniowski
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.rainfall.utils;
/**
* Concurrent deterministic random bit generator
* Based on the XORSHIFT function
*
* We want do avoid using a linear congruential generator in order to get a standardized test.
*
* @author Aurelien Broszniowski
*/
public class ConcurrentPseudoRandom {
private final ThreadLocal randomFunction = new ThreadLocal() {
protected RandomFunction initialValue() {
return new RandomFunction();
}
};
private RandomFunction getRandomFunction() {
return randomFunction.get();
}
public long nextLong() {
return getRandomFunction().nextLong();
}
public long nextLong(final long seed) {
return getRandomFunction().nextLong(seed);
}
public float nextFloat() {
return getRandomFunction().nextFloat();
}
public float nextFloat(final long seed) {
return getRandomFunction().nextFloat(seed);
}
public float nextFloat(float max) {
return max * getRandomFunction().nextFloat();
}
private class RandomFunction {
long seed = 8682522807148012L ^ System.nanoTime();
public long nextLong() {
long nb = nextLong(this.seed);
this.seed = this.seed * 181783497276652981L;
return nb;
}
public long nextLong(long seed) {
seed ^= (seed << 21);
seed ^= (seed >>> 35);
seed ^= (seed << 4);
return seed;
}
public float nextFloat() {
float nb = nextFloat(this.seed);
this.seed = this.seed * 181783497276652981L;
return nb;
}
// Float.intBitsToFloat(nextInt()) ???
public float nextFloat(final long next) {
return Math.abs(((nextLong(next)) % 100000) / 100000f);
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy