vmath/tests/test.nim
2020-11-12 10:11:07 -08:00

246 lines
5.6 KiB
Nim

import vmath, osproc, random, streams
var s = newFileStream("tests/test-output.txt", fmWrite)
randomize(1234)
block:
s.writeLine "# angle stuff"
s.writeLine angleBetween(0.1, 0.2), " should be: ", 0.1
s.writeLine angleBetween(0.1, 0.2 + PI*2), " should be: ", 0.1
s.writeLine angleBetween(0.1, 0.2 - PI*2), " should be: ", 0.1
s.writeLine angleBetween(0.1 + PI*2, 0.2), " should be: ", 0.1
s.writeLine angleBetween(0.1 - PI*2, 0.2), " should be: ", 0.1
s.writeLine angleBetween(0.2, 0.1), " should be: ", -0.1
s.writeLine angleBetween(0.2, 0.1 - PI*2), " should be: ", -0.1
s.writeLine angleBetween(0.2, 0.1 + PI*2), " should be: ", -0.1
s.writeLine angleBetween(0.2 + PI*2, 0.1), " should be: ", -0.1
s.writeLine angleBetween(0.2 - PI*2, 0.1), " should be: ", -0.1
block:
s.writeLine "# basic vector vec2"
var a = vec2(1, 2)
var b = vec2(7, 6)
var n = 13.7
s.writeLine a + b
s.writeLine a - b
s.writeLine a * n
s.writeLine a / n
a += b
s.writeLine a
a -= b
s.writeLine a
a *= n
s.writeLine a
a /= n
s.writeLine a
block:
s.writeLine "# basic vector vec3"
var a = vec3(1, 2, 3)
var b = vec3(7, 6, 5)
var n = 13.7
s.writeLine a + b
s.writeLine a - b
s.writeLine a * n
s.writeLine a / n
a += b
s.writeLine a
a -= b
s.writeLine a
a *= n
s.writeLine a
a /= n
s.writeLine a
block:
s.writeLine "# basic vector vec4"
var a = vec4(1, 2, 3, 4)
var b = vec4(7, 6, 5, 4)
var n = 13.7
s.writeLine a + b
s.writeLine a - b
s.writeLine a * n
s.writeLine a / n
a += b
s.writeLine a
a -= b
s.writeLine a
a *= n
s.writeLine a
a /= n
s.writeLine a
block:
s.writeLine "# basic vector mat4"
var m1 = mat4(
1, 0, 0, 0,
0, 1, 0, 0,
0, 0, 1, 0,
0, 0, 0, 1)
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
assert m1.close(m2)
block:
s.writeLine "# basic vector mat4 -1"
var m1 = mat4(
1, 0, 0, 0,
0, 0, -1, 0,
0, 1, 0, 0,
0, 0, 0, 1)
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
assert m1.close(m2)
block:
s.writeLine "# Y 90"
var m1 = rotate(PI/2, vec3(0, 1, 0))
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
assert m1.close(m2)
block:
s.writeLine "# -Y 90"
var m1 = rotate(PI/2, vec3(0, -1, 0))
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
assert m1.close(m2)
block:
s.writeLine "# X 90"
var m1 = rotate(PI/2, vec3(1, 0, 0))
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
s.writeLine m1.close(m2)
block:
s.writeLine "# Y 90"
var m1 = rotate(PI/2, vec3(1, 0, 0))
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
s.writeLine m1.close(m2)
block:
s.writeLine "# 1,1,1 1.11rad"
var m1 = rotate(PI*1.11, vec3(1, 1, 1).normalize())
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
assert m1.close(m2)
block:
s.writeLine "# 1,1,1 1.11rad"
var m1 = rotate(PI*1.11, vec3(-1, 1, 1).normalize())
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
assert m1.close(m2)
block:
s.writeLine "# 1,1,1 1.11rad"
var m1 = rotate(PI*1.11, vec3(-1, 0.34, 1.123).normalize())
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
assert m1.close(m2)
block:
s.writeLine "# super random"
for i in 0..100:
var m1 = rotate(
PI*rand(2.0),
vec3(rand(2.0)-0.5, rand(2.0)-0.5, rand(2.0)-0.5).normalize()
)
s.writeLine m1
var q1 = m1.quat()
s.writeLine q1
var m2 = q1.mat4()
s.writeLine m2
assert m1.close(m2)
block:
s.writeLine "# matrix to quat test"
# TODO: Fix this test
# var m1 = mat4(
# -0.33089, -0.51266, -0.79227, 0.00000,
# 0, -1.0, 0, 0.00000,
# 0, 0, 1.0, 0.00000,
# 0.00000, 0.00000, 0.00000, 1.00000)
# s.writeLine m1
# var q1 = m1.quat()
# s.writeLine q1
# var m2 = q1.mat4()
# s.writeLine m2
# assert m1.close(m2)
block:
s.writeLine "# matrix to quat test"
# TODO: Fix this test
# var m1 = mat4(
# -0.33089, -0.51266, -0.79227, 0.00000,
# -0.44681, 0.82460, -0.34697, 0.00000,
# -0.83119, -0.23918, 0.50191, 0.00000,
# 0.00000, 0.00000, 0.00000, 1.00000)
# s.writeLine vec3( -0.33089, -0.51266, -0.79227).length
# s.writeLine vec3( -0.44681, 0.82460, -0.34697).length
# s.writeLine vec3( -0.83119, -0.23918, 0.50191).length
# s.writeLine m1
# var q1 = m1.quat().normalize()
# s.writeLine q1
# var m2 = q1.mat4()
# s.writeLine m2
# assert m1.close(m2)
block:
s.writeLine "# matrix to quat test"
var a3 = mat3(0.9659258723258972, -0.258819043636322, 0.0, 0.258819043636322, 0.9659258723258972, 0.0, -25.00000953674316, 70.09619140625, 1.0)
var b3 = mat3(0.9659258127212524, 0.258819043636322, 0.0, -0.258819043636322, 0.9659258127212524, 0.0, 77.64571380615234, 0.0, 1.0)
s.writeLine "Test Mat3 * Mat3:"
s.writeLine (a3.mat4 * b3.mat4).mat3
s.writeLine a3 * b3
s.writeLine (mat3(1,2,3,4,5,6,7,8,9).mat4Rotation * mat3(10,20,30,40,50,60,70,80,90).mat4Rotation).mat3Rotation
s.writeLine mat3(1,2,3,4,5,6,7,8,9) * mat3(10,20,30,40,50,60,70,80,90)
s.writeLine "Test Mat3 * Vec2 and Vec3:"
s.writeLine a3.mat4 * vec3(77.64571380615234, 0, 1)
s.writeLine a3 * vec2(77.64571380615234, 0)
s.writeLine a3 * vec3(77.64571380615234, 0, 1.0)
s.close()
let (outp, _) = execCmdEx("git diff tests/test-output.txt")
if len(outp) != 0:
echo outp
quit("Output does not match")