Double.avt

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

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

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

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

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

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

    Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
    вместе с этой программой. Если это не так, см.
    <http://www.gnu.org/licenses/>.
*/

package avt.lang;

import avt.lang.array.*;
import avt.math.*;

public final class Double(Object, Numeric, Comparable, Cloneable)
{
    public static final double NAN = 0.0d / 0.0d;
    public static final double POSITIVE_INFINITY = +1.0d / 0.0d;
    public static final double NEGATIVE_INFINITY = -1.0d / 0.0d;
    public static final double MAX_VALUE = 1.79769313486231571e+308d;
    public static final double MIN_VALUE = 4.94065645841246544e-324d;
    private static final long SIGNIFICAND_MASK = 0x000fffffffffffffL;
    private static final long NEGATIVE_ZERO_BITS = -1L << 63;
    private static final double NEGATIVE_MAX_VALUE = -MAX_VALUE;
    private static final double NEGATIVE_MIN_VALUE = -MIN_VALUE;
    private static final double HALF = 0.5d;
    private static final RealRepresenter doubleRepresenter;

    public static { doubleRepresenter = new RealRepresenter(RealRepresenter.DOUBLE_SIGNIFICAND_DIGITS - 1, RealRepresenter.DOUBLE_ORDER_DIGITS); }

    /*<fold signum, compare>*/
        public static int signum(double value) { return value != value || value == 0.0d ? 0 : value < 0.0d ? -1 : 1; }

        public static int compare(double value0, double value1) { return value0 != value0 || value1 != value1 ? INDEFINITE : value0 > value1 ? 1 : value0 < value1 ? -1 : 0; }
    /*</fold>*/

    /*<fold arithmetic>*/
        public static boolean isNaN(double value) { return value != value; }

        public static boolean isInfinite(double value) { return value == POSITIVE_INFINITY || value == NEGATIVE_INFINITY; }

        public static native double nextAfter(double value);

        public static native double nextBefore(double value);

        public static double max(double value0, double value1) { return value0 != value0 ? value0 : value1 != value1 ? value1 : value0 == 0.0d && value1 == 0.0d && toLongBits(value0) == NEGATIVE_ZERO_BITS || value0 < value1 ? value1 : value0; }

        public static double min(double value0, double value1) { return value0 != value0 ? value0 : value1 != value1 ? value1 : value0 == 0.0d && value1 == 0.0d && toLongBits(value1) == NEGATIVE_ZERO_BITS || value0 > value1 ? value1 : value0; }
    /*</fold>*/

    /*<fold bit conversion>*/
        public static native long toLongBits(double value);
    /*</fold>*/

    /*<fold parse>*/
        public static double parse(CharArray string) { return doubleRepresenter.parseDouble(string); }
    /*</fold>*/

    /*<fold string representation>*/
        public static String toString(double value) { return doubleRepresenter.toString(value); }

        public static String toString(double value, int sigDigits, int ordDigits) { return (new RealRepresenter(sigDigits, ordDigits)).toString(value); }

        public static String toString(double value, int sigDigits, int ordDigits, boolean sigAll, boolean ordAll) { return (new RealRepresenter(sigDigits, ordDigits, sigAll, ordAll)).toString(value); }

        public static String toString(double value, int sigDigits, int ordDigits, boolean sigAll, boolean ordAll, boolean expForm) { return (new RealRepresenter(sigDigits, ordDigits, sigAll, ordAll, expForm)).toString(value); }

        public static String toString(double value, int sigDigits, int ordDigits, boolean sigAll, boolean ordAll, boolean expForm, boolean sigSign, boolean ordSign) { return (new RealRepresenter(sigDigits, ordDigits, sigAll, ordAll, expForm, sigSign, ordSign)).toString(value); }
    /*</fold>*/

    /*<fold valueOf>*/
        public static Double valueOf(double value) { return new Double(value); }

        public static Double valueOf(CharArray string) {
            double value = parse(string);
            return new Double(value);
        }
    /*</fold>*/


    private final double fldValue;

    public (real value) { fldValue = (double) value; }

    public boolean equals(Object anot) { return anot == this || anot instanceof Double && toLongBits(fldValue) == toLongBits(((Double) anot).fldValue); }

    public long hashCodeAsLong() { return toLongBits(fldValue); }

    public String toString() { return toString(fldValue); }

    public boolean isNaN() { return isNaN(fldValue); }

    public boolean isInfinite() { return isInfinite(fldValue); }

    public byte asByte() { return (byte) fldValue; }

    public byte2 asByte2() { return (byte) fldValue; }

    public byte4 asByte4() { return (byte) fldValue; }

    public byte8 asByte8() { return (byte) fldValue; }

    public short asShort() { return (short) fldValue; }

    public short2 asShort2() { return (short) fldValue; }

    public short4 asShort4() { return (short) fldValue; }

    public short8 asShort8() { return (short) fldValue; }

    public int asInt() { return (int) fldValue; }

    public int2 asInt2() { return (int) fldValue; }

    public int4 asInt4() { return (int) fldValue; }

    public int8 asInt8() { return (int) fldValue; }

    public long asLong() { return (long) fldValue; }

    public long2 asLong2() { return (long) fldValue; }

    public long4 asLong4() { return (long) fldValue; }

    public long8 asLong8() { return (long) fldValue; }

    public float asFloat() { return (float) fldValue; }

    public float2 asFloat2() { return (float) fldValue; }

    public float4 asFloat4() { return (float) fldValue; }

    public float8 asFloat8() { return (float) fldValue; }

    public double asDouble() { return fldValue; }

    public double2 asDouble2() { return fldValue; }

    public double4 asDouble4() { return fldValue; }

    public double8 asDouble8() { return fldValue; }

    public real asReal() { return fldValue; }

    public int compareTo(Comparable anot) { return !(anot instanceof Double) ? INDEFINITE : compare(fldValue, ((Double) anot).fldValue); }

    public Double clone() { return new Double(fldValue); }

    public int kind { read = Class.DOUBLE }

    public double doubleValue { read = fldValue }
}