// 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();
}
}
}