|
mod benchmark_util; |
|
|
|
use benchmark_util::{bench_for_each_demo, setup_network}; |
|
use criterion::{Criterion, criterion_group, criterion_main}; |
|
use graph_craft::proto::ProtoNetwork; |
|
use interpreted_executor::dynamic_executor::DynamicExecutor; |
|
|
|
fn update_executor(c: &mut Criterion) { |
|
let mut group = c.benchmark_group("Update Executor"); |
|
bench_for_each_demo(&mut group, |name, g| { |
|
g.bench_function(name, |b| { |
|
b.iter_batched( |
|
|| { |
|
let (_, proto_network) = setup_network(name); |
|
let empty = ProtoNetwork::default(); |
|
let executor = futures::executor::block_on(DynamicExecutor::new(empty)).unwrap(); |
|
(executor, proto_network) |
|
}, |
|
|(mut executor, network)| futures::executor::block_on(executor.update(criterion::black_box(network))), |
|
criterion::BatchSize::SmallInput, |
|
) |
|
}); |
|
}); |
|
group.finish(); |
|
} |
|
|
|
criterion_group!(benches, update_executor); |
|
criterion_main!(benches); |
|
|