All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.bixilon.kotlinglm.vec1.Vec1d.kt Maven / Gradle / Ivy

package de.bixilon.kotlinglm.vec1

import de.bixilon.kotlinglm.*
import de.bixilon.kotlinglm.vec1.operators.op_Vec1d
import de.bixilon.kotlinglm.vec2.Vec2bool
import de.bixilon.kotlinglm.vec2.Vec2t
import de.bixilon.kotlinglm.vec3.Vec3bool
import de.bixilon.kotlinglm.vec3.Vec3t
import de.bixilon.kotlinglm.vec4.Vec4bool
import de.bixilon.kotlinglm.vec4.Vec4t
import kool.*
import java.nio.*
import kotlin.math.abs

/**
 * Created by GBarbieri on 28.04.2017.
 */

class Vec1d(x: Double) : Vec1t(x), ToDoubleBuffer {

    // -- Implicit basic constructors --

    constructor() : this(0f)
    constructor(s: Number) : this(s.d)

    // -- Explicit basic constructors --
    // Explicit conversions (From section 5.4.1 Conversion and scalar constructors of GLSL 1.30.08 specification)

    constructor(v: Vec1t) : this(v.x)
    constructor(v: Vec2t) : this(v.x)
    constructor(v: Vec3t) : this(v.x)
    constructor(v: Vec4t) : this(v.x)

    constructor(v: Vec1bool) : this(v.x.d)
    constructor(v: Vec2bool) : this(v.x.d)
    constructor(v: Vec3bool) : this(v.x.d)
    constructor(v: Vec4bool) : this(v.x.d)

    constructor(bytes: ByteArray, index: Int = 0, oneByteOneDouble: Boolean = false, bigEndian: Boolean = true)
            : this(if (oneByteOneDouble) bytes[index].d else bytes.getDouble(index, bigEndian))

    constructor(chars: CharArray, index: Int = 0) : this(chars[index].d)
    constructor(shorts: ShortArray, index: Int = 0) : this(shorts[index])
    constructor(ints: IntArray, index: Int = 0) : this(ints[index])
    constructor(longs: LongArray, index: Int = 0) : this(longs[index])
    constructor(floats: FloatArray, index: Int = 0) : this(floats[index])
    constructor(doubles: DoubleArray, index: Int = 0) : this(doubles[index])
    constructor(booleans: BooleanArray, index: Int = 0) : this(booleans[index].d)

    constructor(numbers: Array, index: Int = 0) : this(numbers[index])
    constructor(chars: Array, index: Int = 0) : this(chars[index].d)
    constructor(booleans: Array, index: Int = 0) : this(booleans[index].d)

    constructor(list: List, index: Int = 0) : this() {
        put(list, index)
    }

    constructor(bytes: ByteBuffer, index: Int = bytes.pos, oneByteOneDouble: Boolean = false)
            : this(if (oneByteOneDouble) bytes[index].d else bytes.getDouble(index))

    constructor(chars: CharBuffer, index: Int = chars.pos) : this(chars[index].d)
    constructor(shorts: ShortBuffer, index: Int = shorts.pos) : this(shorts[index])
    constructor(ints: IntBuffer, index: Int = ints.pos) : this(ints[index])
    constructor(longs: LongBuffer, index: Int = longs.pos) : this(longs[index])
    constructor(floats: FloatBuffer, index: Int = floats.pos) : this(floats[index])
    constructor(doubles: DoubleBuffer, index: Int = doubles.pos) : this(doubles[index])

    constructor(block: (Int) -> Double) : this(block(0))
    constructor(ptr: DoublePtr) : this(ptr[0])


    fun set(bytes: ByteArray, index: Int = 0, oneByteOneDouble: Boolean = false, bigEndian: Boolean = true) {
        x = if (oneByteOneDouble) bytes[index].d else bytes.getDouble(index, bigEndian)
    }

    fun set(bytes: ByteBuffer, index: Int = bytes.pos, oneByteOneDouble: Boolean = false) {
        x = if (oneByteOneDouble) bytes[index].d else bytes.getDouble(index)
    }


    fun put(x: Double) {
        this.x = x
    }

    operator fun invoke(x: Double): Vec1d {
        this.x = x
        return this
    }

    override fun put(x: Number) {
        this.x = x.d
    }

    override operator fun invoke(x: Number): Vec1d {
        this.x = x.d
        return this
    }

    fun to(bytes: ByteArray, index: Int) = to(bytes, index, true)
    override fun to(bytes: ByteArray, index: Int, bigEndian: Boolean): ByteArray {
        bytes.putDouble(index, x)
        return bytes
    }

    override fun to(buf: ByteBuffer, offset: Int): ByteBuffer = buf.putDouble(offset, x)

    fun toDoubleArray(): DoubleArray = to(DoubleArray(length), 0)
    infix fun to(doubles: DoubleArray): DoubleArray = to(doubles, 0)
    fun to(doubles: DoubleArray, index: Int): DoubleArray {
        doubles[index] = x
        return doubles
    }

    override fun to(buf: DoubleBuffer, offset: Int): DoubleBuffer {
        buf[offset] = x
        return buf
    }

    // -- Unary arithmetic operators --

    operator fun unaryPlus() = this

    operator fun unaryMinus() = Vec1d(-x)

    // -- Increment main.and decrement operators --

    operator fun inc() = plus(Vec1d(), this, 1.0)

    infix fun inc(res: Vec1d) = plus(res, this, 1.0)
    fun incAssign() = plus(this, this, 1.0)


    operator fun dec() = minus(Vec1d(), this, 1.0)
    infix fun dec(res: Vec1d) = minus(res, this, 1.0)
    fun decAssign() = minus(this, this, 1.0)

    // -- Specific binary arithmetic operators --

    infix operator fun plus(b: Double) = plus(Vec1d(), this, b)
    infix operator fun plus(b: Vec1d) = plus(Vec1d(), this, b.x)

    fun plus(b: Double, res: Vec1d) = plus(res, this, b)
    fun plus(b: Vec1d, res: Vec1d) = plus(res, this, b.x)

    infix operator fun plusAssign(b: Double) {
        plus(this, this, b)
    }

    infix operator fun plusAssign(b: Vec1d) {
        plus(this, this, b.x)
    }


    infix operator fun minus(b: Double) = minus(Vec1d(), this, b)
    infix operator fun minus(b: Vec1d) = minus(Vec1d(), this, b.x)

    fun minus(b: Double, res: Vec1d) = minus(res, this, b)
    fun minus(b: Vec1d, res: Vec1d) = minus(res, this, b.x)

    infix operator fun minusAssign(b: Double) {
        minus(this, this, b)
    }

    infix operator fun minusAssign(b: Vec1d) {
        minus(this, this, b.x)
    }


    infix operator fun times(b: Double) = times(Vec1d(), this, b)
    infix operator fun times(b: Vec1d) = times(Vec1d(), this, b.x)

    fun times(b: Double, res: Vec1d) = times(res, this, b)
    fun times(b: Vec1d, res: Vec1d) = times(res, this, b.x)

    infix operator fun timesAssign(b: Double) {
        times(this, this, b)
    }

    infix operator fun timesAssign(b: Vec1d) {
        times(this, this, b.x)
    }


    infix operator fun div(b: Double) = div(Vec1d(), this, b)
    infix operator fun div(b: Vec1d) = div(Vec1d(), this, b.x)

    fun div(b: Double, res: Vec1d) = div(res, this, b)
    fun div(b: Vec1d, res: Vec1d) = div(res, this, b.x)

    infix operator fun divAssign(b: Double) {
        div(this, this, b)
    }

    infix operator fun divAssign(b: Vec1d) {
        div(this, this, b.x)
    }


    infix operator fun rem(b: Double) = rem(Vec1d(), this, b)
    infix operator fun rem(b: Vec1d) = rem(Vec1d(), this, b.x)

    fun rem(b: Double, res: Vec1d) = rem(res, this, b)
    fun rem(b: Vec1d, res: Vec1d) = rem(res, this, b.x)

    infix operator fun remAssign(b: Double) {
        rem(this, this, b)
    }

    infix operator fun remAssign(b: Vec1d) {
        rem(this, this, b.x)
    }


    // -- Generic binary arithmetic operators --

    infix operator fun plus(b: Number) = plus(Vec1d(), this, b.d)
    infix operator fun plus(b: Vec1t) = plus(Vec1d(), this, b.x.d)

    fun plus(b: Number, res: Vec1d) = plus(res, this, b.d)
    fun plus(b: Vec1t, res: Vec1d) = plus(res, this, b.x.d)

    infix operator fun plusAssign(b: Number) {
        plus(this, this, b.d)
    }

    infix operator fun plusAssign(b: Vec1t) {
        plus(this, this, b.x.d)
    }


    infix operator fun minus(b: Number) = minus(Vec1d(), this, b.d)
    infix operator fun minus(b: Vec1t) = minus(Vec1d(), this, b.x.d)

    fun minus(b: Number, res: Vec1d) = minus(res, this, b.d)
    fun minus(b: Vec1t, res: Vec1d) = minus(res, this, b.x.d)

    infix operator fun minusAssign(b: Number) {
        minus(this, this, b.d)
    }

    infix operator fun minusAssign(b: Vec1t) {
        minus(this, this, b.x.d)
    }


    infix operator fun times(b: Number) = times(Vec1d(), this, b.d)
    infix operator fun times(b: Vec1t) = times(Vec1d(), this, b.x.d)

    fun times(b: Number, res: Vec1d) = times(res, this, b.d)
    fun times(b: Vec1t, res: Vec1d) = times(res, this, b.x.d)

    infix operator fun timesAssign(b: Number) {
        times(this, this, b.d)
    }

    infix operator fun timesAssign(b: Vec1t) {
        times(this, this, b.x.d)
    }


    infix operator fun div(b: Number) = div(Vec1d(), this, b.d)
    infix operator fun div(b: Vec1t) = div(Vec1d(), this, b.x.d)

    fun div(b: Number, res: Vec1d) = div(res, this, b.d)
    fun div(b: Vec1t, res: Vec1d) = div(res, this, b.x.d)

    infix operator fun divAssign(b: Number) {
        div(this, this, b.d)
    }

    infix operator fun divAssign(b: Vec1t) {
        div(this, this, b.x.d)
    }


    infix operator fun rem(b: Number) = rem(Vec1d(), this, b.d)
    infix operator fun rem(b: Vec1t) = rem(Vec1d(), this, b.x.d)

    fun rem(b: Number, res: Vec1d) = rem(res, this, b.d)
    fun rem(b: Vec1t, res: Vec1d) = rem(res, this, b.x.d)

    infix operator fun remAssign(b: Number) {
        rem(this, this, b.d)
    }

    infix operator fun remAssign(b: Vec1t) {
        rem(this, this, b.x.d)
    }


    companion object : op_Vec1d {
        const val length = Vec1t.length
        @JvmField
        val size = length * Double.BYTES
    }

    override fun size() = size

    override fun elementCount() = length

    override fun equals(other: Any?) = other is Vec1d && this[0] == other[0]
    fun equal(b: Vec1d, epsilon: Double = GLM.ε): Boolean = abs(x - b.x) <= epsilon
    fun notEqual(b: Vec1d, epsilon: Double = GLM.ε): Boolean = !equal(b, epsilon)

    override fun hashCode() = x.hashCode()
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy