blob: 9273ebf0686c5ea78a2ad6fb2a514f561ce99c24 [file] [log] [blame]
// Copyright 2011 Google Inc. All Rights Reserved.
part of benchmark_harness;
class BenchmarkBase {
final String name;
final ScoreEmitter emitter;
// Empty constructor.
const BenchmarkBase(String name, {ScoreEmitter emitter: const PrintEmitter()})
: this.name = name,
this.emitter = emitter;
// The benchmark code.
// This function is not used, if both [warmup] and [exercise] are overwritten.
void run() {}
// Runs a short version of the benchmark. By default invokes [run] once.
void warmup() {
run();
}
// Exercices the benchmark. By default invokes [run] 10 times.
void exercise() {
for (int i = 0; i < 10; i++) {
run();
}
}
// Not measured setup code executed prior to the benchmark runs.
void setup() {}
// Not measures teardown code executed after the benchark runs.
void teardown() {}
// Measures the score for this benchmark by executing it repeately until
// time minimum has been reached.
static double measureFor(Function f, int minimumMillis) {
int minimumMicros = minimumMillis * 1000;
int iter = 0;
Stopwatch watch = new Stopwatch();
watch.start();
int elapsed = 0;
while (elapsed < minimumMicros) {
f();
elapsed = watch.elapsedMicroseconds;
iter++;
}
return elapsed / iter;
}
// Measures the score for the benchmark and returns it.
double measure() {
setup();
// Warmup for at least 100ms. Discard result.
measureFor(() {
this.warmup();
}, 100);
// Run the benchmark for at least 2000ms.
double result = measureFor(() {
this.exercise();
}, 2000);
teardown();
return result;
}
void report() {
emitter.emit(name, measure());
}
}