SummationByParts/sbp/benches/maxwell.rs

56 lines
1.6 KiB
Rust
Raw Normal View History

2020-01-27 20:00:44 +00:00
use criterion::{black_box, criterion_group, criterion_main, Criterion};
2020-01-29 20:06:50 +00:00
use sbp::maxwell::System;
use sbp::operators::{SbpOperator2d, Upwind4, UpwindOperator2d, SBP4};
use sbp::Float;
2020-01-27 20:00:44 +00:00
fn advance_system<SBP: SbpOperator2d>(universe: &mut System<SBP>, n: usize) {
2020-01-27 20:00:44 +00:00
for _ in 0..n {
universe.advance(0.01);
}
}
fn advance_system_upwind<UO: UpwindOperator2d>(universe: &mut System<UO>, n: usize) {
2020-01-27 20:00:44 +00:00
for _ in 0..n {
universe.advance_upwind(0.01);
}
}
fn performance_benchmark(c: &mut Criterion) {
2020-01-27 20:20:34 +00:00
let mut group = c.benchmark_group("MaxwellSystem");
2020-01-27 20:00:44 +00:00
group.sample_size(25);
let w = 40;
let h = 26;
let x = ndarray::Array2::from_shape_fn((h, w), |(_, i)| i as Float / (w - 1) as Float);
let y = ndarray::Array2::from_shape_fn((h, w), |(j, _)| j as Float / (h - 1) as Float);
2020-01-27 20:00:44 +00:00
2020-04-14 19:59:02 +00:00
let mut universe = System::new(x.clone(), y.clone(), Upwind4);
2020-01-27 20:00:44 +00:00
group.bench_function("advance", |b| {
b.iter(|| {
universe.set_gaussian(0.5, 0.5);
advance_system(&mut universe, black_box(20))
})
});
2020-04-14 19:59:02 +00:00
let mut universe = System::new(x.clone(), y.clone(), Upwind4);
2020-01-27 20:00:44 +00:00
group.bench_function("advance_upwind", |b| {
b.iter(|| {
universe.set_gaussian(0.5, 0.5);
advance_system_upwind(&mut universe, black_box(20))
})
});
2020-04-14 19:59:02 +00:00
let mut universe = System::new(x, y, SBP4);
2020-01-27 20:00:44 +00:00
group.bench_function("advance_trad4", |b| {
b.iter(|| {
universe.set_gaussian(0.5, 0.5);
advance_system(&mut universe, black_box(20))
})
});
group.finish();
}
criterion_group!(benches, performance_benchmark);
criterion_main!(benches);