use crate::Float;
use crate::test_util::common::rug_float_significant_bits;
use core::cmp::Ordering;
use malachite_base::num::basic::traits::One;
use malachite_base::num::conversion::traits::ExactFrom;
use malachite_base::rounding_modes::RoundingMode;
use malachite_q::Rational;
use rug::float::Round;
use rug::ops::AssignRound;
pub fn reciprocal_prec_round_naive_1(x: Float, prec: u64, rm: RoundingMode) -> (Float, Ordering) {
Float::rational_div_float_prec_round(Rational::ONE, x, prec, rm)
}
pub fn reciprocal_prec_round_naive_2(x: Float, prec: u64, rm: RoundingMode) -> (Float, Ordering) {
Float::ONE.div_prec_round(x, prec, rm)
}
pub fn rug_reciprocal_prec_round(x: &rug::Float, prec: u64, rm: Round) -> (rug::Float, Ordering) {
let mut sum = rug::Float::with_val(u32::exact_from(prec), 0);
let o = sum.assign_round(rug::Rational::ONE / x, rm);
(sum, o)
}
pub fn rug_reciprocal_prec(x: &rug::Float, prec: u64) -> (rug::Float, Ordering) {
rug_reciprocal_prec_round(x, prec, Round::Nearest)
}
pub fn rug_reciprocal_round(x: &rug::Float, rm: Round) -> (rug::Float, Ordering) {
rug_reciprocal_prec_round(x, rug_float_significant_bits(x), rm)
}
pub fn rug_reciprocal(x: &rug::Float) -> rug::Float {
rug_reciprocal_prec_round(x, rug_float_significant_bits(x), Round::Nearest).0
}