// Copyright (c) Six Labors and contributors.
// Licensed under the Apache License, Version 2.0.
using System;
using System.Collections.Generic;
using System.Numerics;
namespace SixLabors.ImageSharp.Tests
{
///
/// Allows the approximate comparison of single precision floating point values.
///
internal readonly struct ApproximateFloatComparer :
IEqualityComparer,
IEqualityComparer
{
private readonly float Epsilon;
///
/// Initializes a new instance of the class.
///
/// The comparison error difference epsilon to use.
public ApproximateFloatComparer(float epsilon = 1f)
{
this.Epsilon = epsilon;
}
public bool Equals(float x, float y)
{
float d = x - y;
return d >= -this.Epsilon && d <= this.Epsilon;
}
public int GetHashCode(float obj)
{
return obj.GetHashCode();
}
public bool Equals(Vector4 x, Vector4 y)
{
return this.Equals(x.X, y.X) && this.Equals(x.Y, y.Y) && this.Equals(x.Z, y.Z) && this.Equals(x.W, y.W);
}
public int GetHashCode(Vector4 obj)
{
return obj.GetHashCode();
}
}
}