// Copyright © 2024 Mikhail Hogrefe
//
// This file is part of Malachite.
//
// Malachite is free software: you can redistribute it and/or modify it under the terms of the GNU
// Lesser General Public License (LGPL) as published by the Free Software Foundation; either version
// 3 of the License, or (at your option) any later version. See .
use malachite_base::num::basic::unsigneds::PrimitiveUnsigned;
use malachite_base::num::conversion::traits::{JoinHalves, SplitInHalf};
use malachite_base::test_util::generators::unsigned_gen;
fn lower_half_test_helper(n: T, out: T::Half)
where
T::Half: PrimitiveUnsigned,
{
assert_eq!(n.lower_half(), out);
}
#[test]
pub fn test_lower_half() {
lower_half_test_helper(0u64, 0u32);
lower_half_test_helper(1u64, 1u32);
lower_half_test_helper(u16::from(u8::MAX), u8::MAX);
lower_half_test_helper(u16::from(u8::MAX) + 1, 0);
lower_half_test_helper(u16::MAX, u8::MAX);
lower_half_test_helper(258u16, 2u8);
lower_half_test_helper(0xabcd1234u32, 0x1234);
}
fn lower_half_properties_helper() {
unsigned_gen::().test_properties(|n| {
let lower = n.lower_half();
assert_eq!(T::join_halves(n.upper_half(), lower), n);
});
}
#[test]
fn lower_half_properties() {
lower_half_properties_helper::();
lower_half_properties_helper::();
lower_half_properties_helper::();
lower_half_properties_helper::();
}