use malachite_base::num::basic::traits::{Infinity, NaN, NegativeInfinity};
use malachite_base::num::conversion::traits::ExactFrom;
use malachite_float::Float;
use malachite_float::test_util::common::parse_hex_string;
use malachite_float::test_util::generators::{
float_natural_pair_gen, float_natural_pair_gen_var_1, float_natural_pair_gen_var_2,
};
use malachite_nz::natural::Natural;
use malachite_nz::test_util::generators::{natural_gen, natural_pair_gen};
use malachite_q::Rational;
use rug;
use std::str::FromStr;
#[test]
fn test_partial_eq_natural() {
let test = |s, s_hex, t, out| {
let u = parse_hex_string(s_hex);
assert_eq!(u.to_string(), s);
let v = Natural::from_str(t).unwrap();
assert_eq!(u == v, out);
assert_eq!(v == u, out);
assert_eq!(rug::Float::exact_from(&u) == rug::Integer::from(&v), out);
};
test("NaN", "NaN", "0", false);
test("Infinity", "Infinity", "0", false);
test("-Infinity", "-Infinity", "0", false);
test("0.0", "0x0.0", "0", true);
test("-0.0", "-0x0.0", "0", true);
test("1.0", "0x1.0#1", "0", false);
test("2.0", "0x2.0#1", "0", false);
test("0.5", "0x0.8#1", "0", false);
test("0.33333333333333331", "0x0.55555555555554#53", "0", false);
test("1.4142135623730951", "0x1.6a09e667f3bcd#53", "0", false);
test("3.1415926535897931", "0x3.243f6a8885a30#53", "0", false);
test("3.0e120", "0x1.0E+100#1", "0", false);
test("4.0e-121", "0x1.0E-100#1", "0", false);
test("-1.0", "-0x1.0#1", "0", false);
test("-2.0", "-0x2.0#1", "0", false);
test("-0.5", "-0x0.8#1", "0", false);
test("-0.33333333333333331", "-0x0.55555555555554#53", "0", false);
test("-1.4142135623730951", "-0x1.6a09e667f3bcd#53", "0", false);
test("-3.1415926535897931", "-0x3.243f6a8885a30#53", "0", false);
test("-3.0e120", "-0x1.0E+100#1", "0", false);
test("-4.0e-121", "-0x1.0E-100#1", "0", false);
test("NaN", "NaN", "1", false);
test("Infinity", "Infinity", "1", false);
test("-Infinity", "-Infinity", "1", false);
test("0.0", "0x0.0", "1", false);
test("-0.0", "-0x0.0", "1", false);
test("1.0", "0x1.0#1", "1", true);
test("2.0", "0x2.0#1", "1", false);
test("0.5", "0x0.8#1", "1", false);
test("0.33333333333333331", "0x0.55555555555554#53", "1", false);
test("1.4142135623730951", "0x1.6a09e667f3bcd#53", "1", false);
test("3.1415926535897931", "0x3.243f6a8885a30#53", "1", false);
test("3.0e120", "0x1.0E+100#1", "1", false);
test("4.0e-121", "0x1.0E-100#1", "1", false);
test("-1.0", "-0x1.0#1", "1", false);
test("-2.0", "-0x2.0#1", "1", false);
test("-0.5", "-0x0.8#1", "1", false);
test("-0.33333333333333331", "-0x0.55555555555554#53", "1", false);
test("-1.4142135623730951", "-0x1.6a09e667f3bcd#53", "1", false);
test("-3.1415926535897931", "-0x3.243f6a8885a30#53", "1", false);
test("-3.0e120", "-0x1.0E+100#1", "1", false);
test("-4.0e-121", "-0x1.0E-100#1", "1", false);
test("NaN", "NaN", "100", false);
test("Infinity", "Infinity", "100", false);
test("-Infinity", "-Infinity", "100", false);
test("0.0", "0x0.0", "100", false);
test("-0.0", "-0x0.0", "100", false);
test("1.0", "0x1.0#1", "100", false);
test("2.0", "0x2.0#1", "100", false);
test("0.5", "0x0.8#1", "100", false);
test("0.33333333333333331", "0x0.55555555555554#53", "100", false);
test("1.4142135623730951", "0x1.6a09e667f3bcd#53", "100", false);
test("3.1415926535897931", "0x3.243f6a8885a30#53", "100", false);
test("3.0e120", "0x1.0E+100#1", "100", false);
test("4.0e-121", "0x1.0E-100#1", "100", false);
test("-1.0", "-0x1.0#1", "100", false);
test("-2.0", "-0x2.0#1", "100", false);
test("-0.5", "-0x0.8#1", "100", false);
test(
"-0.33333333333333331",
"-0x0.55555555555554#53",
"100",
false,
);
test("-1.4142135623730951", "-0x1.6a09e667f3bcd#53", "100", false);
test("-3.1415926535897931", "-0x3.243f6a8885a30#53", "100", false);
test("-3.0e120", "-0x1.0E+100#1", "100", false);
test("-4.0e-121", "-0x1.0E-100#1", "100", false);
let s = "2582249878086908589655919172003011874329705792829223512830659356540647622016841194629\
645353280137831435903171972747493376";
test("NaN", "NaN", s, false);
test("Infinity", "Infinity", s, false);
test("-Infinity", "-Infinity", s, false);
test("0.0", "0x0.0", s, false);
test("-0.0", "-0x0.0", s, false);
test("1.0", "0x1.0#1", s, false);
test("2.0", "0x2.0#1", s, false);
test("0.5", "0x0.8#1", s, false);
test("0.33333333333333331", "0x0.55555555555554#53", s, false);
test("1.4142135623730951", "0x1.6a09e667f3bcd#53", s, false);
test("3.1415926535897931", "0x3.243f6a8885a30#53", s, false);
test("3.0e120", "0x1.0E+100#1", s, true);
test("4.0e-121", "0x1.0E-100#1", s, false);
test("-1.0", "-0x1.0#1", s, false);
test("-2.0", "-0x2.0#1", s, false);
test("-0.5", "-0x0.8#1", s, false);
test("-0.33333333333333331", "-0x0.55555555555554#53", s, false);
test("-1.4142135623730951", "-0x1.6a09e667f3bcd#53", s, false);
test("-3.1415926535897931", "-0x3.243f6a8885a30#53", s, false);
test("-3.0e120", "-0x1.0E+100#1", s, false);
test("-4.0e-121", "-0x1.0E-100#1", s, false);
let s = "2582249878086908589655919172003011874329705792829223512830659356540647622016841194629\
645353280137831435903171972747493377";
test("NaN", "NaN", s, false);
test("Infinity", "Infinity", s, false);
test("-Infinity", "-Infinity", s, false);
test("0.0", "0x0.0", s, false);
test("-0.0", "-0x0.0", s, false);
test("1.0", "0x1.0#1", s, false);
test("2.0", "0x2.0#1", s, false);
test("0.5", "0x0.8#1", s, false);
test("0.33333333333333331", "0x0.55555555555554#53", s, false);
test("1.4142135623730951", "0x1.6a09e667f3bcd#53", s, false);
test("3.1415926535897931", "0x3.243f6a8885a30#53", s, false);
test("3.0e120", "0x1.0E+100#1", s, false);
test("4.0e-121", "0x1.0E-100#1", s, false);
test("-1.0", "-0x1.0#1", s, false);
test("-2.0", "-0x2.0#1", s, false);
test("-0.5", "-0x0.8#1", s, false);
test("-0.33333333333333331", "-0x0.55555555555554#53", s, false);
test("-1.4142135623730951", "-0x1.6a09e667f3bcd#53", s, false);
test("-3.1415926535897931", "-0x3.243f6a8885a30#53", s, false);
test("-3.0e120", "-0x1.0E+100#1", s, false);
test("-4.0e-121", "-0x1.0E-100#1", s, false);
}
#[allow(clippy::needless_pass_by_value, clippy::cmp_owned)]
fn partial_eq_natural_properties_helper(x: Float, y: Natural) {
let eq = x == y;
assert_eq!(y == x, eq);
assert_eq!(x == Float::exact_from(&y), eq);
assert_eq!(rug::Float::exact_from(&x) == rug::Integer::from(&y), eq);
}
#[allow(clippy::cmp_owned)]
#[test]
fn partial_eq_natural_properties() {
float_natural_pair_gen().test_properties(|(x, y)| {
partial_eq_natural_properties_helper(x, y);
});
float_natural_pair_gen_var_2().test_properties(|(x, y)| {
partial_eq_natural_properties_helper(x, y);
});
natural_gen().test_properties(|x| {
assert_ne!(x, Float::NAN);
assert_ne!(x, Float::INFINITY);
assert_ne!(x, Float::NEGATIVE_INFINITY);
});
natural_pair_gen().test_properties(|(x, y)| {
assert_eq!(Float::exact_from(&x) == y, x == y);
assert_eq!(x == Float::exact_from(&y), x == y);
});
float_natural_pair_gen_var_1().test_properties(|(x, y)| {
assert_eq!(Rational::exact_from(&x) == y, x == y);
});
}