de.bixilon.kotlinglm.vec4.Vec4d.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kotlin-glm Show documentation
Show all versions of kotlin-glm Show documentation
Kotlin port of OpenGL Mathematics (GLM)
package de.bixilon.kotlinglm.vec4
import de.bixilon.kotlinglm.*
import de.bixilon.kotlinglm.vec1.Vec1bool
import de.bixilon.kotlinglm.vec1.Vec1t
import de.bixilon.kotlinglm.vec2.Vec2bool
import de.bixilon.kotlinglm.vec2.Vec2d
import de.bixilon.kotlinglm.vec2.Vec2t
import de.bixilon.kotlinglm.vec3.Vec3bool
import de.bixilon.kotlinglm.vec3.Vec3d
import de.bixilon.kotlinglm.vec3.Vec3t
import de.bixilon.kotlinglm.vec4.operators.op_Vec4d
import de.bixilon.kotlinkool.*
import org.lwjgl.system.MemoryUtil.memGetDouble
import org.lwjgl.system.MemoryUtil.memPutDouble
import java.awt.Color
import java.io.InputStream
import java.io.PrintStream
import java.nio.*
import kotlin.math.abs
/**
* Created by elect on 09/10/16.
*/
class Vec4d(var ofs: Int, var array: DoubleArray) : Vec4t(), ToDoubleBuffer {
override var x: Double
get() = array[ofs]
set(value) = array.set(ofs, value)
override var y: Double
get() = array[ofs + 1]
set(value) = array.set(ofs + 1, value)
override var z: Double
get() = array[ofs + 2]
set(value) = array.set(ofs + 2, value)
override var w: Double
get() = array[ofs + 3]
set(value) = array.set(ofs + 3, value)
// -- Implicit basic constructors --
constructor() : this(0)
constructor(v: Vec4d) : this(v.x, v.y, v.z, v.w)
constructor(v: Vec3d) : this(v.x, v.y, v.z, 0.0)
constructor(v: Vec2d) : this(v.x, v.y, 0.0, 0.0)
// -- Explicit basic constructors --
constructor(x: Double) : this(x, x, x, x)
constructor(x: Double, y: Double, z: Double, w: Double) : this(0, doubleArrayOf(x, y, z, w))
// -- Conversion scalar constructors --
constructor(v: Vec1t) : this(v.x, v.x, v.x, v.x)
// Explicit conversions (From section 5.4.1 Conversion and scalar constructors of GLSL 1.30.08 specification)
constructor(x: Number) : this(x, x, x, x)
constructor(x: Number, y: Number, z: Number, w: Number) : this(x.d, y.d, z.d, w.d)
constructor(x: Vec1t, y: Number, z: Number, w: Number) : this(x.x, y, z, w)
constructor(x: Number, y: Vec1t, z: Number, w: Number) : this(x, y.x, z, w)
constructor(x: Vec1t, y: Vec1t, z: Number, w: Number) : this(x.x, y.x, z, w)
constructor(x: Number, y: Number, z: Vec1t, w: Number) : this(x, y, z.x, w)
constructor(x: Vec1t, y: Number, z: Vec1t, w: Number) : this(x.x, y, z.x, w)
constructor(x: Number, y: Vec1t, z: Vec1t, w: Number) : this(x, y.x, z.x, w)
constructor(x: Vec1t, y: Vec1t, z: Vec1t, w: Number) : this(x.x, y.x, z.x, w)
constructor(x: Vec1t, y: Number, z: Number, w: Vec1t) : this(x.x, y, z, w.x)
constructor(x: Number, y: Vec1t, z: Number, w: Vec1t) : this(x, y.x, z, w.x)
constructor(x: Vec1t, y: Vec1t, z: Number, w: Vec1t) : this(x.x, y.x, z, w.x)
constructor(x: Number, y: Number, z: Vec1t, w: Vec1t) : this(x, y, z.x, w.x)
constructor(x: Vec1t, y: Number, z: Vec1t, w: Vec1t) : this(x.x, y, z.x, w.x)
constructor(x: Number, y: Vec1t, z: Vec1t, w: Vec1t) : this(x, y.x, z.x, w.x)
constructor(x: Vec1t, y: Vec1t, z: Vec1t, w: Vec1t) : this(x.x, y.x, z.x, w.x)
constructor(xy: Vec2t, z: Number, w: Number) : this(xy.x, xy.y, z, w)
constructor(xy: Vec2t, z: Vec1t, w: Number) : this(xy.x, xy.y, z.x, w)
constructor(xy: Vec2t, z: Number, w: Vec1t) : this(xy.x, xy.y, z, w.x)
constructor(xy: Vec2t, z: Vec1t, w: Vec1t) : this(xy.x, xy.y, z.x, w.x)
constructor(x: Number, yz: Vec2t, w: Number) : this(x, yz.x, yz.y, w)
constructor(x: Vec1t, yz: Vec2t, w: Number) : this(x.x, yz.x, yz.y, w)
constructor(x: Number, yz: Vec2t, w: Vec1t) : this(x, yz.x, yz.y, w.x)
constructor(x: Vec1t, yz: Vec2t, w: Vec1t) : this(x.x, yz.x, yz.y, w.x)
constructor(x: Number, y: Number, zw: Vec2t) : this(x, y, zw.x, zw.y)
constructor(x: Vec1t, y: Number, zw: Vec2t) : this(x.x, y, zw.x, zw.y)
constructor(x: Number, y: Vec1t, zw: Vec2t) : this(x, y, zw.x, zw.y)
constructor(x: Vec1t, y: Vec1t, zw: Vec2t) : this(x.x, y.x, zw.x, zw.y)
constructor(xyz: Vec3t, w: Number) : this(xyz.x, xyz.y, xyz.z, w)
constructor(xyz: Vec3t, w: Vec1t) : this(xyz.x, xyz.y, xyz.z, w.x)
constructor(x: Number, yzw: Vec3t) : this(x, yzw.x, yzw.y, yzw.z)
constructor(x: Vec1t, yzw: Vec3t) : this(x.x, yzw.x, yzw.y, yzw.z)
constructor(xy: Vec2t, zw: Vec2t) : this(xy.x, xy.y, zw.x, zw.y)
constructor(v: Vec4t) : this(v.x, v.y, v.z, v.w)
constructor(v: Vec1bool) : this(v.x.d, 0, 0, 1)
constructor(v: Vec2bool) : this(v.x.d, v.y.d, 0, 1)
constructor(v: Vec3bool) : this(v.x.d, v.y.d, v.z.d, 1)
constructor(v: Vec4bool) : this(v.x.d, v.y.d, v.z.d, v.w.d)
constructor(bytes: ByteArray, index: Int = 0, oneByteOneDouble: Boolean = false, bigEndian: Boolean = true) : this(
if (oneByteOneDouble) bytes[index].d else bytes.getDouble(index, bigEndian),
if (oneByteOneDouble) bytes[index + 1].d else bytes.getDouble(index + Double.BYTES, bigEndian),
if (oneByteOneDouble) bytes[index + 2].d else bytes.getDouble(index + Double.BYTES * 2, bigEndian),
if (oneByteOneDouble) bytes[index + 3].d else bytes.getDouble(index + Double.BYTES * 3, bigEndian))
constructor(chars: CharArray, index: Int = 0) : this(chars[index].d, chars[index + 1].d, chars[index + 2].d, chars[index + 3].d)
constructor(shorts: ShortArray, index: Int = 0) : this(shorts[index], shorts[index + 1], shorts[index + 2], shorts[index + 3])
constructor(ints: IntArray, index: Int = 0) : this(ints[index], ints[index + 1], ints[index + 2], ints[index + 3])
constructor(longs: LongArray, index: Int = 0) : this(longs[index], longs[index + 1], longs[index + 2], longs[index + 3])
constructor(floats: FloatArray, index: Int = 0) : this(floats[index], floats[index + 1], floats[index + 2], floats[index + 3])
constructor(doubles: DoubleArray, index: Int = 0) : this(doubles[index], doubles[index + 1], doubles[index + 2], doubles[index + 3])
constructor(booleans: BooleanArray, index: Int = 0) : this(booleans[index].d, booleans[index + 1].d, booleans[index + 2].d, booleans[index + 3].d)
constructor(numbers: Array, index: Int = 0) : this(numbers[index], numbers[index + 1], numbers[index + 2], numbers[index + 3])
constructor(chars: Array, index: Int = 0) : this(chars[index].d, chars[index + 1].d, chars[index + 2].d, chars[index + 3].d)
constructor(booleans: Array, index: Int = 0) : this(booleans[index].d, booleans[index + 1].d, booleans[index + 2].d, booleans[index + 3].d)
constructor(list: Iterable<*>, index: Int = 0) : this(list.elementAt(index)!!.toDouble, list.elementAt(index + 1)!!.toDouble,
list.elementAt(index + 2)!!.toDouble, list.elementAt(index + 3)!!.toDouble)
constructor(bytes: ByteBuffer, index: Int = bytes.pos, oneByteOneDouble: Boolean = false) : this(
if (oneByteOneDouble) bytes[index].d else bytes.getDouble(index),
if (oneByteOneDouble) bytes[index + 1].d else bytes.getDouble(index + Double.BYTES),
if (oneByteOneDouble) bytes[index + 2].d else bytes.getDouble(index + Double.BYTES * 2),
if (oneByteOneDouble) bytes[index + 3].d else bytes.getDouble(index + Double.BYTES * 3))
constructor(chars: CharBuffer, index: Int = chars.pos) : this(chars[index].d, chars[index + 1].d, chars[index + 2].d, chars[index + 3].d)
constructor(shorts: ShortBuffer, index: Int = shorts.pos) : this(shorts[index], shorts[index + 1], shorts[index + 2], shorts[index + 3])
constructor(ints: IntBuffer, index: Int = ints.pos) : this(ints[index], ints[index + 1], ints[index + 2], ints[index + 3])
constructor(longs: LongBuffer, index: Int = longs.pos) : this(longs[index], longs[index + 1], longs[index + 2], longs[index + 3])
constructor(floats: FloatBuffer, index: Int = floats.pos) : this(floats[index], floats[index + 1], floats[index + 2], floats[index + 3])
constructor(doubles: DoubleBuffer, index: Int = doubles.pos) : this(doubles[index], doubles[index + 1], doubles[index + 2], doubles[index + 3])
constructor(block: (Int) -> Double) : this(block(0), block(1), block(2), block(3))
constructor(ptr: DoublePtr) : this(ptr[0], ptr[1], ptr[2], ptr[3])
constructor(inputStream: InputStream, bigEndian: Boolean = true) :
this(inputStream.double(bigEndian), inputStream.double(bigEndian), inputStream.double(bigEndian), inputStream.double(bigEndian))
constructor(color: Color) : this(color.red / 255.0, color.green / 255.0, color.blue / 255.0, color.alpha / 255.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)
y = if (oneByteOneDouble) bytes[index + 1].d else bytes.getDouble(index + Double.BYTES, bigEndian)
z = if (oneByteOneDouble) bytes[index + 2].d else bytes.getDouble(index + Double.BYTES * 2, bigEndian)
w = if (oneByteOneDouble) bytes[index + 3].d else bytes.getDouble(index + Double.BYTES * 3, bigEndian)
}
fun set(bytes: ByteBuffer, index: Int = bytes.pos, oneByteOneDouble: Boolean = false) {
x = if (oneByteOneDouble) bytes[index].d else bytes.getDouble(index)
y = if (oneByteOneDouble) bytes[index + 1].d else bytes.getDouble(index + Double.BYTES)
z = if (oneByteOneDouble) bytes[index + 2].d else bytes.getDouble(index + Double.BYTES * 2)
w = if (oneByteOneDouble) bytes[index + 3].d else bytes.getDouble(index + Double.BYTES * 3)
}
fun put(x: Double, y: Double, z: Double, w: Double) {
this.x = x
this.y = y
this.z = z
this.w = w
}
operator fun invoke(x: Double, y: Double, z: Double, w: Double): Vec4d {
this.x = x
this.y = y
this.z = z
this.w = w
return this
}
override fun put(x: Number, y: Number, z: Number, w: Number) {
this.x = x.d
this.y = y.d
this.z = z.d
this.w = w.d
}
override operator fun invoke(x: Number, y: Number, z: Number, w: Number): Vec4d {
this.x = x.d
this.y = y.d
this.z = z.d
this.w = w.d
return this
}
fun to(bytes: ByteArray, index: Int): ByteArray = to(bytes, index, true)
override fun to(bytes: ByteArray, index: Int, bigEndian: Boolean): ByteArray {
bytes.putDouble(index, x, bigEndian)
bytes.putDouble(index + Double.BYTES, y, bigEndian)
bytes.putDouble(index + Double.BYTES * 2, z, bigEndian)
bytes.putDouble(index + Double.BYTES * 3, w, bigEndian)
return bytes
}
fun toDoubleArray(): DoubleArray = to(DoubleArray(length), 0)
infix fun to(doubles: DoubleArray): DoubleArray = to(doubles, 0)
fun to(doubles: DoubleArray, index: Int): DoubleArray {
System.arraycopy(array, ofs, doubles, index, length)
return doubles
}
override fun to(buf: ByteBuffer, offset: Int): ByteBuffer {
buf.putDouble(offset, x)
buf.putDouble(offset + Double.BYTES, y)
buf.putDouble(offset + Double.BYTES * 2, z)
buf.putDouble(offset + Double.BYTES * 3, w)
return buf
}
override fun to(buf: DoubleBuffer, offset: Int): DoubleBuffer {
buf[offset] = x
buf[offset + 1] = y
buf[offset + 2] = z
buf[offset + 3] = w
return buf
}
infix fun to(ptr: Ptr) {
memPutDouble(ptr, x)
memPutDouble(ptr + Double.BYTES, y)
memPutDouble(ptr + Double.BYTES * 2, z)
memPutDouble(ptr + Double.BYTES * 3, w)
}
// -- Component accesses --
operator fun set(index: Int, value: Double) = when (index) {
0 -> x = value
1 -> y = value
2 -> z = value
3 -> w = value
else -> throw ArrayIndexOutOfBoundsException()
}
override operator fun set(index: Int, value: Number) = when (index) {
0 -> x = value.d
1 -> y = value.d
2 -> z = value.d
3 -> w = value.d
else -> throw ArrayIndexOutOfBoundsException()
}
// -- Unary arithmetic operators --
operator fun unaryPlus() = this
operator fun unaryMinus() = Vec4d(-x, -y, -z, -w)
// -- Increment main.and decrement operators --
operator fun inc(res: Vec4d = Vec4d()) = plus(res, this, 1.0, 1.0, 1.0, 1.0)
fun incAssign() = plus(this, this, 1.0, 1.0, 1.0, 1.0)
operator fun dec(res: Vec4d = Vec4d()) = minus(res, this, 1.0, 1.0, 1.0, 1.0)
fun decAssign() = minus(this, this, 1.0, 1.0, 1.0, 1.0)
// -- Specific binary arithmetic operators --
operator fun plus(b: Double) = plus(Vec4d(), this, b, b, b, b)
operator fun plus(b: Vec4d) = plus(Vec4d(), this, b.x, b.y, b.z, b.w)
fun plus(bX: Double, bY: Double, bZ: Double, bW: Double, res: Vec4d = Vec4d()) = plus(res, this, bX, bY, bZ, bW)
fun plus(b: Double, res: Vec4d = Vec4d()) = plus(res, this, b, b, b, b)
fun plus(b: Vec4d, res: Vec4d = Vec4d()) = plus(res, this, b.x, b.y, b.z, b.w)
fun plusAssign(bX: Double, bY: Double, bZ: Double, bW: Double) = plus(this, this, bX, bY, bZ, bW)
infix operator fun plusAssign(b: Double) {
plus(this, this, b, b, b, b)
}
infix operator fun plusAssign(b: Vec4d) {
plus(this, this, b.x, b.y, b.z, b.w)
}
operator fun minus(b: Double) = minus(Vec4d(), this, b, b, b, b)
operator fun minus(b: Vec4d) = minus(Vec4d(), this, b.x, b.y, b.z, b.w)
fun minus(bX: Double, bY: Double, bZ: Double, bW: Double, res: Vec4d = Vec4d()) = minus(res, this, bX, bY, bZ, bW)
fun minus(b: Double, res: Vec4d = Vec4d()) = minus(res, this, b, b, b, b)
fun minus(b: Vec4d, res: Vec4d = Vec4d()) = minus(res, this, b.x, b.y, b.z, b.w)
fun minusAssign(bX: Double, bY: Double, bZ: Double, bW: Double) = minus(this, this, bX, bY, bZ, bW)
infix operator fun minusAssign(b: Double) {
minus(this, this, b, b, b, b)
}
infix operator fun minusAssign(b: Vec4d) {
minus(this, this, b.x, b.y, b.z, b.w)
}
operator fun times(b: Double) = times(Vec4d(), this, b, b, b, b)
operator fun times(b: Vec4d) = times(Vec4d(), this, b.x, b.y, b.z, b.w)
fun times(bX: Double, bY: Double, bZ: Double, bW: Double, res: Vec4d = Vec4d()) = times(res, this, bX, bY, bZ, bW)
fun times(b: Double, res: Vec4d = Vec4d()) = times(res, this, b, b, b, b)
fun times(b: Vec4d, res: Vec4d = Vec4d()) = times(res, this, b.x, b.y, b.z, b.w)
fun timesAssign(bX: Double, bY: Double, bZ: Double, bW: Double) = times(this, this, bX, bY, bZ, bW)
infix operator fun timesAssign(b: Double) {
times(this, this, b, b, b, b)
}
infix operator fun timesAssign(b: Vec4d) {
times(this, this, b.x, b.y, b.z, b.w)
}
operator fun div(b: Double) = div(Vec4d(), this, b, b, b, b)
operator fun div(b: Vec4d) = div(Vec4d(), this, b.x, b.y, b.z, b.w)
fun div(bX: Double, bY: Double, bZ: Double, bW: Double, res: Vec4d = Vec4d()) = div(res, this, bX, bY, bZ, bW)
fun div(b: Double, res: Vec4d = Vec4d()) = div(res, this, b, b, b, b)
fun div(b: Vec4d, res: Vec4d = Vec4d()) = div(res, this, b.x, b.y, b.z, b.w)
fun divAssign(bX: Double, bY: Double, bZ: Double, bW: Double) = div(this, this, bX, bY, bZ, bW)
infix operator fun divAssign(b: Double) {
div(this, this, b, b, b, b)
}
infix operator fun divAssign(b: Vec4d) {
div(this, this, b.x, b.y, b.z, b.w)
}
operator fun rem(b: Double) = rem(Vec4d(), this, b, b, b, b)
operator fun rem(b: Vec4d) = rem(Vec4d(), this, b.x, b.y, b.z, b.w)
fun rem(bX: Double, bY: Double, bZ: Double, bW: Double, res: Vec4d = Vec4d()) = rem(res, this, bX, bY, bZ, bW)
fun rem(b: Double, res: Vec4d = Vec4d()) = rem(res, this, b, b, b, b)
fun rem(b: Vec4d, res: Vec4d = Vec4d()) = rem(res, this, b.x, b.y, b.z, b.w)
fun remAssign(bX: Double, bY: Double, bZ: Double, bW: Double) = rem(this, this, bX, bY, bZ, bW)
infix operator fun remAssign(b: Double) {
rem(this, this, b, b, b, b)
}
infix operator fun remAssign(b: Vec4d) {
rem(this, this, b.x, b.y, b.z, b.w)
}
// -- Generic binary arithmetic operators --
operator fun plus(b: Number) = plus(Vec4d(), this, b.d, b.d, b.d, b.d)
operator fun plus(b: Vec4t) = plus(Vec4d(), this, b.x.d, b.y.d, b.z.d, b.w.d)
fun plus(bX: Number, bY: Number, bZ: Number, bW: Number, res: Vec4d = Vec4d()) = plus(res, this, bX.d, bY.d, bZ.d, bW.d)
fun plus(b: Number, res: Vec4d = Vec4d()) = plus(res, this, b.d, b.d, b.d, b.d)
fun plus(b: Vec4t, res: Vec4d = Vec4d()) = plus(res, this, b.x.d, b.y.d, b.z.d, b.w.d)
fun plusAssign(bX: Number, bY: Number, bZ: Number, bW: Number) = plus(this, this, bX.d, bY.d, bZ.d, bW.d)
infix operator fun plusAssign(b: Number) {
plus(this, this, b.d, b.d, b.d, b.d)
}
infix operator fun plusAssign(b: Vec4t) {
plus(this, this, b.x.d, b.y.d, b.z.d, b.w.d)
}
operator fun minus(b: Number) = minus(Vec4d(), this, b.d, b.d, b.d, b.d)
operator fun minus(b: Vec4t) = minus(Vec4d(), this, b.x.d, b.y.d, b.z.d, b.w.d)
fun minus(bX: Number, bY: Number, bZ: Number, bW: Number, res: Vec4d = Vec4d()) = minus(res, this, bX.d, bY.d, bZ.d, bW.d)
fun minus(b: Number, res: Vec4d = Vec4d()) = minus(res, this, b.d, b.d, b.d, b.d)
fun minus(b: Vec4t, res: Vec4d = Vec4d()) = minus(res, this, b.x.d, b.y.d, b.z.d, b.w.d)
fun minusAssign(bX: Number, bY: Number, bZ: Number, bW: Number) = minus(this, this, bX.d, bY.d, bZ.d, bW.d)
infix operator fun minusAssign(b: Number) {
minus(this, this, b.d, b.d, b.d, b.d)
}
infix operator fun minusAssign(b: Vec4t) {
minus(this, this, b.x.d, b.y.d, b.z.d, b.w.d)
}
operator fun times(b: Number) = times(Vec4d(), this, b.d, b.d, b.d, b.d)
operator fun times(b: Vec4t) = times(Vec4d(), this, b.x.d, b.y.d, b.z.d, b.w.d)
fun times(bX: Number, bY: Number, bZ: Number, bW: Number, res: Vec4d = Vec4d()) = times(res, this, bX.d, bY.d, bZ.d, bW.d)
fun times(b: Number, res: Vec4d = Vec4d()) = times(res, this, b.d, b.d, b.d, b.d)
fun times(b: Vec4t, res: Vec4d = Vec4d()) = times(res, this, b.x.d, b.y.d, b.z.d, b.w.d)
fun timesAssign(bX: Number, bY: Number, bZ: Number, bW: Number) = times(this, this, bX.d, bY.d, bZ.d, bW.d)
infix operator fun timesAssign(b: Number) {
times(this, this, b.d, b.d, b.d, b.d)
}
infix operator fun timesAssign(b: Vec4t) {
times(this, this, b.x.d, b.y.d, b.z.d, b.w.d)
}
operator fun div(b: Number) = div(Vec4d(), this, b.d, b.d, b.d, b.d)
operator fun div(b: Vec4t) = div(Vec4d(), this, b.x.d, b.y.d, b.z.d, b.w.d)
fun div(bX: Number, bY: Number, bZ: Number, bW: Number, res: Vec4d = Vec4d()) = div(res, this, bX.d, bY.d, bZ.d, bW.d)
fun div(b: Number, res: Vec4d = Vec4d()) = div(res, this, b.d, b.d, b.d, b.d)
fun div(b: Vec4t, res: Vec4d = Vec4d()) = div(res, this, b.x.d, b.y.d, b.z.d, b.w.d)
fun divAssign(bX: Number, bY: Number, bZ: Number, bW: Number) = div(this, this, bX.d, bY.d, bZ.d, bW.d)
infix operator fun divAssign(b: Number) {
div(this, this, b.d, b.d, b.d, b.d)
}
infix operator fun divAssign(b: Vec4t) {
div(this, this, b.x.d, b.y.d, b.z.d, b.w.d)
}
operator fun rem(b: Number) = rem(Vec4d(), this, b.d, b.d, b.d, b.d)
operator fun rem(b: Vec4t) = rem(Vec4d(), this, b.x.d, b.y.d, b.z.d, b.w.d)
fun rem(bX: Number, bY: Number, bZ: Number, bW: Number, res: Vec4d = Vec4d()) = rem(res, this, bX.d, bY.d, bZ.d, bW.d)
fun rem(b: Number, res: Vec4d = Vec4d()) = rem(res, this, b.d, b.d, b.d, b.d)
fun rem(b: Vec4t, res: Vec4d = Vec4d()) = rem(res, this, b.x.d, b.y.d, b.z.d, b.w.d)
fun remAssign(bX: Number, bY: Number, bZ: Number, bW: Number) = rem(this, this, bX.d, bY.d, bZ.d, bW.d)
infix operator fun remAssign(b: Number) {
rem(this, this, b.d, b.d, b.d, b.d)
}
infix operator fun remAssign(b: Vec4t) {
rem(this, this, b.x.d, b.y.d, b.z.d, b.w.d)
}
infix fun allLessThan(d: Double): Boolean = x < d && y < d && z < d && w < d
infix fun anyLessThan(d: Double): Boolean = x < d || y < d || z < d || w < d
infix fun lessThan(d: Double): Vec4bool = Vec4bool { get(it) < d }
infix fun allLessThanEqual(d: Double): Boolean = x <= d && y <= d && z <= d && w <= d
infix fun anyLessThanEqual(d: Double): Boolean = x <= d || y <= d || z <= d || w <= d
infix fun lessThanEqual(d: Double): Vec4bool = Vec4bool { get(it) <= d }
fun allEqual(d: Double, epsilon: Double = GLM.ε): Boolean = abs(x - d) < epsilon && abs(y - d) < epsilon && abs(z - d) < epsilon && abs(w - d) < epsilon
fun anyEqual(d: Double, epsilon: Double = GLM.ε): Boolean = abs(x - d) < epsilon || abs(y - d) < epsilon || abs(z - d) < epsilon || abs(w - d) < epsilon
fun equal(d: Double, epsilon: Double = GLM.ε): Vec4bool = Vec4bool { abs(get(it) - d) < epsilon }
fun allNotEqual(d: Double, epsilon: Double = GLM.ε): Boolean = abs(x - d) >= epsilon && abs(y - d) >= epsilon && abs(z - d) >= epsilon && abs(w - d) >= epsilon
fun anyNotEqual(d: Double, epsilon: Double = GLM.ε): Boolean = abs(x - d) >= epsilon || abs(y - d) >= epsilon || abs(z - d) >= epsilon || abs(w - d) >= epsilon
fun notEqual(d: Double, epsilon: Double = GLM.ε): Vec4bool = Vec4bool{ abs(get(it) - d) >= epsilon }
infix fun allGreaterThan(d: Double): Boolean = x > d && y > d && z > d && w > d
infix fun anyGreaterThan(d: Double): Boolean = x > d || y > d || z > d || w > d
infix fun greaterThan(d: Double): Vec4bool = Vec4bool{ get(it) > d }
infix fun allGreaterThanEqual(d: Double): Boolean = x >= d && y >= d && z >= d && w >= d
infix fun anyGreaterThanEqual(d: Double): Boolean = x >= d || y >= d || z >= d || w >= d
infix fun greaterThanEqual(d: Double): Vec4bool = Vec4bool{ get(it) >= d }
infix fun allLessThan(v: Vec4d): Boolean = x < v.x && y < v.y && z < v.z && w < v.w
infix fun anyLessThan(v: Vec4d): Boolean = x < v.x || y < v.y || z < v.z || w < v.w
infix fun lessThan(v: Vec4d): Vec4bool = Vec4bool { get(it) < v[it] }
infix fun allLessThanEqual(v: Vec4d): Boolean = x <= v.x && y <= v.y && z <= v.z && w <= v.w
infix fun anyLessThanEqual(v: Vec4d): Boolean = x <= v.x || y <= v.y || z <= v.z || w <= v.w
infix fun lessThanEqual(v: Vec4d): Vec4bool = Vec4bool { get(it) <= v[it] }
fun allEqual(v: Vec4d, epsilon: Double = GLM.ε): Boolean = abs(x - v.x) < epsilon && abs(y - v.y) < epsilon && abs(z - v.z) < epsilon && abs(w - v.w) < epsilon
fun anyEqual(v: Vec4d, epsilon: Double = GLM.ε): Boolean = abs(x - v.x) < epsilon || abs(y - v.y) < epsilon || abs(z - v.z) < epsilon || abs(w - v.w) < epsilon
fun equal(v: Vec4d, epsilon: Double = GLM.ε): Vec4bool = Vec4bool { abs(get(it) - v[it]) < epsilon }
fun allNotEqual(v: Vec4d, epsilon: Double = GLM.ε): Boolean = abs(x - v.x) >= epsilon && abs(y - v.y) >= epsilon && abs(z - v.z) >= epsilon && abs(w - v.w) >= epsilon
fun anyNotEqual(v: Vec4d, epsilon: Double = GLM.ε): Boolean = abs(x - v.x) >= epsilon || abs(y - v.y) >= epsilon || abs(z - v.z) >= epsilon || abs(w - v.w) >= epsilon
fun notEqual(v: Vec4d, epsilon: Double = GLM.ε): Vec4bool = Vec4bool{ abs(get(it) - v[it]) >= epsilon }
infix fun allGreaterThan(v: Vec4d): Boolean = x > v.x && y > v.y && z > v.z && w > v.w
infix fun anyGreaterThan(v: Vec4d): Boolean = x > v.x || y > v.y || z > v.z || w > v.w
infix fun greaterThan(v: Vec4d): Vec4bool = Vec4bool{ get(it) > v[it] }
infix fun allGreaterThanEqual(v: Vec4d): Boolean = x >= v.x && y >= v.y && z >= v.z && w >= v.w
infix fun anyGreaterThanEqual(v: Vec4d): Boolean = x >= v.x || y >= v.y || z >= v.z || w >= v.w
infix fun greaterThanEqual(v: Vec4d): Vec4bool = Vec4bool{ get(it) >= v[it] }
infix fun dot(b: Vec4d) = GLM.dot(this, b) // TODO others
fun length() = GLM.length(this)
fun length2() = GLM.length2(this)
companion object : op_Vec4d {
const val length = Vec4t.length
@JvmField
val size = length * Double.BYTES
@JvmStatic
fun fromPointer(ptr: Ptr) = Vec4d(memGetDouble(ptr), memGetDouble(ptr + Double.BYTES), memGetDouble(ptr + Double.BYTES * 2), memGetDouble(ptr + Double.BYTES * 3))
}
override fun size() = size
override fun elementCount() = length
override fun equals(other: Any?) = other is Vec4d && this[0] == other[0] && this[1] == other[1] && this[2] == other[2] && this[3] == other[3]
override fun hashCode() = 31 * (31 * (31 * x.hashCode() + y.hashCode()) + z.hashCode()) + w.hashCode()
@JvmOverloads
fun print(name: String = "", stream: PrintStream = System.out) = stream.print("$name$this")
@JvmOverloads
fun println(name: String = "", stream: PrintStream = System.out) = stream.println("$name$this")
override fun toString(): String = "($x, $y, $z, $w)"
}