use crate::Float;
use crate::test_util::common::rug_float_significant_bits;
use core::cmp::Ordering;
use malachite_base::num::conversion::traits::ExactFrom;
use malachite_base::rounding_modes::RoundingMode;
use rug::float::Round;
use rug::ops::AssignRound;
pub fn square_prec_round_naive(x: Float, prec: u64, rm: RoundingMode) -> (Float, Ordering) {
x.clone().mul_prec_round(x, prec, rm)
}
pub fn rug_square_prec_round(x: &rug::Float, prec: u64, rm: Round) -> (rug::Float, Ordering) {
let mut square = rug::Float::with_val(u32::exact_from(prec), 0);
let o = square.assign_round(x.square_ref(), rm);
(square, o)
}
pub fn rug_square_prec(x: &rug::Float, prec: u64) -> (rug::Float, Ordering) {
rug_square_prec_round(x, prec, Round::Nearest)
}
pub fn rug_square_round(x: &rug::Float, rm: Round) -> (rug::Float, Ordering) {
rug_square_prec_round(x, rug_float_significant_bits(x), rm)
}
pub fn rug_square(x: &rug::Float) -> rug::Float {
rug_square_prec_round(x, rug_float_significant_bits(x), Round::Nearest).0
}