Random.avt

Переключить прокрутку окна
Загрузить этот исходный код

/*
    Исходный код среды исполнения ПВТ-ОО.

    Этот исходный код является частью проекта ПВТ-ОО.

    Copyright © 2021 Малик Разработчик

    Это свободная программа: вы можете перераспространять её и/или
    изменять её на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
    в каком она была опубликована Фондом свободного программного обеспечения;
    либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.

    Эта программа распространяется в надежде, что она может быть полезна,
    но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
    или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЁННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
    общественной лицензии GNU.

    Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
    вместе с этой программой. Если это не так, см.
    <http://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("аргумент 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 < 0);
        return result;
    }

    public long nextLong() { return ((long) next(32) << 32) + ####next(32); }

    public float nextFloat() { return (float) next(24) / 16777216.0f; }

    public double nextDouble() { return (double) (((long) next(26) << 27) + (long) next(27)) / 9007199254740992.0d; }

    public real nextReal() { return (real) (((long) next(32) << 32) + ####next(32)) / (4611686018427387904.0r * 4.0r); }

    protected synchronized int next(int bits) { return (int) ((fldSeed = (fldSeed * MULTIPLIER + ADDEND) & MASK) >>> (48 - bits)); }
}