use criterion::{black_box, criterion_group, criterion_main, Criterion};
fn fibonacci(n: u64) -> u64 {
match n {
0 => 0,
1 => 1,
_ => fibonacci(n - 1) + fibonacci(n - 2),
}
}
fn criterion_benchmark(c: &mut Criterion) {
c.bench_function("fib 20", |b| b.iter(|| fibonacci(black_box(20))));
}
criterion_group!(benches, criterion_benchmark);
criterion_main!(benches);
fn bad(data: &Vec<String>) -> Vec<String> {
data.clone()
}
fn good(data: &[String]) -> &[String] {
data
}
fn sum_v1(data: &[i32]) -> i32 {
let mut sum = 0;
for i in 0..data.len() {
sum += data[i];
}
sum
}
fn sum_v2(data: &[i32]) -> i32 {
data.iter().sum()
}
fn collect_v1(n: usize) -> Vec<i32> {
let mut v = Vec::new();
for i in 0..n {
v.push(i);
}
v
}
fn collect_v2(n: usize) -> Vec<i32> {
let mut v = Vec::with_capacity(n);
for i in 0..n {
v.push(i);
}
v
}