2013-07-02 20:52:38 -06:00
|
|
|
/* Copyright (c) 2008-2013, Avian Contributors
|
2008-02-19 11:06:52 -07:00
|
|
|
|
|
|
|
Permission to use, copy, modify, and/or distribute this software
|
|
|
|
for any purpose with or without fee is hereby granted, provided
|
|
|
|
that the above copyright notice and this permission notice appear
|
|
|
|
in all copies.
|
|
|
|
|
|
|
|
There is NO WARRANTY for this software. See license.txt for
|
|
|
|
details. */
|
|
|
|
|
2007-12-17 15:43:51 -07:00
|
|
|
package java.util;
|
|
|
|
|
|
|
|
public class Random {
|
2008-03-20 18:39:25 -06:00
|
|
|
private static final long Mask = 0x5DEECE66DL;
|
|
|
|
|
2012-02-14 13:01:00 -07:00
|
|
|
private static final long InitialSeed = 123456789987654321L;
|
|
|
|
|
|
|
|
private static long nextSeed = InitialSeed;
|
2008-03-20 18:39:25 -06:00
|
|
|
|
|
|
|
private long seed;
|
|
|
|
|
|
|
|
public Random(long seed) {
|
|
|
|
setSeed(seed);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Random() {
|
2012-02-14 13:01:00 -07:00
|
|
|
synchronized (Random.class) {
|
|
|
|
setSeed(nextSeed ^ System.currentTimeMillis());
|
|
|
|
nextSeed *= 123456789987654321L;
|
|
|
|
if (nextSeed == 0) {
|
|
|
|
nextSeed = InitialSeed;
|
|
|
|
}
|
|
|
|
}
|
2008-03-20 18:39:25 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
public void setSeed(long seed) {
|
|
|
|
this.seed = (seed ^ Mask) & ((1L << 48) - 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected int next(int bits) {
|
|
|
|
seed = ((seed * Mask) + 0xBL) & ((1L << 48) - 1);
|
|
|
|
return (int) (seed >>> (48 - bits));
|
|
|
|
}
|
|
|
|
|
|
|
|
public int nextInt(int limit) {
|
|
|
|
if (limit <= 0) {
|
|
|
|
throw new IllegalArgumentException();
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((limit & -limit) == limit) {
|
|
|
|
// limit is a power of two
|
|
|
|
return (int) ((limit * (long) next(31)) >> 31);
|
|
|
|
}
|
|
|
|
|
|
|
|
int bits;
|
|
|
|
int value;
|
|
|
|
do {
|
|
|
|
bits = next(31);
|
|
|
|
value = bits % limit;
|
|
|
|
} while (bits - value + (limit - 1) < 0);
|
|
|
|
|
|
|
|
return value;
|
2008-02-26 09:37:46 -07:00
|
|
|
}
|
|
|
|
|
2007-12-17 15:43:51 -07:00
|
|
|
public int nextInt() {
|
2008-03-20 18:39:25 -06:00
|
|
|
return next(32);
|
2007-12-17 15:43:51 -07:00
|
|
|
}
|
2008-02-28 11:02:58 -07:00
|
|
|
|
2008-11-11 08:20:49 -07:00
|
|
|
public void nextBytes(byte[] bytes) {
|
|
|
|
final int length = bytes.length;
|
|
|
|
for (int i = 0; i < length;) {
|
|
|
|
int r = nextInt();
|
|
|
|
for (int j = Math.min(length - i, 4); j > 0; --j) {
|
|
|
|
bytes[i++] = (byte) r;
|
|
|
|
r >>= 8;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public long nextLong() {
|
|
|
|
return ((long) next(32) << 32) + next(32);
|
|
|
|
}
|
|
|
|
|
2008-02-28 11:02:58 -07:00
|
|
|
public double nextDouble() {
|
2008-03-20 18:39:25 -06:00
|
|
|
return (((long) next(26) << 27) + next(27)) / (double) (1L << 53);
|
2008-02-28 11:02:58 -07:00
|
|
|
}
|
2007-12-17 15:43:51 -07:00
|
|
|
}
|