malachite-float 0.9.1

The arbitrary-precision floating-point type Float, with efficient algorithms partially derived from MPFR.
Documentation
// Copyright © 2026 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 <https://www.gnu.org/licenses/>.

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
}