/*
Реализация среды исполнения языка программирования
Объектно-ориентированный продвинутый векторный транслятор
Copyright © 2021, 2024 Малик Разработчик
Это свободная программа: вы можете перераспространять ее и/или изменять
ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
в каком она была опубликована Фондом свободного программного обеспечения;
либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
Эта программа распространяется в надежде, что она будет полезной,
но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
общественной лицензии GNU.
Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
вместе с этой программой. Если это не так, см.
<https://www.gnu.org/licenses/>.
*/
package avt.util;
public class Random(Object)
{
private static final long MULTIPLIER = 0x00000005deece66dL;
private static final long ADDEND = 0x000000000000000bL;
private static final long MASK = 0x0000ffffffffffffL;
private long fldSeed;
public () { fldSeed = (System.currentTimeInMillis() ^ MULTIPLIER) & MASK; }
public (long seed) { fldSeed = (seed ^ MULTIPLIER) & MASK; }
public synchronized void setSeed(long seed) { fldSeed = (seed ^ MULTIPLIER) & MASK; }
public int nextInt() { return next(32); }
public int nextInt(int limit) {
int bits;
int result;
if(limit <= 0)
{
throw new IllegalArgumentException(String.format(avt.lang.package.getResourceString("illegal-argument.non-positive"), new Object[] { "limit" }));
}
if((limit & -limit) == limit) /* limit является степенью двойки */
{
return (int) (((long) limit * (long) next(31)) >> 31);
}
do
{
result = (bits = next(31)) % limit;
} while(bits - result + limit < 1);
return result;
}
public long nextLong() { return ((long) next(32) << 32) + ####next(32); }
public float nextFloat() { return ((float) next(24)) * 0x1.0p-24f; }
public double nextDouble() { return ((double) (((long) next(26) << 27) + ####next(27))) * 0x1.0p-53f; }
public real nextReal() { return ((real) (((long) next(32) << 32) + ####next(32)) + 0x1.0p+63f) * 0x1.0p-64f; }
protected synchronized int next(int bits) { return (int) ((fldSeed = (fldSeed * MULTIPLIER + ADDEND) & MASK) >>> (48 - bits)); }
}