use malachite_base::num::basic::unsigneds::PrimitiveUnsigned;
use malachite_base::test_util::bench::bucketers::pair_2_bucketer;
use malachite_base::test_util::bench::{run_benchmark, BenchmarkType};
use malachite_base::test_util::generators::common::{GenConfig, GenMode};
use malachite_base::test_util::generators::unsigned_pair_gen_var_2;
use malachite_base::test_util::runner::Runner;
pub(crate) fn register(runner: &mut Runner) {
register_unsigned_demos!(runner, demo_mod_power_of_2_is_reduced);
register_unsigned_benches!(runner, benchmark_mod_power_of_2_is_reduced);
}
fn demo_mod_power_of_2_is_reduced<T: PrimitiveUnsigned>(
gm: GenMode,
config: GenConfig,
limit: usize,
) {
for (n, pow) in unsigned_pair_gen_var_2::<T, u64>()
.get(gm, &config)
.take(limit)
{
if n.mod_power_of_2_is_reduced(pow) {
println!("{} is reduced mod 2^{}", n, pow);
} else {
println!("{} is not reduced mod 2^{}", n, pow);
}
}
}
fn benchmark_mod_power_of_2_is_reduced<T: PrimitiveUnsigned>(
gm: GenMode,
config: GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
&format!("{}.mod_power_of_2_is_reduced(u64)", T::NAME),
BenchmarkType::Single,
unsigned_pair_gen_var_2::<T, u64>().get(gm, &config),
gm.name(),
limit,
file_name,
&pair_2_bucketer("pow"),
&mut [("Malachite", &mut |(n, pow)| {
no_out!(n.mod_power_of_2_is_reduced(pow))
})],
);
}