use malachite_base::num::arithmetic::traits::{ReciprocalSqrt, ReciprocalSqrtAssign};
use malachite_base::num::basic::floats::PrimitiveFloat;
use malachite_base::num::conversion::traits::{ExactFrom, RoundingFrom};
use malachite_base::num::float::NiceFloat;
use malachite_base::test_util::bench::bucketers::primitive_float_bucketer;
use malachite_base::test_util::bench::{BenchmarkType, run_benchmark};
use malachite_base::test_util::generators::common::{GenConfig, GenMode};
use malachite_base::test_util::generators::primitive_float_gen;
use malachite_base::test_util::runner::Runner;
use malachite_float::arithmetic::reciprocal_sqrt::{
primitive_float_reciprocal_sqrt, primitive_float_reciprocal_sqrt_rational,
};
use malachite_float::test_util::arithmetic::reciprocal_sqrt::{
reciprocal_sqrt_rational_prec_round_generic, reciprocal_sqrt_rational_prec_round_simple,
rug_reciprocal_sqrt, rug_reciprocal_sqrt_prec, rug_reciprocal_sqrt_prec_round,
rug_reciprocal_sqrt_round,
};
use malachite_float::test_util::bench::bucketers::{
float_complexity_bucketer, pair_1_float_complexity_bucketer, pair_2_float_complexity_bucketer,
pair_2_pair_1_float_complexity_bucketer,
pair_2_pair_float_primitive_int_max_complexity_bucketer,
pair_2_triple_1_2_float_primitive_int_max_complexity_bucketer,
pair_float_primitive_int_max_complexity_bucketer,
triple_1_2_float_primitive_int_max_complexity_bucketer,
};
use malachite_float::test_util::generators::{
float_gen, float_gen_rm, float_gen_var_12, float_rounding_mode_pair_gen_var_30,
float_rounding_mode_pair_gen_var_30_rm, float_rounding_mode_pair_gen_var_31,
float_unsigned_pair_gen_var_1, float_unsigned_pair_gen_var_1_rm, float_unsigned_pair_gen_var_4,
float_unsigned_rounding_mode_triple_gen_var_15,
float_unsigned_rounding_mode_triple_gen_var_15_rm,
float_unsigned_rounding_mode_triple_gen_var_16,
rational_unsigned_rounding_mode_triple_gen_var_4,
};
use malachite_float::{ComparableFloat, ComparableFloatRef, Float};
use malachite_q::test_util::bench::bucketers::{
pair_rational_bit_u64_max_bucketer, rational_bit_bucketer,
triple_1_2_rational_bit_u64_max_bucketer,
};
use malachite_q::test_util::generators::{rational_gen, rational_unsigned_pair_gen_var_3};
pub(crate) fn register(runner: &mut Runner) {
register_demo!(runner, demo_float_reciprocal_sqrt);
register_demo!(runner, demo_float_reciprocal_sqrt_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_extreme);
register_demo!(runner, demo_float_reciprocal_sqrt_extreme_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_ref);
register_demo!(runner, demo_float_reciprocal_sqrt_ref_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_assign);
register_demo!(runner, demo_float_reciprocal_sqrt_assign_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_prec);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_extreme);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_extreme_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_ref);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_ref_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_assign);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_assign_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_round);
register_demo!(runner, demo_float_reciprocal_sqrt_round_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_round_extreme);
register_demo!(runner, demo_float_reciprocal_sqrt_round_extreme_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_round_ref);
register_demo!(runner, demo_float_reciprocal_sqrt_round_ref_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_round_assign);
register_demo!(runner, demo_float_reciprocal_sqrt_round_assign_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_round);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_round_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_round_extreme);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_round_extreme_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_round_ref);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_round_ref_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_round_assign);
register_demo!(runner, demo_float_reciprocal_sqrt_prec_round_assign_debug);
register_primitive_float_demos!(runner, demo_primitive_float_reciprocal_sqrt);
register_demo!(runner, demo_float_reciprocal_sqrt_rational_prec);
register_demo!(runner, demo_float_reciprocal_sqrt_rational_prec_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_rational_prec_ref);
register_demo!(runner, demo_float_reciprocal_sqrt_rational_prec_ref_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_rational_prec_round);
register_demo!(runner, demo_float_reciprocal_sqrt_rational_prec_round_debug);
register_demo!(runner, demo_float_reciprocal_sqrt_rational_prec_round_ref);
register_demo!(
runner,
demo_float_reciprocal_sqrt_rational_prec_round_ref_debug
);
register_primitive_float_demos!(runner, demo_primitive_float_reciprocal_sqrt_rational);
register_bench!(runner, benchmark_float_reciprocal_sqrt_evaluation_strategy);
register_bench!(runner, benchmark_float_reciprocal_sqrt_library_comparison);
register_bench!(runner, benchmark_float_reciprocal_sqrt_assign);
register_bench!(
runner,
benchmark_float_reciprocal_sqrt_prec_evaluation_strategy
);
register_bench!(
runner,
benchmark_float_reciprocal_sqrt_prec_library_comparison
);
register_bench!(runner, benchmark_float_reciprocal_sqrt_prec_assign);
register_bench!(
runner,
benchmark_float_reciprocal_sqrt_round_evaluation_strategy
);
register_bench!(
runner,
benchmark_float_reciprocal_sqrt_round_library_comparison
);
register_bench!(runner, benchmark_float_reciprocal_sqrt_round_assign);
register_bench!(
runner,
benchmark_float_reciprocal_sqrt_prec_round_evaluation_strategy
);
register_bench!(
runner,
benchmark_float_reciprocal_sqrt_prec_round_library_comparison
);
register_bench!(runner, benchmark_float_reciprocal_sqrt_prec_round_assign);
register_primitive_float_benches!(runner, benchmark_primitive_float_reciprocal_sqrt);
register_bench!(
runner,
benchmark_float_reciprocal_sqrt_rational_prec_evaluation_strategy
);
register_bench!(
runner,
benchmark_float_reciprocal_sqrt_rational_prec_round_evaluation_strategy
);
register_bench!(
runner,
benchmark_float_reciprocal_sqrt_rational_prec_round_algorithms
);
register_primitive_float_benches!(runner, benchmark_primitive_float_reciprocal_sqrt_rational);
}
fn demo_float_reciprocal_sqrt(gm: GenMode, config: &GenConfig, limit: usize) {
for x in float_gen().get(gm, config).take(limit) {
let x_old = x.clone();
println!("({}).reciprocal_sqrt() = {}", x_old, x.reciprocal_sqrt());
}
}
fn demo_float_reciprocal_sqrt_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for x in float_gen().get(gm, config).take(limit) {
let x_old = x.clone();
println!(
"({:#x}).reciprocal_sqrt() = {:#x}",
ComparableFloat(x_old),
ComparableFloat(x.reciprocal_sqrt())
);
}
}
fn demo_float_reciprocal_sqrt_extreme(gm: GenMode, config: &GenConfig, limit: usize) {
for x in float_gen_var_12().get(gm, config).take(limit) {
let x_old = x.clone();
println!("({}).reciprocal_sqrt() = {}", x_old, x.reciprocal_sqrt());
}
}
fn demo_float_reciprocal_sqrt_extreme_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for x in float_gen_var_12().get(gm, config).take(limit) {
let x_old = x.clone();
println!(
"({:#x}).reciprocal_sqrt() = {:#x}",
ComparableFloat(x_old),
ComparableFloat(x.reciprocal_sqrt())
);
}
}
fn demo_float_reciprocal_sqrt_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for x in float_gen().get(gm, config).take(limit) {
println!("(&{}).reciprocal_sqrt() = {}", x, (&x).reciprocal_sqrt());
}
}
fn demo_float_reciprocal_sqrt_ref_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for x in float_gen().get(gm, config).take(limit) {
println!(
"(&{:#x}).reciprocal_sqrt() = {:#x}",
ComparableFloatRef(&x),
ComparableFloat((&x).reciprocal_sqrt())
);
}
}
fn demo_float_reciprocal_sqrt_assign(gm: GenMode, config: &GenConfig, limit: usize) {
for mut x in float_gen().get(gm, config).take(limit) {
let x_old = x.clone();
x.reciprocal_sqrt_assign();
println!("x := {x_old}; x.reciprocal_sqrt_assign(); x = {x}");
}
}
fn demo_float_reciprocal_sqrt_assign_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for mut x in float_gen().get(gm, config).take(limit) {
let x_old = x.clone();
x.reciprocal_sqrt_assign();
println!(
"x := {:#x}; x.reciprocal_sqrt_assign(); x = {:#x}",
ComparableFloat(x_old),
ComparableFloat(x)
);
}
}
fn demo_float_reciprocal_sqrt_prec(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec) in float_unsigned_pair_gen_var_1().get(gm, config).take(limit) {
let x_old = x.clone();
println!(
"({}).reciprocal_sqrt_prec({}) = {:?}",
x_old,
prec,
x.reciprocal_sqrt_prec(prec)
);
}
}
fn demo_float_reciprocal_sqrt_prec_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec) in float_unsigned_pair_gen_var_1().get(gm, config).take(limit) {
let x_old = x.clone();
let (sum, o) = x.reciprocal_sqrt_prec(prec);
println!(
"({:#x}).reciprocal_sqrt_prec({}) = ({:#x}, {:?})",
ComparableFloat(x_old),
prec,
ComparableFloat(sum),
o
);
}
}
fn demo_float_reciprocal_sqrt_prec_extreme(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec) in float_unsigned_pair_gen_var_4().get(gm, config).take(limit) {
let x_old = x.clone();
println!(
"({}).reciprocal_sqrt_prec({}) = {:?}",
x_old,
prec,
x.reciprocal_sqrt_prec(prec)
);
}
}
fn demo_float_reciprocal_sqrt_prec_extreme_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec) in float_unsigned_pair_gen_var_4().get(gm, config).take(limit) {
let x_old = x.clone();
let (sum, o) = x.reciprocal_sqrt_prec(prec);
println!(
"({:#x}).reciprocal_sqrt_prec({}) = ({:#x}, {:?})",
ComparableFloat(x_old),
prec,
ComparableFloat(sum),
o
);
}
}
fn demo_float_reciprocal_sqrt_prec_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec) in float_unsigned_pair_gen_var_1().get(gm, config).take(limit) {
println!(
"(&{}).reciprocal_sqrt_prec_ref({}) = {:?}",
x,
prec,
x.reciprocal_sqrt_prec_ref(prec)
);
}
}
fn demo_float_reciprocal_sqrt_prec_ref_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec) in float_unsigned_pair_gen_var_1().get(gm, config).take(limit) {
let (sum, o) = x.reciprocal_sqrt_prec_ref(prec);
println!(
"(&{:#x}).reciprocal_sqrt_prec_ref({}) = ({:#x}, {:?})",
ComparableFloat(x),
prec,
ComparableFloat(sum),
o
);
}
}
fn demo_float_reciprocal_sqrt_prec_assign(gm: GenMode, config: &GenConfig, limit: usize) {
for (mut x, prec) in float_unsigned_pair_gen_var_1().get(gm, config).take(limit) {
let x_old = x.clone();
x.reciprocal_sqrt_prec_assign(prec);
println!("x := {x_old}; x.reciprocal_sqrt_prec_assign({prec}); x = {x}");
}
}
fn demo_float_reciprocal_sqrt_prec_assign_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (mut x, prec) in float_unsigned_pair_gen_var_1().get(gm, config).take(limit) {
let x_old = x.clone();
let o = x.reciprocal_sqrt_prec_assign(prec);
println!(
"x := {:#x}; x.reciprocal_sqrt_prec_assign({}) = {:?}; x = {:#x}",
ComparableFloat(x_old),
prec,
o,
ComparableFloat(x)
);
}
}
fn demo_float_reciprocal_sqrt_round(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, rm) in float_rounding_mode_pair_gen_var_30()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
println!(
"({}).reciprocal_sqrt_round({}) = {:?}",
x_old,
rm,
x.reciprocal_sqrt_round(rm)
);
}
}
fn demo_float_reciprocal_sqrt_round_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, rm) in float_rounding_mode_pair_gen_var_30()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
let (sum, o) = x.reciprocal_sqrt_round(rm);
println!(
"({:#x}).reciprocal_sqrt_round({}) = ({:#x}, {:?})",
ComparableFloat(x_old),
rm,
ComparableFloat(sum),
o
);
}
}
fn demo_float_reciprocal_sqrt_round_extreme(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, rm) in float_rounding_mode_pair_gen_var_31()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
println!(
"({}).reciprocal_sqrt_round({}) = {:?}",
x_old,
rm,
x.reciprocal_sqrt_round(rm)
);
}
}
fn demo_float_reciprocal_sqrt_round_extreme_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, rm) in float_rounding_mode_pair_gen_var_31()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
let (sum, o) = x.reciprocal_sqrt_round(rm);
println!(
"({:#x}).reciprocal_sqrt_round({}) = ({:#x}, {:?})",
ComparableFloat(x_old),
rm,
ComparableFloat(sum),
o
);
}
}
fn demo_float_reciprocal_sqrt_round_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, rm) in float_rounding_mode_pair_gen_var_30()
.get(gm, config)
.take(limit)
{
println!(
"(&{}).reciprocal_sqrt_round_ref({}) = {:?}",
x,
rm,
x.reciprocal_sqrt_round_ref(rm)
);
}
}
fn demo_float_reciprocal_sqrt_round_ref_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, rm) in float_rounding_mode_pair_gen_var_30()
.get(gm, config)
.take(limit)
{
let (sum, o) = x.reciprocal_sqrt_round_ref(rm);
println!(
"(&{:#x}).reciprocal_sqrt_round_ref({}) = ({:#x}, {:?})",
ComparableFloat(x),
rm,
ComparableFloat(sum),
o
);
}
}
fn demo_float_reciprocal_sqrt_round_assign(gm: GenMode, config: &GenConfig, limit: usize) {
for (mut x, rm) in float_rounding_mode_pair_gen_var_30()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
x.reciprocal_sqrt_round_assign(rm);
println!("x := {x_old}; x.reciprocal_sqrt_round_assign({rm}); x = {x}");
}
}
fn demo_float_reciprocal_sqrt_round_assign_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (mut x, rm) in float_rounding_mode_pair_gen_var_30()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
let o = x.reciprocal_sqrt_round_assign(rm);
println!(
"x := {:#x}; x.reciprocal_sqrt_round_assign({}) = {:?}; x = {:#x}",
ComparableFloat(x_old),
rm,
o,
ComparableFloat(x)
);
}
}
fn demo_float_reciprocal_sqrt_prec_round(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec, rm) in float_unsigned_rounding_mode_triple_gen_var_15()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
println!(
"({}).reciprocal_sqrt_prec_round({}, {}) = {:?}",
x_old,
prec,
rm,
x.reciprocal_sqrt_prec_round(prec, rm)
);
}
}
fn demo_float_reciprocal_sqrt_prec_round_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec, rm) in float_unsigned_rounding_mode_triple_gen_var_15()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
let (sum, o) = x.reciprocal_sqrt_prec_round(prec, rm);
println!(
"({:#x}).reciprocal_sqrt_prec_round({}, {}) = ({:#x}, {:?})",
ComparableFloat(x_old),
prec,
rm,
ComparableFloat(sum),
o
);
}
}
fn demo_float_reciprocal_sqrt_prec_round_extreme(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec, rm) in float_unsigned_rounding_mode_triple_gen_var_16()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
println!(
"({}).reciprocal_sqrt_prec_round({}, {}) = {:?}",
x_old,
prec,
rm,
x.reciprocal_sqrt_prec_round(prec, rm)
);
}
}
fn demo_float_reciprocal_sqrt_prec_round_extreme_debug(
gm: GenMode,
config: &GenConfig,
limit: usize,
) {
for (x, prec, rm) in float_unsigned_rounding_mode_triple_gen_var_16()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
let (sum, o) = x.reciprocal_sqrt_prec_round(prec, rm);
println!(
"({:#x}).reciprocal_sqrt_prec_round({}, {}) = ({:#x}, {:?})",
ComparableFloat(x_old),
prec,
rm,
ComparableFloat(sum),
o
);
}
}
fn demo_float_reciprocal_sqrt_prec_round_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec, rm) in float_unsigned_rounding_mode_triple_gen_var_15()
.get(gm, config)
.take(limit)
{
println!(
"({}).reciprocal_sqrt_prec_round_ref({}, {}) = {:?}",
x,
prec,
rm,
x.reciprocal_sqrt_prec_round_ref(prec, rm)
);
}
}
fn demo_float_reciprocal_sqrt_prec_round_ref_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, prec, rm) in float_unsigned_rounding_mode_triple_gen_var_15()
.get(gm, config)
.take(limit)
{
let (sum, o) = x.reciprocal_sqrt_prec_round_ref(prec, rm);
println!(
"({:#x}).reciprocal_sqrt_prec_round_ref({}, {}) = ({:#x}, {:?})",
ComparableFloat(x),
prec,
rm,
ComparableFloat(sum),
o
);
}
}
fn demo_float_reciprocal_sqrt_prec_round_assign(gm: GenMode, config: &GenConfig, limit: usize) {
for (mut x, prec, rm) in float_unsigned_rounding_mode_triple_gen_var_15()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
let o = x.reciprocal_sqrt_prec_round_assign(prec, rm);
println!("x := {x_old}; x.reciprocal_sqrt_prec_round({prec}, {rm}) = {o:?}; x = {x}");
}
}
fn demo_float_reciprocal_sqrt_prec_round_assign_debug(
gm: GenMode,
config: &GenConfig,
limit: usize,
) {
for (mut x, prec, rm) in float_unsigned_rounding_mode_triple_gen_var_15()
.get(gm, config)
.take(limit)
{
let x_old = x.clone();
let o = x.reciprocal_sqrt_prec_round_assign(prec, rm);
println!(
"x := {:#x}; x.reciprocal_sqrt_prec_round({}, {}) = {:?}; x = {:#x}",
ComparableFloat(x_old),
prec,
rm,
o,
ComparableFloat(x)
);
}
}
#[allow(clippy::type_repetition_in_bounds)]
fn demo_primitive_float_reciprocal_sqrt<T: PrimitiveFloat>(
gm: GenMode,
config: &GenConfig,
limit: usize,
) where
Float: From<T> + PartialOrd<T>,
for<'a> T: ExactFrom<&'a Float> + RoundingFrom<&'a Float>,
{
for x in primitive_float_gen::<T>().get(gm, config).take(limit) {
println!(
"primitive_float_reciprocal_sqrt({}) = {}",
NiceFloat(x),
NiceFloat(primitive_float_reciprocal_sqrt(x))
);
}
}
fn demo_float_reciprocal_sqrt_rational_prec(gm: GenMode, config: &GenConfig, limit: usize) {
for (n, p) in rational_unsigned_pair_gen_var_3()
.get(gm, config)
.take(limit)
{
println!(
"Float::reciprocal_sqrt_rational_prec({}, {}) = {:?}",
n.clone(),
p,
Float::reciprocal_sqrt_rational_prec(n, p)
);
}
}
fn demo_float_reciprocal_sqrt_rational_prec_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (n, p) in rational_unsigned_pair_gen_var_3()
.get(gm, config)
.take(limit)
{
let (f, o) = Float::reciprocal_sqrt_rational_prec(n.clone(), p);
println!(
"Float::reciprocal_sqrt_rational_prec({}, {}) = ({:#x}, {:?})",
n,
p,
ComparableFloat(f),
o
);
}
}
fn demo_float_reciprocal_sqrt_rational_prec_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (n, p) in rational_unsigned_pair_gen_var_3()
.get(gm, config)
.take(limit)
{
println!(
"Float::reciprocal_sqrt_rational_prec_ref(&{}, {}) = {:?}",
n,
p,
Float::reciprocal_sqrt_rational_prec_ref(&n, p)
);
}
}
fn demo_float_reciprocal_sqrt_rational_prec_ref_debug(
gm: GenMode,
config: &GenConfig,
limit: usize,
) {
for (n, p) in rational_unsigned_pair_gen_var_3()
.get(gm, config)
.take(limit)
{
let (f, o) = Float::reciprocal_sqrt_rational_prec_ref(&n, p);
println!(
"Float::reciprocal_sqrt_rational_prec_ref(&{}, {}) = {:x?}",
n,
p,
(ComparableFloat(f), o)
);
}
}
fn demo_float_reciprocal_sqrt_rational_prec_round(gm: GenMode, config: &GenConfig, limit: usize) {
for (n, p, rm) in rational_unsigned_rounding_mode_triple_gen_var_4()
.get(gm, config)
.take(limit)
{
println!(
"Float::reciprocal_sqrt_rational_prec_round({}, {}, {:?}) = {:?}",
n.clone(),
p,
rm,
Float::reciprocal_sqrt_rational_prec_round(n, p, rm)
);
}
}
fn demo_float_reciprocal_sqrt_rational_prec_round_debug(
gm: GenMode,
config: &GenConfig,
limit: usize,
) {
for (n, p, rm) in rational_unsigned_rounding_mode_triple_gen_var_4()
.get(gm, config)
.take(limit)
{
let (f, o) = Float::reciprocal_sqrt_rational_prec_round(n.clone(), p, rm);
println!(
"Float::reciprocal_sqrt_rational_prec_round({}, {}, {:?}) = {:x?}",
n,
p,
rm,
(ComparableFloat(f), o)
);
}
}
fn demo_float_reciprocal_sqrt_rational_prec_round_ref(
gm: GenMode,
config: &GenConfig,
limit: usize,
) {
for (n, p, rm) in rational_unsigned_rounding_mode_triple_gen_var_4()
.get(gm, config)
.take(limit)
{
println!(
"Float::reciprocal_sqrt_rational_prec_round_ref(&{}, {}, {:?}) = {:?}",
n,
p,
rm,
Float::reciprocal_sqrt_rational_prec_round_ref(&n, p, rm)
);
}
}
fn demo_float_reciprocal_sqrt_rational_prec_round_ref_debug(
gm: GenMode,
config: &GenConfig,
limit: usize,
) {
for (n, p, rm) in rational_unsigned_rounding_mode_triple_gen_var_4()
.get(gm, config)
.take(limit)
{
let (f, o) = Float::reciprocal_sqrt_rational_prec_round_ref(&n, p, rm);
println!(
"Float::reciprocal_sqrt_rational_prec_round_ref(&{}, {}, {:?}) = {:x?}",
n,
p,
rm,
(ComparableFloat(f), o)
);
}
}
#[allow(clippy::type_repetition_in_bounds)]
fn demo_primitive_float_reciprocal_sqrt_rational<T: PrimitiveFloat>(
gm: GenMode,
config: &GenConfig,
limit: usize,
) where
Float: From<T> + PartialOrd<T>,
for<'a> T: ExactFrom<&'a Float> + RoundingFrom<&'a Float>,
{
for x in rational_gen().get(gm, config).take(limit) {
println!(
"primitive_float_reciprocal_sqrt_rational({}) = {:?}",
x,
NiceFloat(primitive_float_reciprocal_sqrt_rational::<T>(&x))
);
}
}
#[allow(clippy::no_effect, unused_must_use)]
fn benchmark_float_reciprocal_sqrt_evaluation_strategy(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt()",
BenchmarkType::EvaluationStrategy,
float_gen().get(gm, config),
gm.name(),
limit,
file_name,
&float_complexity_bucketer("x"),
&mut [
("Float.reciprocal_sqrt()", &mut |x| {
no_out!(x.reciprocal_sqrt());
}),
("(&Float).reciprocal_sqrt()", &mut |x| {
no_out!((&x).reciprocal_sqrt());
}),
],
);
}
fn benchmark_float_reciprocal_sqrt_library_comparison(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt()",
BenchmarkType::LibraryComparison,
float_gen_rm().get(gm, config),
gm.name(),
limit,
file_name,
&pair_2_float_complexity_bucketer("x"),
&mut [
("Malachite", &mut |(_, x)| no_out!((&x).reciprocal_sqrt())),
("rug", &mut |(x, _)| no_out!(rug_reciprocal_sqrt(&x))),
],
);
}
fn benchmark_float_reciprocal_sqrt_assign(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_assign()",
BenchmarkType::Single,
float_gen().get(gm, config),
gm.name(),
limit,
file_name,
&float_complexity_bucketer("x"),
&mut [("Float.reciprocal_sqrt_assign()", &mut |mut x| {
x.reciprocal_sqrt_assign();
})],
);
}
fn benchmark_float_reciprocal_sqrt_prec_evaluation_strategy(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_prec(u64)",
BenchmarkType::EvaluationStrategy,
float_unsigned_pair_gen_var_1().get(gm, config),
gm.name(),
limit,
file_name,
&pair_float_primitive_int_max_complexity_bucketer("x", "prec"),
&mut [
("Float.reciprocal_sqrt_prec(u64)", &mut |(x, prec)| {
no_out!(x.reciprocal_sqrt_prec(prec));
}),
(
"(&Float).reciprocal_sqrt_prec_ref(u64)",
&mut |(x, prec)| {
no_out!(x.reciprocal_sqrt_prec_ref(prec));
},
),
],
);
}
fn benchmark_float_reciprocal_sqrt_prec_library_comparison(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_prec(u64)",
BenchmarkType::LibraryComparison,
float_unsigned_pair_gen_var_1_rm().get(gm, config),
gm.name(),
limit,
file_name,
&pair_2_pair_float_primitive_int_max_complexity_bucketer("x", "prec"),
&mut [
("Malachite", &mut |(_, (x, prec))| {
no_out!(x.reciprocal_sqrt_prec_ref(prec));
}),
("rug", &mut |((x, prec), _)| {
no_out!(rug_reciprocal_sqrt_prec(&x, prec));
}),
],
);
}
fn benchmark_float_reciprocal_sqrt_prec_assign(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_prec_assign(u64)",
BenchmarkType::Single,
float_unsigned_pair_gen_var_1().get(gm, config),
gm.name(),
limit,
file_name,
&pair_float_primitive_int_max_complexity_bucketer("x", "prec"),
&mut [("Float.reciprocal_sqrt_prec_assign(u64)", &mut |(
mut x,
prec,
)| {
no_out!(x.reciprocal_sqrt_prec_assign(prec));
})],
);
}
fn benchmark_float_reciprocal_sqrt_round_evaluation_strategy(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_round(RoundingMode)",
BenchmarkType::EvaluationStrategy,
float_rounding_mode_pair_gen_var_30().get(gm, config),
gm.name(),
limit,
file_name,
&pair_1_float_complexity_bucketer("x"),
&mut [
(
"Float.reciprocal_sqrt_round(RoundingMode)",
&mut |(x, rm)| {
no_out!(x.reciprocal_sqrt_round(rm));
},
),
(
"(&Float).reciprocal_sqrt_round_ref(RoundingMode)",
&mut |(x, rm)| {
no_out!(x.reciprocal_sqrt_round_ref(rm));
},
),
],
);
}
fn benchmark_float_reciprocal_sqrt_round_library_comparison(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_round(RoundingMode)",
BenchmarkType::LibraryComparison,
float_rounding_mode_pair_gen_var_30_rm().get(gm, config),
gm.name(),
limit,
file_name,
&pair_2_pair_1_float_complexity_bucketer("x"),
&mut [
("Malachite", &mut |(_, (x, rm))| {
no_out!(x.reciprocal_sqrt_round_ref(rm));
}),
("rug", &mut |((x, rm), _)| {
no_out!(rug_reciprocal_sqrt_round(&x, rm));
}),
],
);
}
fn benchmark_float_reciprocal_sqrt_round_assign(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_round_assign(RoundingMode)",
BenchmarkType::Single,
float_rounding_mode_pair_gen_var_30().get(gm, config),
gm.name(),
limit,
file_name,
&pair_1_float_complexity_bucketer("x"),
&mut [(
"Float.reciprocal_sqrt_round_assign(RoundingMode)",
&mut |(mut x, rm)| {
no_out!(x.reciprocal_sqrt_round_assign(rm));
},
)],
);
}
fn benchmark_float_reciprocal_sqrt_prec_round_evaluation_strategy(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_prec_round(u64, RoundingMode)",
BenchmarkType::EvaluationStrategy,
float_unsigned_rounding_mode_triple_gen_var_15().get(gm, config),
gm.name(),
limit,
file_name,
&triple_1_2_float_primitive_int_max_complexity_bucketer("x", "prec"),
&mut [
(
"Float.reciprocal_sqrt_prec_round(u64, RoundingMode)",
&mut |(x, prec, rm)| no_out!(x.reciprocal_sqrt_prec_round(prec, rm)),
),
(
"(&Float).reciprocal_sqrt_prec_round_ref(u64, RoundingMode)",
&mut |(x, prec, rm)| no_out!(x.reciprocal_sqrt_prec_round_ref(prec, rm)),
),
],
);
}
fn benchmark_float_reciprocal_sqrt_prec_round_library_comparison(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_prec_round(u64, RoundingMode)",
BenchmarkType::LibraryComparison,
float_unsigned_rounding_mode_triple_gen_var_15_rm().get(gm, config),
gm.name(),
limit,
file_name,
&pair_2_triple_1_2_float_primitive_int_max_complexity_bucketer("x", "prec"),
&mut [
("Malachite", &mut |(_, (x, prec, rm))| {
no_out!(x.reciprocal_sqrt_prec_round_ref(prec, rm));
}),
("rug", &mut |((x, prec, rm), _)| {
no_out!(rug_reciprocal_sqrt_prec_round(&x, prec, rm));
}),
],
);
}
fn benchmark_float_reciprocal_sqrt_prec_round_assign(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float.reciprocal_sqrt_prec_round_assign(u64, RoundingMode)",
BenchmarkType::Single,
float_unsigned_rounding_mode_triple_gen_var_15().get(gm, config),
gm.name(),
limit,
file_name,
&triple_1_2_float_primitive_int_max_complexity_bucketer("x", "prec"),
&mut [(
"Float.reciprocal_sqrt_prec_round_assign(u64, RoundingMode)",
&mut |(mut x, prec, rm)| no_out!(x.reciprocal_sqrt_prec_round_assign(prec, rm)),
)],
);
}
#[allow(clippy::type_repetition_in_bounds)]
fn benchmark_primitive_float_reciprocal_sqrt<T: PrimitiveFloat>(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) where
Float: From<T> + PartialOrd<T>,
for<'a> T: ExactFrom<&'a Float> + RoundingFrom<&'a Float>,
{
run_benchmark(
&format!("primitive_float_reciprocal_sqrt({})", T::NAME),
BenchmarkType::EvaluationStrategy,
primitive_float_gen::<T>().get(gm, config),
gm.name(),
limit,
file_name,
&primitive_float_bucketer("x"),
&mut [("malachite", &mut |x| {
no_out!(primitive_float_reciprocal_sqrt(x));
})],
);
}
fn benchmark_float_reciprocal_sqrt_rational_prec_evaluation_strategy(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float::reciprocal_sqrt_rational_prec(Rational, u64)",
BenchmarkType::EvaluationStrategy,
rational_unsigned_pair_gen_var_3().get(gm, config),
gm.name(),
limit,
file_name,
&pair_rational_bit_u64_max_bucketer("n", "prec"),
&mut [
(
"Float::reciprocal_sqrt_rational_prec(Rational, u64)",
&mut |(n, prec)| no_out!(Float::reciprocal_sqrt_rational_prec(n, prec)),
),
(
"Float::reciprocal_sqrt_rational_prec_ref(&Rational, u64)",
&mut |(n, prec)| no_out!(Float::reciprocal_sqrt_rational_prec_ref(&n, prec)),
),
],
);
}
fn benchmark_float_reciprocal_sqrt_rational_prec_round_evaluation_strategy(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float::reciprocal_sqrt_rational_prec_round(Rational, u64, RoundingMode)",
BenchmarkType::EvaluationStrategy,
rational_unsigned_rounding_mode_triple_gen_var_4().get(gm, config),
gm.name(),
limit,
file_name,
&triple_1_2_rational_bit_u64_max_bucketer("n", "prec"),
&mut [
(
"Float::reciprocal_sqrt_rational_prec(Rational, u64, RoundingMode)",
&mut |(n, prec, rm)| {
no_out!(Float::reciprocal_sqrt_rational_prec_round(n, prec, rm));
},
),
(
"Float::reciprocal_sqrt_rational_prec_ref(&Rational, u64, RoundingMode)",
&mut |(n, prec, rm)| {
no_out!(Float::reciprocal_sqrt_rational_prec_round_ref(&n, prec, rm));
},
),
],
);
}
fn benchmark_float_reciprocal_sqrt_rational_prec_round_algorithms(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float::reciprocal_sqrt_rational_prec_round(Rational, u64, RoundingMode)",
BenchmarkType::EvaluationStrategy,
rational_unsigned_rounding_mode_triple_gen_var_4().get(gm, config),
gm.name(),
limit,
file_name,
&triple_1_2_rational_bit_u64_max_bucketer("n", "prec"),
&mut [
("default", &mut |(n, prec, rm)| {
no_out!(Float::reciprocal_sqrt_rational_prec_round_ref(&n, prec, rm));
}),
("generic", &mut |(n, prec, rm)| {
no_out!(reciprocal_sqrt_rational_prec_round_generic(&n, prec, rm));
}),
("simple", &mut |(n, prec, rm)| {
no_out!(reciprocal_sqrt_rational_prec_round_simple(&n, prec, rm));
}),
],
);
}
#[allow(clippy::type_repetition_in_bounds)]
fn benchmark_primitive_float_reciprocal_sqrt_rational<T: PrimitiveFloat>(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) where
Float: From<T> + PartialOrd<T>,
for<'a> T: ExactFrom<&'a Float> + RoundingFrom<&'a Float>,
{
run_benchmark(
&format!(
"primitive_float_reciprocal_sqrt_rational_prec::<{}>(Rational)",
T::NAME
),
BenchmarkType::Single,
rational_gen().get(gm, config),
gm.name(),
limit,
file_name,
&rational_bit_bucketer("x"),
&mut [("Malachite", &mut |x| {
no_out!(primitive_float_reciprocal_sqrt_rational::<T>(&x));
})],
);
}