#[macro_use] extern crate criterion; #[macro_use] extern crate lazy_static; use criterion::{Benchmark, Criterion, Throughput}; use metrics_runtime::data::AtomicWindowedHistogram; use quanta::{Builder as UpkeepBuilder, Clock, Handle as UpkeepHandle}; use std::time::Duration; lazy_static! { static ref QUANTA_UPKEEP: UpkeepHandle = { let builder = UpkeepBuilder::new(Duration::from_millis(10)); builder .start() .expect("failed to start quanta upkeep thread") }; static ref RANDOM_INTS: Vec = vec![ 21061184, 21301862, 21331592, 21457012, 21500016, 21537837, 21581557, 21620030, 21664102, 21678463, 21708437, 21751808, 21845243, 21850265, 21938879, 21971014, 22005842, 22034601, 22085552, 22101746, 22115429, 22139883, 22260209, 22270768, 22298080, 22299780, 22307659, 22354697, 22355668, 22359397, 22463872, 22496590, 22590978, 22603740, 22706352, 22820895, 22849491, 22891538, 22912955, 22919915, 22928920, 22968656, 22985992, 23033739, 23061395, 23077554, 23138588, 23185172, 23282479, 23290830, 23316844, 23386911, 23641319, 23677058, 23742930, 25350389, 25399746, 25404925, 25464391, 25478415, 25480015, 25632783, 25639769, 25645612, 25688228, 25724427, 25862192, 25954476, 25994479, 26008752, 26036460, 26038202, 26078874, 26118327, 26132679, 26207601, 26262418, 26270737, 26274860, 26431248, 26434268, 26562736, 26580134, 26593740, 26618561, 26844181, 26866971, 26907883, 27005270, 27023584, 27024044, 27057184, 23061395, 23077554, 23138588, 23185172, 23282479, 23290830, 23316844, 23386911, 23641319, 23677058, 23742930, 25350389, 25399746, 25404925, 25464391, 25478415, 25480015, 25632783, 25639769, 25645612, 25688228, 25724427, 25862192, 25954476, 25994479, 26008752, 26036460, 26038202, 26078874, 26118327, 26132679, 26207601, 26262418, 26270737, 26274860, 26431248, 26434268, 26562736, 26580134, 26593740, 26618561, 26844181, 26866971, 26907883, 27005270, 27023584, 27024044, 27057184, 23061395, 23077554, 23138588, 23185172, 23282479, 23290830, 23316844, 23386911, 23641319, 23677058, 23742930, 25350389, 25399746, 25404925, 25464391, 25478415, 25480015, 25632783, 25639769, 25645612, 25688228, 25724427, 25862192, 25954476, 25994479, 26008752, 26036460, 26038202, 26078874, 26118327, 26132679, 26207601, 26262418, 26270737, 26274860, 26431248, 26434268, 26562736, 26580134, 26593740, 26618561, 26844181, 26866971, 26907883, 27005270, 27023584, 27024044, 27057184, 23061395, 23077554, 23138588, 23185172, 23282479, 23290830, 23316844, 23386911, 23641319, 23677058, 23742930, 25350389, 25399746, 25404925, 25464391, 25478415, 25480015, 25632783, 25639769, 25645612, 25688228, 25724427, 25862192, 25954476, 25994479, 26008752, 26036460, 26038202, 26078874, 26118327, 26132679, 26207601, 26262418, 26270737, 26274860, 26431248, 26434268, 26562736, 26580134, 26593740, 26618561, 26844181, 26866971, 26907883, 27005270, 27023584, 27024044, 27057184, 27088034, 27088550, 27302898, 27353925, 27412984, 27488633, 27514155, 27558052, 27601937, 27606339, 27624514, 27680396, 27684064, 27963602, 27414982, 28450673 ]; } fn bucket_benchmark(c: &mut Criterion) { // Trigger the quanta upkeep thread to spawn and start updating the time. let _handle = &QUANTA_UPKEEP; c.bench( "histogram", Benchmark::new("record", |b| { let clock = Clock::new(); let bucket = AtomicWindowedHistogram::new( Duration::from_secs(1), Duration::from_millis(100), clock, ); b.iter(|| { for value in RANDOM_INTS.iter() { bucket.record(*value); } }) }) .throughput(Throughput::Elements(RANDOM_INTS.len() as u64)), ); } criterion_group!(benches, bucket_benchmark); criterion_main!(benches);