/*
Исходный код среды исполнения ПВТ-ОО.
Этот исходный код является частью проекта ПВТ-ОО.
Copyright © 2021 Малик Разработчик
Это свободная программа: вы можете перераспространять её и/или
изменять её на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
в каком она была опубликована Фондом свободного программного обеспечения;
либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
Эта программа распространяется в надежде, что она может быть полезна,
но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЁННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
общественной лицензии GNU.
Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
вместе с этой программой. Если это не так, см.
<http://www.gnu.org/licenses/>.
*/
package avt.lang;
public final class Double2(Object, Numeric, Cloneable)
{
public static final double2 MIN_VALUE = new double2 { Double.MIN_VALUE, Double.MIN_VALUE };
public static final double2 MAX_VALUE = new double2 { Double.MAX_VALUE, Double.MAX_VALUE };
/*<fold arithmetic>*/
public static boolean isNaN(double2 value) { return value != value; }
public static boolean isAllNaN(double2 value) { return (value |!=| value) == new int2 { -1, -1 }; }
public static boolean isInfinite(double2 value) {
return ((value |==| new double2 {
Double.POSITIVE_INFINITY, Double.POSITIVE_INFINITY
}) | (value |==| new double2 {
Double.NEGATIVE_INFINITY, Double.NEGATIVE_INFINITY
})) != 0;
}
public static boolean isAllInfinite(double2 value) {
return ((value |==| new double2 {
Double.POSITIVE_INFINITY, Double.POSITIVE_INFINITY
}) | (value |==| new double2 {
Double.NEGATIVE_INFINITY, Double.NEGATIVE_INFINITY
})) == new int2 { -1, -1 };
}
public static double2 max(double2 value0, double2 value1) {
return new double2 {
Double.max(value0[0], value1[0]), Double.max(value0[1], value1[1])
};
}
public static double2 min(double2 value0, double2 value1) {
return new double2 {
Double.min(value0[0], value1[0]), Double.min(value0[1], value1[1])
};
}
/*</fold>*/
/*<fold bit conversion>*/
public static native double2 setElement(double2 value, int index, double element);
public static native long2 toLong2Bits(double2 value);
/*</fold>*/
/*<fold valueOf>*/
public static Double2 valueOf(double2 value) { return new Double2(value); }
/*</fold>*/
private final double2 fldValue;
public (double2 value) { fldValue = value; }
public boolean equals(Object anot) { return anot == this || anot instanceof Double2 && toLong2Bits(fldValue) == toLong2Bits(((Double2) anot).fldValue); }
public long hashCodeAsLong() {
long2 value = toLong2Bits(fldValue);
return value[0] ^ value[1];
}
public long2 hashCodeAsLong2() { return toLong2Bits(fldValue); }
public boolean isNaN() { return isNaN(fldValue); }
public boolean isInfinite() { return isInfinite(fldValue); }
public byte2 asByte2() { return (byte2) fldValue; }
public byte4 asByte4() { return (byte2) fldValue; }
public byte8 asByte8() { return (byte2) fldValue; }
public short2 asShort2() { return (short2) fldValue; }
public short4 asShort4() { return (short2) fldValue; }
public short8 asShort8() { return (short2) fldValue; }
public int2 asInt2() { return (int2) fldValue; }
public int4 asInt4() { return (int2) fldValue; }
public int8 asInt8() { return (int2) fldValue; }
public long2 asLong2() { return (long2) fldValue; }
public long4 asLong4() { return (long2) fldValue; }
public long8 asLong8() { return (long2) fldValue; }
public float2 asFloat2() { return (float2) fldValue; }
public float4 asFloat4() { return (float2) fldValue; }
public float8 asFloat8() { return (float2) fldValue; }
public double2 asDouble2() { return fldValue; }
public double4 asDouble4() { return fldValue; }
public double8 asDouble8() { return fldValue; }
public real asReal() { return (double) fldValue; }
public Double2 clone() { return new Double2(fldValue); }
public int kind { read = Class.DOUBLE2 }
public double2 double2Value { read = fldValue }
}