// Copyright (c) Six Labors. // Licensed under the Six Labors Split License. using System.Numerics; using SixLabors.ImageSharp.PixelFormats; // ReSharper disable MemberHidesStaticFromOuterClass namespace SixLabors.ImageSharp.Tests; /// /// Class to perform simple image comparisons. /// public static class VectorAssert { public static void Equal(TPixel expected, TPixel actual, int precision = int.MaxValue) where TPixel : unmanaged, IPixel { Equal(expected.ToVector4(), actual.ToVector4(), precision); } public static void Equal(Vector4 expected, Vector4 actual, int precision = int.MaxValue) { Assert.Equal(expected, actual, new PrecisionEqualityComparer(precision)); } public static void Equal(Vector3 expected, Vector3 actual, int precision = int.MaxValue) { Assert.Equal(expected, actual, new PrecisionEqualityComparer(precision)); } public static void Equal(Vector2 expected, Vector2 actual, int precision = int.MaxValue) { Assert.Equal(expected, actual, new PrecisionEqualityComparer(precision)); } private struct PrecisionEqualityComparer : IEqualityComparer, IEqualityComparer, IEqualityComparer, IEqualityComparer { private readonly int precision; public PrecisionEqualityComparer(int precision) { this.precision = precision; } public bool Equals(Vector2 x, Vector2 y) { return this.Equals(x.X, y.X) && this.Equals(x.Y, y.Y); } public bool Equals(Vector3 x, Vector3 y) { return this.Equals(x.X, y.X) && this.Equals(x.Y, y.Y) && this.Equals(x.Z, y.Z); } public bool Equals(Vector4 x, Vector4 y) { return this.Equals(x.W, y.W) && this.Equals(x.X, y.X) && this.Equals(x.Y, y.Y) && this.Equals(x.Z, y.Z); } public bool Equals(float x, float y) { return Math.Round(x, this.precision) == Math.Round(y, this.precision); } public int GetHashCode(Vector4 obj) { return obj.GetHashCode(); } public int GetHashCode(Vector3 obj) { return obj.GetHashCode(); } public int GetHashCode(Vector2 obj) { return obj.GetHashCode(); } public int GetHashCode(float obj) { return obj.GetHashCode(); } } }