benchmark improvements

This commit is contained in:
2025-02-28 20:39:47 -05:00
parent d97a432066
commit 60b4fdd836
2 changed files with 14 additions and 11 deletions

View File

@@ -1,33 +1,36 @@
use criterion::{criterion_group, criterion_main, BenchmarkId, Criterion};
use criterion::{criterion_group, criterion_main, BenchmarkId, Criterion, Throughput};
use othello::{
logic::{FutureMoveConfig, FutureMoves},
repr::{Board, Piece},
};
use std::time::Duration;
fn extend_layers_test(depth: usize) {
fn extend_layers_test(depth: usize, arena_size: usize) -> usize {
let config = FutureMoveConfig {
max_depth: depth,
min_arena_depth_sub: 4,
top_k_children: 2,
up_to_minus: 4,
max_arena_size: 10_000_000,
up_to_minus: usize::MAX, // disable pruning
max_arena_size: arena_size,
};
let mut fut = FutureMoves::new(Piece::Black, config);
fut.set_root_from_board(Board::new().starting_pos());
fut.extend_layers();
fut.arena_len()
}
fn criterion_benchmark(c: &mut Criterion) {
let mut group = c.benchmark_group("extend_layer");
group.measurement_time(Duration::from_secs(10));
group.sample_size(1000);
// group.measurement_time(Duration::from_secs(10));
// group.sample_size(1000);
const ARENA_SIZE: usize = 10_000_000;
for depth in 1..8 {
// TODO! maybe somehow get throughput from `extend_layers`?
// group.throughput(Throughput::Elements(depth as u64));
group.throughput(Throughput::Elements(
extend_layers_test(depth, ARENA_SIZE) as u64
));
group.bench_with_input(BenchmarkId::from_parameter(depth), &depth, |b, depth| {
b.iter(|| extend_layers_test(*depth));
b.iter(|| extend_layers_test(*depth, ARENA_SIZE));
});
}
group.finish();

View File

@@ -26,7 +26,7 @@ fn main() {
// max_depth: 20,
// min_arena_depth_sub: 3,
// top_k_children: 2,
// up_to_minus: 5, // disable pruning
// up_to_minus: 5,
// max_arena_size: 2_000_000,
// },
// );