use malachite_base::num::arithmetic::traits::{ModAdd, ModAddAssign};
use malachite_base::test_util::bench::{BenchmarkType, run_benchmark};
use malachite_base::test_util::generators::common::{GenConfig, GenMode};
use malachite_base::test_util::runner::Runner;
use malachite_nz::test_util::bench::bucketers::triple_3_natural_bit_bucketer;
use malachite_nz::test_util::generators::natural_triple_gen_var_3;
pub(crate) fn register(runner: &mut Runner) {
register_demo!(runner, demo_natural_mod_add_assign);
register_demo!(runner, demo_natural_mod_add_assign_val_ref);
register_demo!(runner, demo_natural_mod_add_assign_ref_val);
register_demo!(runner, demo_natural_mod_add_assign_ref_ref);
register_demo!(runner, demo_natural_mod_add);
register_demo!(runner, demo_natural_mod_add_val_val_ref);
register_demo!(runner, demo_natural_mod_add_val_ref_val);
register_demo!(runner, demo_natural_mod_add_val_ref_ref);
register_demo!(runner, demo_natural_mod_add_ref_val_val);
register_demo!(runner, demo_natural_mod_add_ref_val_ref);
register_demo!(runner, demo_natural_mod_add_ref_ref_val);
register_demo!(runner, demo_natural_mod_add_ref_ref_ref);
register_bench!(runner, benchmark_natural_mod_add_assign_evaluation_strategy);
register_bench!(runner, benchmark_natural_mod_add_algorithms);
register_bench!(runner, benchmark_natural_mod_add_evaluation_strategy);
}
fn demo_natural_mod_add_assign(gm: GenMode, config: &GenConfig, limit: usize) {
for (mut x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let x_old = x.clone();
let y_old = y.clone();
let m_old = m.clone();
x.mod_add_assign(y, m);
println!("x := {x_old}; x.mod_add_assign({y_old}, {m_old}); x = {x}");
}
}
fn demo_natural_mod_add_assign_val_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (mut x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let m_old = m.clone();
let y_old = y.clone();
x.mod_add_assign(y, &m);
println!("x := {x}; x.mod_add_assign({y_old}, &{m_old}); x = {x}");
}
}
fn demo_natural_mod_add_assign_ref_val(gm: GenMode, config: &GenConfig, limit: usize) {
for (mut x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let x_old = x.clone();
let m_old = m.clone();
x.mod_add_assign(&y, m);
println!("x := {x_old}; x.mod_add_assign(&{y}, {m_old}); x = {x}");
}
}
fn demo_natural_mod_add_assign_ref_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (mut x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let x_old = x.clone();
x.mod_add_assign(&y, &m);
println!("x := {x_old}; x.mod_add_assign(&{y}, &{m}); x = {x}");
}
}
fn demo_natural_mod_add(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let x_old = x.clone();
let y_old = y.clone();
let m_old = m.clone();
println!("{} + {} ≡ {} mod {}", x_old, y_old, x.mod_add(y, m), m_old);
}
}
fn demo_natural_mod_add_val_val_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let x_old = x.clone();
let y_old = y.clone();
println!("{} + {} ≡ {} mod {}", x_old, y_old, x.mod_add(y, &m), m);
}
}
fn demo_natural_mod_add_val_ref_val(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let x_old = x.clone();
let m_old = m.clone();
println!("{} + {} ≡ {} mod {}", x_old, y, x.mod_add(&y, m), m_old);
}
}
fn demo_natural_mod_add_val_ref_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let x_old = x.clone();
println!("{} + {} ≡ {} mod {}", x_old, y, x.mod_add(&y, &m), m);
}
}
fn demo_natural_mod_add_ref_val_val(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let y_old = y.clone();
let m_old = m.clone();
println!("{} + {} ≡ {} mod {}", x, y_old, (&x).mod_add(y, m), m_old);
}
}
fn demo_natural_mod_add_ref_val_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let y_old = y.clone();
println!("{} + {} ≡ {} mod {}", x, y_old, (&x).mod_add(y, &m), m);
}
}
fn demo_natural_mod_add_ref_ref_val(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
let m_old = m.clone();
println!("{} + {} ≡ {} mod {}", x, y, (&x).mod_add(&y, m), m_old);
}
}
fn demo_natural_mod_add_ref_ref_ref(gm: GenMode, config: &GenConfig, limit: usize) {
for (x, y, m) in natural_triple_gen_var_3().get(gm, config).take(limit) {
println!("{} + {} ≡ {} mod {}", x, y, (&x).mod_add(&y, &m), m);
}
}
fn benchmark_natural_mod_add_assign_evaluation_strategy(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Natural.mod_add_assign(Natural, Natural)",
BenchmarkType::EvaluationStrategy,
natural_triple_gen_var_3().get(gm, config),
gm.name(),
limit,
file_name,
&triple_3_natural_bit_bucketer("m"),
&mut [
(
"Natural.mod_add_assign(Natural, Natural)",
&mut |(mut x, y, m)| no_out!(x.mod_add_assign(y, m)),
),
(
"Natural.mod_add_assign(Natural, &Natural)",
&mut |(mut x, y, m)| no_out!(x.mod_add_assign(y, &m)),
),
(
"Natural.mod_add_assign(&Natural, Natural)",
&mut |(mut x, y, m)| no_out!(x.mod_add_assign(&y, m)),
),
(
"Natural.mod_add_assign(&Natural, &Natural)",
&mut |(mut x, y, m)| no_out!(x.mod_add_assign(&y, &m)),
),
],
);
}
#[allow(clippy::no_effect, unused_must_use)]
fn benchmark_natural_mod_add_algorithms(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Natural.mod_add(Natural, Natural)",
BenchmarkType::Algorithms,
natural_triple_gen_var_3().get(gm, config),
gm.name(),
limit,
file_name,
&triple_3_natural_bit_bucketer("m"),
&mut [
("default", &mut |(x, y, m)| no_out!(x.mod_add(y, m))),
("naive", &mut |(x, y, m)| no_out!((x + y) % m)),
],
);
}
fn benchmark_natural_mod_add_evaluation_strategy(
gm: GenMode,
config: &GenConfig,
limit: usize,
file_name: &str,
) {
run_benchmark(
"Natural.mod_add(Natural, Natural)",
BenchmarkType::EvaluationStrategy,
natural_triple_gen_var_3().get(gm, config),
gm.name(),
limit,
file_name,
&triple_3_natural_bit_bucketer("m"),
&mut [
("Natural.mod_add(Natural, Natural)", &mut |(x, y, m)| {
no_out!(x.mod_add(y, m));
}),
("Natural.mod_add(Natural, &Natural)", &mut |(x, y, m)| {
no_out!(x.mod_add(y, &m));
}),
("Natural.mod_add(&Natural, Natural)", &mut |(x, y, m)| {
no_out!(x.mod_add(&y, m));
}),
("Natural.mod_add(&Natural, &Natural)", &mut |(x, y, m)| {
no_out!(x.mod_add(&y, &m));
}),
("(&Natural).mod_add(Natural, Natural)", &mut |(x, y, m)| {
no_out!((&x).mod_add(y, m));
}),
("(&Natural).mod_add(Natural, &Natural)", &mut |(x, y, m)| {
no_out!((&x).mod_add(y, &m));
}),
("(&Natural).mod_add(&Natural, Natural)", &mut |(x, y, m)| {
no_out!((&x).mod_add(&y, m));
}),
(
"(&Natural).mod_add(&Natural, &Natural)",
&mut |(x, y, m)| no_out!((&x).mod_add(&y, &m)),
),
],
);
}