namespace OpenTK.Tests.Generators open Xunit open FsCheck open FsCheck.Xunit open System open OpenTK [] module public AssertHelpers = [] let private BitAccuracy = 16 [] let private EquivalenceTolerance = 0.00005f let approxEq a b = MathHelper.ApproximatelyEquivalent(a, b, EquivalenceTolerance) let approxEqDelta a b = MathHelper.ApproximatelyEqual(a, b, BitAccuracy) let approxEqSingleEpsilon a b = MathHelper.ApproximatelyEqualEpsilon(a, b, 0.00001f) let approxEqDoubleEpsilon a b = MathHelper.ApproximatelyEqualEpsilon(a, b, 0.00001) let approxEqSingleEpsilonWithError (a, b, c : float32) = MathHelper.ApproximatelyEqualEpsilon(a, b, c) let approxEqDoubleEpsilonWithError (a, b, c : float) = MathHelper.ApproximatelyEqualEpsilon(a, b, c) let anyZero2 (a : Vector2) = (approxEq a.X 0.0f || approxEq a.Y 0.0f) let anyZero3 (a : Vector3) = (approxEq a.X 0.0f || approxEq a.Y 0.0f || approxEq a.Z 0.0f) let anyZero4 (a : Vector4) = (approxEq a.X 0.0f || approxEq a.Y 0.0f || approxEq a.Z 0.0f || approxEq a.W 0.0f) /// We use a full type here instead of a module, as the overloading semantics are more suitable for our desired goal. [] type public Assert = static member ApproximatelyEquivalent(a : Vector2,b : Vector2) = if not <| approxEq a.X b.X && approxEq a.Y b.Y then raise <| new Xunit.Sdk.EqualException(a,b) static member ApproximatelyEquivalent(a : Vector3,b : Vector3) = if not <| approxEq a.X b.X && approxEq a.Y b.Y && approxEq a.Z b.Z then raise <| new Xunit.Sdk.EqualException(a,b) static member ApproximatelyEquivalent(a : Vector4,b : Vector4) = if not <| approxEq a.X b.X && approxEq a.Y b.Y && approxEq a.Z b.Z && approxEq a.W b.W then raise <| new Xunit.Sdk.EqualException(a,b) static member ApproximatelyEquivalent(a : float32,b : float32) = if not <| approxEq a b then raise <| new Xunit.Sdk.EqualException(a,b) static member ApproximatelyEqualEpsilon(a : float32, b : float32) = if not <| approxEqSingleEpsilon a b then raise <| new Xunit.Sdk.EqualException(a,b) static member ApproximatelyEqualEpsilon(a : float32, b : float32, c : float32) = if not <| approxEqSingleEpsilonWithError(a, b, c) then raise <| new Xunit.Sdk.EqualException(a,b) static member ApproximatelyEqualEpsilon(a : float, b : float) = if not <| approxEqDoubleEpsilon a b then raise <| new Xunit.Sdk.EqualException(a,b) static member ApproximatelyEqualEpsilon(a : float, b : float, c : float) = if not <| approxEqDoubleEpsilonWithError(a, b, c) then raise <| new Xunit.Sdk.EqualException(a,b) static member NotApproximatelyEqualEpsilon(a : float32, b : float32) = if approxEqSingleEpsilon a b then raise <| new Xunit.Sdk.EqualException(a,b) static member NotApproximatelyEqualEpsilon(a : float32, b : float32, c : float32) = if approxEqSingleEpsilonWithError(a, b, c) then raise <| new Xunit.Sdk.EqualException(a,b) static member NotApproximatelyEqualEpsilon(a : float, b : float) = if approxEqDoubleEpsilon a b then raise <| new Xunit.Sdk.EqualException(a,b) static member NotApproximatelyEqualEpsilon(a : float, b : float, c : float) = if approxEqDoubleEpsilonWithError(a, b, c) then raise <| new Xunit.Sdk.EqualException(a,b) static member ThrowsIndexExn(f:unit -> unit) = Assert.Throws(f) |> ignore static member ApproximatelyEqual(a : float32, b : float32) = if not <| approxEqDelta a b then raise <| new Xunit.Sdk.EqualException(a, b)