use malachite_base::rounding_modes::RoundingMode::*;
use malachite_base::test_util::bench::bucketers::{pair_1_bucketer, unsigned_direct_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::{
unsigned_gen_var_11, unsigned_rounding_mode_pair_gen_var_4,
};
use malachite_base::test_util::runner::Runner;
use malachite_float::ComparableFloat;
use malachite_float::Float;
use malachite_float::test_util::constants::lemniscate_constant::*;
pub(crate) fn register(runner: &mut Runner) {
register_demo!(runner, demo_float_lemniscate_constant_prec_round);
register_demo!(runner, demo_float_lemniscate_constant_prec_round_debug);
register_demo!(runner, demo_float_lemniscate_constant_prec);
register_demo!(runner, demo_float_lemniscate_constant_prec_debug);
register_bench!(
runner,
benchmark_float_lemniscate_constant_prec_round_algorithms
);
register_bench!(runner, benchmark_float_lemniscate_constant_prec_algorithms);
}
fn demo_float_lemniscate_constant_prec_round(gm: GenMode, config: &GenConfig, limit: usize) {
for (p, rm) in unsigned_rounding_mode_pair_gen_var_4()
.get(gm, config)
.take(limit)
{
println!(
"lemniscate_constant_prec_round({}, {}) = {:?}",
p,
rm,
Float::lemniscate_constant_prec_round(p, rm)
);
}
}
fn demo_float_lemniscate_constant_prec_round_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for (p, rm) in unsigned_rounding_mode_pair_gen_var_4()
.get(gm, config)
.take(limit)
{
let (pc, o) = Float::lemniscate_constant_prec_round(p, rm);
println!(
"lemniscate_constant_prec_round({}, {}) = ({:#x}, {:?})",
p,
rm,
ComparableFloat(pc),
o
);
}
}
fn demo_float_lemniscate_constant_prec(gm: GenMode, config: &GenConfig, limit: usize) {
for p in unsigned_gen_var_11().get(gm, config).take(limit) {
println!(
"lemniscate_constant_prec({}) = {:?}",
p,
Float::lemniscate_constant_prec(p)
);
}
}
fn demo_float_lemniscate_constant_prec_debug(gm: GenMode, config: &GenConfig, limit: usize) {
for p in unsigned_gen_var_11().get(gm, config).take(limit) {
let (pc, o) = Float::lemniscate_constant_prec(p);
println!(
"lemniscate_constant_prec({}) = ({:#x}, {:?})",
p,
ComparableFloat(pc),
o
);
}
}
fn benchmark_float_lemniscate_constant_prec_round_algorithms(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float::lemniscate_constant_prec_round(u64, RoundingMode)",
BenchmarkType::Algorithms,
unsigned_rounding_mode_pair_gen_var_4().get(gm, config),
gm.name(),
limit,
file_name,
&pair_1_bucketer("prec"),
&mut [
("default", &mut |(p, rm)| {
no_out!(Float::lemniscate_constant_prec_round(p, rm));
}),
("simple", &mut |(p, rm)| {
no_out!(lemniscate_constant_prec_round_simple(p, rm));
}),
],
);
}
fn benchmark_float_lemniscate_constant_prec_algorithms(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Float::lemniscate_constant_prec(u64)",
BenchmarkType::Algorithms,
unsigned_gen_var_11().get(gm, config),
gm.name(),
limit,
file_name,
&unsigned_direct_bucketer(),
&mut [
("default", &mut |p| {
no_out!(Float::lemniscate_constant_prec(p));
}),
("simple", &mut |p| {
no_out!(lemniscate_constant_prec_round_simple(p, Nearest));
}),
],
);
}