File size: 1,668 Bytes
2409829
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
use criterion::measurement::Measurement;
use criterion::{BenchmarkGroup, Criterion, black_box, criterion_group, criterion_main};
use graph_craft::graphene_compiler::Executor;
use graph_craft::proto::ProtoNetwork;
use graph_craft::util::{DEMO_ART, compile, load_from_name};
use graphene_std::transform::Footprint;
use interpreted_executor::dynamic_executor::DynamicExecutor;

fn update_executor<M: Measurement>(name: &str, c: &mut BenchmarkGroup<M>) {
	let network = load_from_name(name);
	let proto_network = compile(network);
	let empty = ProtoNetwork::default();

	let executor = futures::executor::block_on(DynamicExecutor::new(empty)).unwrap();

	c.bench_function(name, |b| {
		b.iter_batched(
			|| (executor.clone(), proto_network.clone()),
			|(mut executor, network)| futures::executor::block_on(executor.update(black_box(network))),
			criterion::BatchSize::SmallInput,
		)
	});
}

fn update_executor_demo(c: &mut Criterion) {
	let mut g = c.benchmark_group("Update Executor");
	for name in DEMO_ART {
		update_executor(name, &mut g);
	}
}

fn run_once<M: Measurement>(name: &str, c: &mut BenchmarkGroup<M>) {
	let network = load_from_name(name);
	let proto_network = compile(network);

	let executor = futures::executor::block_on(DynamicExecutor::new(proto_network)).unwrap();
	let footprint = Footprint::default();

	c.bench_function(name, |b| b.iter(|| futures::executor::block_on((&executor).execute(footprint))));
}
fn run_once_demo(c: &mut Criterion) {
	let mut g = c.benchmark_group("Run Once no render");
	for name in DEMO_ART {
		run_once(name, &mut g);
	}
}

criterion_group!(benches, update_executor_demo, run_once_demo);
criterion_main!(benches);