fuookami.ospf.kotlin.utils.math.NumericUInteger.kt Maven / Gradle / Ivy
package fuookami.ospf.kotlin.utils.math
import java.math.*
import kotlinx.serialization.*
import kotlinx.serialization.descriptors.*
import kotlinx.serialization.encoding.*
import fuookami.ospf.kotlin.utils.concept.*
import fuookami.ospf.kotlin.utils.operator.*
interface NumericUInteger
: NumericUIntegerNumber where Self : NumericUInteger, I : UIntegerNumber, I : NumberField {
override fun inc() = this + constants.one
override fun lg() = log(Flt64(10.0))
override fun ln() = log(Flt64.e)
override fun sqr() = pow(2)
override fun cub() = pow(3)
override fun sqrt() = pow(Flt64(1.0 / 2.0))
override fun cbrt() = pow(Flt64(1.0 / 3.0))
}
abstract class NumericUIntegerConstants(
private val ctor: (I) -> Self,
private val constants: RealNumberConstants
) : RealNumberConstants where Self : NumericUInteger, I : UIntegerNumber, I : NumberField {
override val zero: Self get() = ctor(constants.zero)
override val one: Self get() = ctor(constants.one)
override val two: Self get() = ctor(constants.two)
override val three: Self get() = ctor(constants.three)
override val five: Self get() = ctor(constants.five)
override val ten: Self get() = ctor(constants.ten)
override val minimum: Self get() = ctor(constants.minimum)
override val maximum: Self get() = ctor(constants.maximum)
}
data object NUInt8Serializer : KSerializer {
override val descriptor: SerialDescriptor = PrimitiveSerialDescriptor("NUInt8", PrimitiveKind.INT)
override fun serialize(encoder: Encoder, value: NUInt8) {
encoder.encodeInt(value.value.value.toInt())
}
override fun deserialize(decoder: Decoder): NUInt8 {
return NUInt8(UInt8(decoder.decodeInt().toUByte()))
}
}
@JvmInline
@Serializable(with = NUInt8Serializer::class)
value class NUInt8(val value: UInt8) : NumericUInteger, Copyable {
companion object : NumericUIntegerConstants(NUInt8::invoke, UInt8) {
operator fun invoke(value: UInt8) = NUInt8(value)
}
override val constants: RealNumberConstants get() = NUInt8
override fun copy(): NUInt8 = NUInt8(value)
override fun toString() = value.toString()
fun toString(radix: Int) = value.toString(radix)
override fun dec(): NUInt8 = NUInt8(value - UInt8.one)
override fun partialOrd(rhs: NUInt8) = orderOf(value.compareTo(rhs.value))
override fun partialEq(rhs: NUInt8) = (value.compareTo(rhs.value) == 0)
override fun reciprocal() = URtn8(UInt8.one, value)
override fun unaryMinus() = NInt8(-value.toInt8())
override fun abs() = NUInt8(value.abs())
override fun plus(rhs: NUInt8) = NUInt8(value + rhs.value)
override fun minus(rhs: NUInt8) = NInt8(value.toInt8() - rhs.toInt8())
override fun times(rhs: NUInt8) = NUInt8(value * rhs.value)
override fun div(rhs: NUInt8) = URtn8(value, rhs.value)
override fun rem(rhs: NUInt8) = NUInt8(value % rhs.value)
override fun intDiv(rhs: NUInt8) = NUInt8(value / rhs.value)
@Throws(IllegalArgumentException::class)
override fun log(base: FloatingNumber<*>): FloatingNumber<*>? = when (base) {
is Flt32 -> toFlt32().log(base)
is Flt64 -> toFlt64().log(base)
is FltX -> toFltX().log(base)
else -> throw IllegalArgumentException("Unknown argument type to NUInt8.log: ${base.javaClass}")
}
override fun pow(index: Int): URtn8 {
return if (index >= 1) {
URtn8(value.pow(index), UInt8.one)
} else if (index <= -1) {
URtn8(UInt8.one, value.pow(index))
} else {
URtn8.one
}
}
@Throws(IllegalArgumentException::class)
override fun pow(index: FloatingNumber<*>): FloatingNumber<*> = when (index) {
is Flt32 -> toFlt32().pow(index)
is Flt64 -> toFlt64().pow(index)
is FltX -> toFltX().pow(index)
else -> throw IllegalArgumentException("Unknown argument type to NUInt8.pow: ${index.javaClass}")
}
override fun exp() = toFlt64().exp()
override fun rangeTo(rhs: NUInt8) = NumericUIntegerRange(copy(), rhs, one, UInt8, UInt8::toNUInt8, NUInt8::toUInt8)
override infix fun until(rhs: NUInt8) = if (rhs == NUInt8.zero) {
rangeTo(NUInt8.zero)
} else {
rangeTo((rhs - NUInt8.one).toNUInt8())
}
override fun toInt8() = value.toInt8()
override fun toInt16() = value.toInt16()
override fun toInt32() = value.toInt32()
override fun toInt64() = value.toInt64()
override fun toIntX() = value.toIntX()
override fun toUInt8() = value.toUInt8()
override fun toUInt16() = value.toUInt16()
override fun toUInt32() = value.toUInt32()
override fun toUInt64() = value.toUInt64()
override fun toUIntX() = value.toUIntX()
override fun toFlt32() = value.toFlt32()
override fun toFlt64() = value.toFlt64()
override fun toFltX() = value.toFltX()
}
data object NUInt16Serializer : KSerializer {
override val descriptor: SerialDescriptor = PrimitiveSerialDescriptor("NUInt16", PrimitiveKind.INT)
override fun serialize(encoder: Encoder, value: NUInt16) {
encoder.encodeInt(value.value.value.toInt())
}
override fun deserialize(decoder: Decoder): NUInt16 {
return NUInt16(UInt16(decoder.decodeInt().toUShort()))
}
}
@JvmInline
@Serializable(with = NUInt16Serializer::class)
value class NUInt16(val value: UInt16) : NumericUInteger, Copyable {
companion object : NumericUIntegerConstants(NUInt16::invoke, UInt16) {
operator fun invoke(value: UInt16) = NUInt16(value)
}
override val constants: RealNumberConstants get() = NUInt16
override fun copy(): NUInt16 = NUInt16(value)
override fun toString() = value.toString()
fun toString(radix: Int) = value.toString(radix)
override fun dec(): NUInt16 = NUInt16(value - UInt16.one)
override fun partialOrd(rhs: NUInt16) = orderOf(value.compareTo(rhs.value))
override fun partialEq(rhs: NUInt16) = (value.compareTo(rhs.value) == 0)
override fun reciprocal() = URtn16(UInt16.one, value)
override fun unaryMinus() = NInt16(-value.toInt16())
override fun abs() = NUInt16(value.abs())
override fun plus(rhs: NUInt16) = NUInt16(value + rhs.value)
override fun minus(rhs: NUInt16) = NInt16(value.toInt16() - rhs.toInt16())
override fun times(rhs: NUInt16) = NUInt16(value * rhs.value)
override fun div(rhs: NUInt16) = URtn16(value, rhs.value)
override fun rem(rhs: NUInt16) = NUInt16(value % rhs.value)
override fun intDiv(rhs: NUInt16) = NUInt16(value / rhs.value)
@Throws(IllegalArgumentException::class)
override fun log(base: FloatingNumber<*>): FloatingNumber<*>? = when (base) {
is Flt32 -> toFlt32().log(base)
is Flt64 -> toFlt64().log(base)
is FltX -> toFltX().log(base)
else -> throw IllegalArgumentException("Unknown argument type to NUInt16.log: ${base.javaClass}")
}
override fun pow(index: Int): URtn16 {
return if (index >= 1) {
URtn16(value.pow(index), UInt16.one)
} else if (index <= -1) {
URtn16(UInt16.one, value.pow(index))
} else {
URtn16.one
}
}
@Throws(IllegalArgumentException::class)
override fun pow(index: FloatingNumber<*>): FloatingNumber<*> = when (index) {
is Flt32 -> toFlt32().pow(index)
is Flt64 -> toFlt64().pow(index)
is FltX -> toFltX().pow(index)
else -> throw IllegalArgumentException("Unknown argument type to NUInt16.pow: ${index.javaClass}")
}
override fun exp() = toFlt64().exp()
override fun rangeTo(rhs: NUInt16) =
NumericUIntegerRange(copy(), rhs, one, UInt16, UInt16::toNUInt16, NUInt16::toUInt16)
override infix fun until(rhs: NUInt16) = if (rhs == NUInt16.zero) {
rangeTo(NUInt16.zero)
} else {
rangeTo((rhs - NUInt16.one).toNUInt16())
}
override fun toInt8() = value.toInt8()
override fun toInt16() = value.toInt16()
override fun toInt32() = value.toInt32()
override fun toInt64() = value.toInt64()
override fun toIntX() = value.toIntX()
override fun toUInt8() = value.toUInt8()
override fun toUInt16() = value.toUInt16()
override fun toUInt32() = value.toUInt32()
override fun toUInt64() = value.toUInt64()
override fun toUIntX() = value.toUIntX()
override fun toFlt32() = value.toFlt32()
override fun toFlt64() = value.toFlt64()
override fun toFltX() = value.toFltX()
}
data object NUInt32Serializer : KSerializer {
override val descriptor: SerialDescriptor = PrimitiveSerialDescriptor("NUInt32", PrimitiveKind.INT)
override fun serialize(encoder: Encoder, value: NUInt32) {
encoder.encodeInt(value.value.value.toInt())
}
override fun deserialize(decoder: Decoder): NUInt32 {
return NUInt32(UInt32(decoder.decodeInt().toUInt()))
}
}
@JvmInline
@Serializable(with = NUInt32Serializer::class)
value class NUInt32(val value: UInt32) : NumericUInteger, Copyable {
companion object : NumericUIntegerConstants(NUInt32::invoke, UInt32) {
operator fun invoke(value: UInt32) = NUInt32(value)
}
override val constants: RealNumberConstants get() = NUInt32
override fun copy(): NUInt32 = NUInt32(value)
override fun toString() = value.toString()
fun toString(radix: Int) = value.toString(radix)
override fun dec(): NUInt32 = NUInt32(value - UInt32.one)
override fun partialOrd(rhs: NUInt32) = orderOf(value.compareTo(rhs.value))
override fun partialEq(rhs: NUInt32) = (value.compareTo(rhs.value) == 0)
override fun reciprocal() = URtn32(UInt32.one, value)
override fun unaryMinus() = NInt32(-value.toInt32())
override fun abs() = NUInt32(value.abs())
override fun plus(rhs: NUInt32) = NUInt32(value + rhs.value)
override fun minus(rhs: NUInt32) = NInt32(value.toInt32() - rhs.toInt32())
override fun times(rhs: NUInt32) = NUInt32(value * rhs.value)
override fun div(rhs: NUInt32) = URtn32(value, rhs.value)
override fun rem(rhs: NUInt32) = NUInt32(value % rhs.value)
override fun intDiv(rhs: NUInt32) = NUInt32(value / rhs.value)
@Throws(IllegalArgumentException::class)
override fun log(base: FloatingNumber<*>): FloatingNumber<*>? = when (base) {
is Flt32 -> toFlt32().log(base)
is Flt64 -> toFlt64().log(base)
is FltX -> toFltX().log(base)
else -> throw IllegalArgumentException("Unknown argument type to NUInt32.log: ${base.javaClass}")
}
override fun pow(index: Int): URtn32 {
return if (index >= 1) {
URtn32(value.pow(index), UInt32.one)
} else if (index <= -1) {
URtn32(UInt32.one, value.pow(index))
} else {
URtn32.one
}
}
@Throws(IllegalArgumentException::class)
override fun pow(index: FloatingNumber<*>): FloatingNumber<*> = when (index) {
is Flt32 -> toFlt32().pow(index)
is Flt64 -> toFlt64().pow(index)
is FltX -> toFltX().pow(index)
else -> throw IllegalArgumentException("Unknown argument type to NUInt32.pow: ${index.javaClass}")
}
override fun exp() = toFlt64().exp()
override fun rangeTo(rhs: NUInt32) =
NumericUIntegerRange(copy(), rhs, one, UInt32, UInt32::toNUInt32, NUInt32::toUInt32)
override infix fun until(rhs: NUInt32) = if (rhs == NUInt32.zero) {
rangeTo(NUInt32.zero)
} else {
rangeTo((rhs - NUInt32.one).toNUInt32())
}
override fun toInt8() = value.toInt8()
override fun toInt16() = value.toInt16()
override fun toInt32() = value.toInt32()
override fun toInt64() = value.toInt64()
override fun toIntX() = value.toIntX()
override fun toUInt8() = value.toUInt8()
override fun toUInt16() = value.toUInt16()
override fun toUInt32() = value.toUInt32()
override fun toUInt64() = value.toUInt64()
override fun toUIntX() = value.toUIntX()
override fun toFlt32() = value.toFlt32()
override fun toFlt64() = value.toFlt64()
override fun toFltX() = value.toFltX()
}
data object NUInt64Serializer : KSerializer {
override val descriptor: SerialDescriptor = PrimitiveSerialDescriptor("NUInt64", PrimitiveKind.LONG)
override fun serialize(encoder: Encoder, value: NUInt64) {
encoder.encodeLong(value.value.value.toLong())
}
override fun deserialize(decoder: Decoder): NUInt64 {
return NUInt64(UInt64(decoder.decodeLong().toULong()))
}
}
@JvmInline
@Serializable(with = NUInt64Serializer::class)
value class NUInt64(val value: UInt64) : NumericUInteger, Copyable {
companion object : NumericUIntegerConstants(NUInt64::invoke, UInt64) {
operator fun invoke(value: UInt64) = NUInt64(value)
}
override val constants: RealNumberConstants get() = NUInt64
override fun copy(): NUInt64 = NUInt64(value)
override fun toString() = value.toString()
fun toString(radix: Int) = value.toString(radix)
override fun dec(): NUInt64 = NUInt64(value - UInt64.one)
override fun partialOrd(rhs: NUInt64) = orderOf(value.compareTo(rhs.value))
override fun partialEq(rhs: NUInt64) = (value.compareTo(rhs.value) == 0)
override fun reciprocal() = URtn64(UInt64.one, value)
override fun unaryMinus() = NInt64(-value.toInt64())
override fun abs() = NUInt64(value.abs())
override fun plus(rhs: NUInt64) = NUInt64(value + rhs.value)
override fun minus(rhs: NUInt64) = NInt64(value.toInt64() - rhs.toInt64())
override fun times(rhs: NUInt64) = NUInt64(value * rhs.value)
override fun div(rhs: NUInt64) = URtn64(value, rhs.value)
override fun rem(rhs: NUInt64) = NUInt64(value % rhs.value)
override fun intDiv(rhs: NUInt64) = NUInt64(value / rhs.value)
@Throws(IllegalArgumentException::class)
override fun log(base: FloatingNumber<*>): FloatingNumber<*>? = when (base) {
is Flt32 -> toFlt64().log(base)
is Flt64 -> toFlt64().log(base)
is FltX -> toFltX().log(base)
else -> throw IllegalArgumentException("Unknown argument type to NUInt64.log: ${base.javaClass}")
}
override fun pow(index: Int): URtn64 {
return if (index >= 1) {
URtn64(value.pow(index), UInt64.one)
} else if (index <= -1) {
URtn64(UInt64.one, value.pow(index))
} else {
URtn64.one
}
}
@Throws(IllegalArgumentException::class)
override fun pow(index: FloatingNumber<*>): FloatingNumber<*> = when (index) {
is Flt32 -> toFlt64().pow(index)
is Flt64 -> toFlt64().pow(index)
is FltX -> toFltX().pow(index)
else -> throw IllegalArgumentException("Unknown argument type to NUInt64.pow: ${index.javaClass}")
}
override fun exp() = toFlt64().exp()
override fun rangeTo(rhs: NUInt64) =
NumericUIntegerRange(copy(), rhs, one, UInt64, UInt64::toNUInt64, NUInt64::toUInt64)
override infix fun until(rhs: NUInt64) = if (rhs == NUInt64.zero) {
rangeTo(NUInt64.zero)
} else {
rangeTo((rhs - NUInt64.one).toNUInt64())
}
override fun toInt8() = value.toInt8()
override fun toInt16() = value.toInt16()
override fun toInt32() = value.toInt32()
override fun toInt64() = value.toInt64()
override fun toIntX() = value.toIntX()
override fun toUInt8() = value.toUInt8()
override fun toUInt16() = value.toUInt16()
override fun toUInt32() = value.toUInt32()
override fun toUInt64() = value.toUInt64()
override fun toUIntX() = value.toUIntX()
override fun toFlt32() = value.toFlt32()
override fun toFlt64() = value.toFlt64()
override fun toFltX() = value.toFltX()
}
class NUIntXSerializer : KSerializer {
override val descriptor: SerialDescriptor = PrimitiveSerialDescriptor("NUIntX", PrimitiveKind.STRING)
override fun serialize(encoder: Encoder, value: NUIntX) {
encoder.encodeString(value.value.toString(10))
}
override fun deserialize(decoder: Decoder): NUIntX {
return NUIntX(UIntX(decoder.decodeString()))
}
}
@JvmInline
@Serializable(with = NUIntXSerializer::class)
value class NUIntX(val value: UIntX) : NumericUInteger, Copyable {
companion object : NumericUIntegerConstants(NUIntX::invoke, UIntX) {
operator fun invoke(value: UIntX) = NUIntX(value)
}
override val constants: RealNumberConstants get() = NUIntX
override fun copy(): NUIntX = NUIntX(value)
override fun toString() = value.toString()
fun toString(radix: Int) = value.toString(radix)
override fun dec(): NUIntX = NUIntX(value - UIntX.one)
override fun partialOrd(rhs: NUIntX) = orderOf(value.compareTo(rhs.value))
override fun partialEq(rhs: NUIntX) = (value.compareTo(rhs.value) == 0)
override fun reciprocal() = URtnX(UIntX.one, value)
override fun unaryMinus() = NIntX(-value.toIntX())
override fun abs() = NUIntX(value.abs())
override fun plus(rhs: NUIntX) = NUIntX(value + rhs.value)
override fun minus(rhs: NUIntX) = NIntX(value.toIntX() - rhs.toIntX())
override fun times(rhs: NUIntX) = NUIntX(value * rhs.value)
override fun div(rhs: NUIntX) = URtnX(value, rhs.value)
override fun rem(rhs: NUIntX) = NUIntX(value % rhs.value)
override fun intDiv(rhs: NUIntX) = NUIntX(value / rhs.value)
override fun sqr() = pow(2)
override fun cub() = pow(3)
@Throws(IllegalArgumentException::class)
override fun log(base: FloatingNumber<*>): FloatingNumber<*>? = when (base) {
is Flt32 -> toFltX().log(base)
is Flt64 -> toFltX().log(base)
is FltX -> toFltX().log(base)
else -> throw IllegalArgumentException("Unknown argument type to NUIntX.log: ${base.javaClass}")
}
override fun lg() = log(FltX(10.0))
override fun ln() = log(FltX.e)
override fun pow(index: Int): URtnX {
return if (index >= 1) {
URtnX(value.pow(index), UIntX.one)
} else if (index <= -1) {
URtnX(UIntX.one, value.pow(index))
} else {
URtnX.one
}
}
@Throws(IllegalArgumentException::class)
override fun pow(index: FloatingNumber<*>): FloatingNumber<*> = when (index) {
is Flt32 -> toFltX().pow(index)
is Flt64 -> toFltX().pow(index)
is FltX -> toFltX().pow(index)
else -> throw IllegalArgumentException("Unknown argument type to NUIntX.pow: ${index.javaClass}")
}
override fun sqrt() = pow(FltX(1.0 / 2.0))
override fun cbrt() = pow(FltX(1.0 / 3.0))
override fun exp() = toFltX().exp()
override fun rangeTo(rhs: NUIntX) = NumericUIntegerRange(copy(), rhs, one, UIntX, UIntX::toNUIntX, NUIntX::toUIntX)
override infix fun until(rhs: NUIntX) = if (rhs == NUIntX.zero) {
rangeTo(NUIntX.zero)
} else {
rangeTo((rhs - NUIntX.one).toNUIntX())
}
override fun toInt8() = value.toInt8()
override fun toInt16() = value.toInt16()
override fun toInt32() = value.toInt32()
override fun toInt64() = value.toInt64()
override fun toIntX() = value.toIntX()
override fun toUInt8() = value.toUInt8()
override fun toUInt16() = value.toUInt16()
override fun toUInt32() = value.toUInt32()
override fun toUInt64() = value.toUInt64()
override fun toUIntX() = value.toUIntX()
override fun toFlt32() = value.toFlt32()
override fun toFlt64() = value.toFlt64()
override fun toFltX() = value.toFltX()
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy