use malachite_base::num::arithmetic::traits::Abs;
use malachite_base::num::basic::floats::PrimitiveFloat;
use malachite_base::num::basic::traits::NegativeInfinity;
use malachite_base::num::comparison::traits::{EqAbs, PartialOrdAbs};
use malachite_nz::integer::Integer;
use malachite_nz::test_util::generators::{integer_gen, integer_primitive_float_pair_gen};
use std::cmp::Ordering::*;
use std::str::FromStr;
#[test]
fn test_eq_abs_f32() {
let test = |u, v: f32, eq: bool| {
let u = Integer::from_str(u).unwrap();
assert_eq!(u.eq_abs(&v), eq);
assert_eq!(u.ne_abs(&v), !eq);
assert_eq!((&u).abs() == v.abs(), eq);
assert_eq!(v.eq_abs(&u), eq);
};
test("0", 0.0, true);
test("0", -0.0, true);
test("0", 5.0, false);
test("0", -5.0, false);
test("123", 123.0, true);
test("123", -123.0, true);
test("123", 5.0, false);
test("123", -5.0, false);
test("1000000000000", 123.0, false);
test("1000000000000", -123.0, false);
test("1", 0.5, false);
test("1", -0.5, false);
test("1", f32::INFINITY, false);
test("1", f32::NEGATIVE_INFINITY, false);
test("1", f32::NAN, false);
test("-123", 123.0, true);
test("-123", -123.0, true);
test("-123", 5.0, false);
test("-123", -5.0, false);
test("-1000000000000", 123.0, false);
test("-1000000000000", -123.0, false);
test("-1", 0.5, false);
test("-1", -0.5, false);
test("-1", f32::INFINITY, false);
test("-1", f32::NEGATIVE_INFINITY, false);
test("-1", f32::NAN, false);
}
#[test]
fn test_eq_abs_f64() {
let test = |u, v: f64, eq: bool| {
let u = Integer::from_str(u).unwrap();
assert_eq!(u.eq_abs(&v), eq);
assert_eq!(u.ne_abs(&v), !eq);
assert_eq!((&u).abs() == v.abs(), eq);
assert_eq!(v.eq_abs(&u), eq);
};
test("0", 0.0, true);
test("0", -0.0, true);
test("0", 5.0, false);
test("0", -5.0, false);
test("123", 123.0, true);
test("123", -123.0, true);
test("123", 5.0, false);
test("123", -5.0, false);
test("1000000000000", 123.0, false);
test("1000000000000", -123.0, false);
test("1", 0.5, false);
test("1", -0.5, false);
test("1", f64::INFINITY, false);
test("1", f64::NEGATIVE_INFINITY, false);
test("1", f64::NAN, false);
test("-123", 123.0, true);
test("-123", -123.0, true);
test("-123", 5.0, false);
test("-123", -5.0, false);
test("-1000000000000", 123.0, false);
test("-1000000000000", -123.0, false);
test("-1", 0.5, false);
test("-1", -0.5, false);
test("-1", f64::INFINITY, false);
test("-1", f64::NEGATIVE_INFINITY, false);
test("-1", f64::NAN, false);
}
fn eq_abs_primitive_float_properties_helper<
T: EqAbs<Integer> + PartialEq<Integer> + PrimitiveFloat,
>()
where
Integer: EqAbs<T> + PartialEq<T> + PartialOrdAbs<T>,
{
integer_primitive_float_pair_gen::<T>().test_properties(|(x, y)| {
let eq = x.eq_abs(&y);
assert_eq!((&x).abs() == y.abs(), eq);
assert_eq!(x.ne_abs(&y), !eq);
assert_eq!(y.eq_abs(&x), eq);
assert_eq!(x.partial_cmp_abs(&y) == Some(Equal), eq);
});
integer_gen().test_properties(|n| {
assert_ne!(n, T::NAN);
assert_ne!(n, T::INFINITY);
assert_ne!(n, T::NEGATIVE_INFINITY);
});
}
#[test]
fn eq_abs_primitive_float_properties() {
apply_fn_to_primitive_floats!(eq_abs_primitive_float_properties_helper);
}