pub struct Benchmarks<C, W, E>{ /* private fields */ }
Expand description
Run and analyze a benchmarks suite
C
- configurationW
- workload unitE
- error type
Implementations§
Source§impl<C, W, E> Benchmarks<C, W, E>
impl<C, W, E> Benchmarks<C, W, E>
Sourcepub fn new(name: &str) -> Benchmarks<C, W, E>
pub fn new(name: &str) -> Benchmarks<C, W, E>
Create a new Benchmarks
name
- the name of the benchmark session
Sourcepub fn add(
&mut self,
name: &str,
f: fn(stop_watch: &mut StopWatch, config: C, workload_point: W) -> Result<(), E>,
config: C,
work: Vec<W>,
repeat: usize,
ramp_up: usize,
) -> Result<(), Error>
pub fn add( &mut self, name: &str, f: fn(stop_watch: &mut StopWatch, config: C, workload_point: W) -> Result<(), E>, config: C, work: Vec<W>, repeat: usize, ramp_up: usize, ) -> Result<(), Error>
Create and add a Benchmark
name
- the name of the benchmark series. The result will be accessible by the name as a key from the summary.f
- the function that runs the benchmark.config
- the configuration value for this benchmark serieswork
- workload points vector for this benchmark series. Elements of this vector are passed tof
in each iterationrepeat
- number of times the benchmark will be repeatedramp_up
- number of times the benchmark will be performed before the measurement is taken
Sourcepub fn summary_as_json(&self) -> String
pub fn summary_as_json(&self) -> String
Produce Summary for all series as JSON string.
Sourcepub fn summary_as_csv(
&self,
with_headers: bool,
with_config: bool,
) -> HashMap<String, Vec<String>>
pub fn summary_as_csv( &self, with_headers: bool, with_config: bool, ) -> HashMap<String, Vec<String>>
Produce summary for each series as vector of CSV lines. The key for series data is the series name used in Self::add method, values are placed as the headers returned by [Self::csv_headers]
Sourcepub fn save_to_csv(
&self,
dir: PathBuf,
with_headers: bool,
with_config: bool,
) -> Result<(), Error>
pub fn save_to_csv( &self, dir: PathBuf, with_headers: bool, with_config: bool, ) -> Result<(), Error>
Save each benchmark summary to its own CSV file
The name of each CSV file is the name of the benchmark.
dir
- directory to store results. If doesn’t exist - create it.with_headers
- add column headers on the first linewith_config
- add the configuration string in the headers row
use std::path::PathBuf;
use benchmark_rs::benchmarks::Benchmarks;
let benchmarks = Benchmarks::<usize, usize, anyhow::Error>::new("example");
benchmarks.save_to_csv(PathBuf::from("./target/benchmarks"), true, true).expect("failed to save to csv");
Sourcepub fn save_to_json(&self, dir: PathBuf) -> Result<(), Error>
pub fn save_to_json(&self, dir: PathBuf) -> Result<(), Error>
Save the summary to a json file.
The name of the JSON file is the name of the suite of benchmarks. If dir doesn’t exist - create it.
use std::path::PathBuf;
use anyhow::anyhow;
use benchmark_rs::benchmarks::Benchmarks;
let benchmarks = Benchmarks::<usize, usize, anyhow::Error>::new("example");
benchmarks.save_to_json(PathBuf::from("./target/benchmarks")).expect("failed to save to json");
Auto Trait Implementations§
impl<C, W, E> Freeze for Benchmarks<C, W, E>
impl<C, W, E> RefUnwindSafe for Benchmarks<C, W, E>
impl<C, W, E> Send for Benchmarks<C, W, E>
impl<C, W, E> Sync for Benchmarks<C, W, E>
impl<C, W, E> Unpin for Benchmarks<C, W, E>
impl<C, W, E> UnwindSafe for Benchmarks<C, W, E>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self
from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self
is actually part of its subset T
(and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset
but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self
to the equivalent element of its superset.