Fixed normalization tests in Vector3 and ported some common tests to Vector2.

This commit is contained in:
Jarl Gullberg 2017-05-31 22:28:27 +02:00
parent 05fcf7961e
commit be213a7828
No known key found for this signature in database
GPG key ID: 750FF6F6BDA72D23
2 changed files with 105 additions and 12 deletions

View file

@ -35,6 +35,47 @@ module Vector2 =
// //
Assert.True(a.Length >= 0.0f) Assert.True(a.Length >= 0.0f)
[<Properties(Arbitrary = [| typeof<OpenTKGen> |])>]
module Length =
//
[<Property>]
let ``Length method works`` (a, b) =
let v = Vector2(a, b)
let l = System.Math.Sqrt((float)(a * a + b * b))
Assert.Equal((float32)l, v.Length)
[<Property>]
let ``Fast length method works`` (a, b) =
let v = Vector2(a, b)
let l = 1.0f / MathHelper.InverseSqrtFast(a * a + b * b)
Assert.Equal(l, v.LengthFast)
[<Property>]
let ``Length squared method works`` (a, b) =
let v = Vector2(a, b)
let lsq = a * a + b * b
Assert.Equal(lsq, v.LengthSquared)
[<Properties(Arbitrary = [| typeof<OpenTKGen> |])>]
module ``Unit vectors and perpendicularity`` =
//
[<Property>]
let ``Perpendicular vector to the right is correct`` (a, b) =
let v = Vector2(a, b)
let perp = Vector2(a, -b)
Assert.Equal(perp, v.PerpendicularRight)
[<Property>]
let ``Perpendicular vector to the left is correct`` (a, b) =
let v = Vector2(a, b)
let perp = Vector2(-a, b)
Assert.Equal(perp, v.PerpendicularLeft)
[<Properties(Arbitrary = [| typeof<OpenTKGen> |])>] [<Properties(Arbitrary = [| typeof<OpenTKGen> |])>]
module Indexing = module Indexing =
// //
@ -242,21 +283,73 @@ module Vector2 =
Assert.Equal(dot, vRes) Assert.Equal(dot, vRes)
[<Properties(Arbitrary = [| typeof<OpenTKGen> |])>] [<Properties(Arbitrary = [| typeof<OpenTKGen> |])>]
module Normalization = module Normalization =
// //
[<Property>] [<Property>]
let ``Normalization works`` (a : Vector2) = let ``Normalization of instance, creating a new vector, works`` (a, b) =
let scale = 1.0f / a.Length let v = Vector2(a, b)
let norm = Vector2(a.X * scale, a.Y * scale) let l = v.Length
let vRes = Vector2.Normalize(ref a)
Assert.Equal(norm, Vector2.Normalize(a)); // Dividing by zero is not supported
Assert.Equal(norm, vRes) if not (approxEq l 0.0f) then
let norm = v.Normalized()
Assert.ApproximatelyEqual(v.X / l, norm.X)
Assert.ApproximatelyEqual(v.Y / l, norm.Y)
[<Property>]
let ``Normalization of instance works`` (a, b) =
let v = Vector2(a, b)
let l = v.Length
if not (approxEq l 0.0f) then
let norm = Vector2(a, b)
norm.Normalize()
Assert.ApproximatelyEqual(v.X / l, norm.X)
Assert.ApproximatelyEqual(v.Y / l, norm.Y)
[<Property>]
let ``Fast approximate normalization of instance works`` (a, b) =
let v = Vector2(a, b)
let norm = Vector2(a, b)
norm.NormalizeFast()
let scale = MathHelper.InverseSqrtFast(a * a + b * b)
Assert.ApproximatelyEqual(v.X * scale, norm.X)
Assert.ApproximatelyEqual(v.Y * scale, norm.Y)
[<Property>] [<Property>]
let ``Fast approximate normalization works`` (a : Vector2, b : Vector2) = let ``Normalization by reference works`` (a : Vector2) =
if not (approxEq a.Length 0.0f) then
let scale = 1.0f / a.Length
let norm = Vector2(a.X * scale, a.Y * scale)
let vRes = Vector2.Normalize(ref a)
Assert.ApproximatelyEqual(norm, vRes)
[<Property>]
let ``Normalization works`` (a : Vector2) =
if not (approxEq a.Length 0.0f) then
let scale = 1.0f / a.Length
let norm = Vector2(a.X * scale, a.Y * scale)
Assert.ApproximatelyEqual(norm, Vector3.Normalize(a));
[<Property>]
let ``Fast approximate normalization by reference works`` (a : Vector2) =
let scale = MathHelper.InverseSqrtFast(a.X * a.X + a.Y * a.Y) let scale = MathHelper.InverseSqrtFast(a.X * a.X + a.Y * a.Y)
let norm = Vector2(a.X * scale, a.Y * scale) let norm = Vector2(a.X * scale, a.Y * scale)
let vRes = Vector2.NormalizeFast(ref a) let vRes = Vector2.NormalizeFast(ref a)
Assert.Equal(norm, Vector2.NormalizeFast(a)); Assert.ApproximatelyEqual(norm, vRes)
Assert.Equal(norm, vRes)
[<Property>]
let ``Fast approximate normalization works`` (a : Vector2) =
let scale = MathHelper.InverseSqrtFast(a.X * a.X + a.Y * a.Y)
let norm = Vector2(a.X * scale, a.Y * scale)
Assert.ApproximatelyEqual(norm, Vector2.NormalizeFast(a));

View file

@ -181,7 +181,7 @@ module Vector3 =
[<Property>] [<Property>]
let ``Fast approximate normalization by reference works`` (a : Vector3) = let ``Fast approximate normalization by reference works`` (a : Vector3) =
let scale = MathHelper.InverseSqrtFast(a.X * a.X + a.Y * a.Y) let scale = MathHelper.InverseSqrtFast(a.X * a.X + a.Y * a.Y + a.Z * a.Z)
let norm = Vector3(a.X * scale, a.Y * scale, a.Z * scale) let norm = Vector3(a.X * scale, a.Y * scale, a.Z * scale)
let vRes = Vector3.NormalizeFast(ref a) let vRes = Vector3.NormalizeFast(ref a)
@ -190,7 +190,7 @@ module Vector3 =
[<Property>] [<Property>]
let ``Fast approximate normalization works`` (a : Vector3) = let ``Fast approximate normalization works`` (a : Vector3) =
let scale = MathHelper.InverseSqrtFast(a.X * a.X + a.Y * a.Y) let scale = MathHelper.InverseSqrtFast(a.X * a.X + a.Y * a.Y + a.Z * a.Z)
let norm = Vector3(a.X * scale, a.Y * scale, a.Z * scale) let norm = Vector3(a.X * scale, a.Y * scale, a.Z * scale)