diff --git a/Cargo.toml b/Cargo.toml index 4a2f164..48d7012 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -15,11 +15,7 @@ rust-version = "1.63" [features] default = ["std"] std = [] -derive = ["dep:scroll_derive"] +derive = ["scroll_derive"] [dependencies] scroll_derive = { version = "0.11", optional = true, path = "scroll_derive" } - -[dev-dependencies] -rayon = "1" -byteorder = "1" diff --git a/benches/bench.rs b/benches/bench.rs index 0787dbe..313b723 100644 --- a/benches/bench.rs +++ b/benches/bench.rs @@ -1,157 +1,172 @@ -#![feature(test)] -extern crate test; +// last numbers before disabled this for MSRV reasons -use scroll::{Cread, Pread, LE}; -use test::black_box; +// test bench_byteorder ... bench: 26,971 ns/iter (+/- 334) = 7415 MB/s +// test bench_byteorder_vec ... bench: 327,029 ns/iter (+/- 4,127) = 3057 MB/s +// test bench_cread ... bench: 26,978 ns/iter (+/- 183) = 7413 MB/s +// test bench_cread_vec ... bench: 220,327 ns/iter (+/- 880) = 4538 MB/s +// test bench_gread_unwrap ... bench: 27,044 ns/iter (+/- 161) = 7395 MB/s +// test bench_gread_vec ... bench: 394,277 ns/iter (+/- 7,979) = 2536 MB/s +// test bench_parallel_cread_with ... bench: 84,137 ns/iter (+/- 2,095) = 11885 MB/s +// test bench_parallel_pread_with ... bench: 115,520 ns/iter (+/- 4,162) = 8656 MB/s +// test bench_pread_ctx_vec ... bench: 411,731 ns/iter (+/- 11,635) = 2428 MB/s +// test bench_pread_unwrap ... bench: 51,681 ns/iter (+/- 583) = 3869 MB/s +// test bench_pread_vec ... bench: 406,224 ns/iter (+/- 6,717) = 2461 MB/s +// test bench_pread_with_unwrap ... bench: 27,197 ns/iter (+/- 152) = 7353 MB/s -#[bench] -fn bench_parallel_cread_with(b: &mut test::Bencher) { - use rayon::prelude::*; - let vec = vec![0u8; 1_000_000]; - let nums = vec![0usize; 500_000]; - b.iter(|| { - let data = black_box(&vec[..]); - nums.par_iter().for_each(|offset| { - let _: u16 = black_box(data.cread_with(*offset, LE)); - }); - }); - b.bytes = vec.len() as u64; -} +// #![feature(test)] +// extern crate test; -#[bench] -fn bench_cread_vec(b: &mut test::Bencher) { - let vec = vec![0u8; 1_000_000]; - b.iter(|| { - let data = black_box(&vec[..]); - for val in data.chunks(2) { - let _: u16 = black_box(val.cread_with(0, LE)); - } - }); - b.bytes = vec.len() as u64; -} +// use scroll::{Cread, Pread, LE}; +// use test::black_box; -#[bench] -fn bench_cread(b: &mut test::Bencher) { - const NITER: i32 = 100_000; - b.iter(|| { - for _ in 1..NITER { - let data = black_box([1, 2]); - let _: u16 = black_box(data.cread(0)); - } - }); - b.bytes = 2 * NITER as u64; -} +// #[bench] +// fn bench_parallel_cread_with(b: &mut test::Bencher) { +// use rayon::prelude::*; +// let vec = vec![0u8; 1_000_000]; +// let nums = vec![0usize; 500_000]; +// b.iter(|| { +// let data = black_box(&vec[..]); +// nums.par_iter().for_each(|offset| { +// let _: u16 = black_box(data.cread_with(*offset, LE)); +// }); +// }); +// b.bytes = vec.len() as u64; +// } -#[bench] -fn bench_pread_ctx_vec(b: &mut test::Bencher) { - let vec = vec![0u8; 1_000_000]; - b.iter(|| { - let data = black_box(&vec[..]); - for val in data.chunks(2) { - let _: Result = black_box(val.pread(0)); - } - }); - b.bytes = vec.len() as u64; -} +// #[bench] +// fn bench_cread_vec(b: &mut test::Bencher) { +// let vec = vec![0u8; 1_000_000]; +// b.iter(|| { +// let data = black_box(&vec[..]); +// for val in data.chunks(2) { +// let _: u16 = black_box(val.cread_with(0, LE)); +// } +// }); +// b.bytes = vec.len() as u64; +// } -#[bench] -fn bench_pread_with_unwrap(b: &mut test::Bencher) { - const NITER: i32 = 100_000; - b.iter(|| { - for _ in 1..NITER { - let data: &[u8] = &black_box([1, 2]); - let _: u16 = black_box(data.pread_with(0, LE).unwrap()); - } - }); - b.bytes = 2 * NITER as u64; -} +// #[bench] +// fn bench_cread(b: &mut test::Bencher) { +// const NITER: i32 = 100_000; +// b.iter(|| { +// for _ in 1..NITER { +// let data = black_box([1, 2]); +// let _: u16 = black_box(data.cread(0)); +// } +// }); +// b.bytes = 2 * NITER as u64; +// } -#[bench] -fn bench_pread_vec(b: &mut test::Bencher) { - let vec = vec![0u8; 1_000_000]; - b.iter(|| { - let data = black_box(&vec[..]); - for val in data.chunks(2) { - let _: Result = black_box(val.pread_with(0, LE)); - } - }); - b.bytes = vec.len() as u64; -} +// #[bench] +// fn bench_pread_ctx_vec(b: &mut test::Bencher) { +// let vec = vec![0u8; 1_000_000]; +// b.iter(|| { +// let data = black_box(&vec[..]); +// for val in data.chunks(2) { +// let _: Result = black_box(val.pread(0)); +// } +// }); +// b.bytes = vec.len() as u64; +// } -#[bench] -fn bench_pread_unwrap(b: &mut test::Bencher) { - const NITER: i32 = 100_000; - b.iter(|| { - for _ in 1..NITER { - let data = black_box([1, 2]); - let _: u16 = black_box(data.pread(0)).unwrap(); - } - }); - b.bytes = 2 * NITER as u64; -} +// #[bench] +// fn bench_pread_with_unwrap(b: &mut test::Bencher) { +// const NITER: i32 = 100_000; +// b.iter(|| { +// for _ in 1..NITER { +// let data: &[u8] = &black_box([1, 2]); +// let _: u16 = black_box(data.pread_with(0, LE).unwrap()); +// } +// }); +// b.bytes = 2 * NITER as u64; +// } -#[bench] -fn bench_gread_vec(b: &mut test::Bencher) { - let vec = vec![0u8; 1_000_000]; - b.iter(|| { - let data = black_box(&vec[..]); - for val in data.chunks(2) { - let mut offset = 0; - let _: Result = black_box(val.gread(&mut offset)); - } - }); - b.bytes = vec.len() as u64; -} +// #[bench] +// fn bench_pread_vec(b: &mut test::Bencher) { +// let vec = vec![0u8; 1_000_000]; +// b.iter(|| { +// let data = black_box(&vec[..]); +// for val in data.chunks(2) { +// let _: Result = black_box(val.pread_with(0, LE)); +// } +// }); +// b.bytes = vec.len() as u64; +// } -#[bench] -fn bench_gread_unwrap(b: &mut test::Bencher) { - const NITER: i32 = 100_000; - b.iter(|| { - for _ in 1..NITER { - let data = black_box([1, 2]); - let mut offset = 0; - let _: u16 = black_box(data.gread_with(&mut offset, LE).unwrap()); - } - }); - b.bytes = 2 * NITER as u64; -} +// #[bench] +// fn bench_pread_unwrap(b: &mut test::Bencher) { +// const NITER: i32 = 100_000; +// b.iter(|| { +// for _ in 1..NITER { +// let data = black_box([1, 2]); +// let _: u16 = black_box(data.pread(0)).unwrap(); +// } +// }); +// b.bytes = 2 * NITER as u64; +// } -#[bench] -fn bench_parallel_pread_with(b: &mut test::Bencher) { - use rayon::prelude::*; - let vec = vec![0u8; 1_000_000]; - let nums = vec![0usize; 500_000]; - b.iter(|| { - let data = black_box(&vec[..]); - nums.par_iter().for_each(|offset| { - let _: Result = black_box(data.pread_with(*offset, LE)); - }); - }); - b.bytes = vec.len() as u64; -} +// #[bench] +// fn bench_gread_vec(b: &mut test::Bencher) { +// let vec = vec![0u8; 1_000_000]; +// b.iter(|| { +// let data = black_box(&vec[..]); +// for val in data.chunks(2) { +// let mut offset = 0; +// let _: Result = black_box(val.gread(&mut offset)); +// } +// }); +// b.bytes = vec.len() as u64; +// } -#[bench] -fn bench_byteorder_vec(b: &mut test::Bencher) { - use byteorder::ReadBytesExt; - let vec = vec![0u8; 1_000_000]; - b.iter(|| { - let data = black_box(&vec[..]); - for mut val in data.chunks(2) { - let _: Result = black_box(val.read_u16::()); - } - }); - b.bytes = vec.len() as u64; -} +// #[bench] +// fn bench_gread_unwrap(b: &mut test::Bencher) { +// const NITER: i32 = 100_000; +// b.iter(|| { +// for _ in 1..NITER { +// let data = black_box([1, 2]); +// let mut offset = 0; +// let _: u16 = black_box(data.gread_with(&mut offset, LE).unwrap()); +// } +// }); +// b.bytes = 2 * NITER as u64; +// } -#[bench] -fn bench_byteorder(b: &mut test::Bencher) { - use byteorder::ByteOrder; - const NITER: i32 = 100_000; - b.iter(|| { - for _ in 1..NITER { - let data = black_box([1, 2]); - let _: u16 = black_box(byteorder::LittleEndian::read_u16(&data)); - } - }); - b.bytes = 2 * NITER as u64; -} +// #[bench] +// fn bench_parallel_pread_with(b: &mut test::Bencher) { +// use rayon::prelude::*; +// let vec = vec![0u8; 1_000_000]; +// let nums = vec![0usize; 500_000]; +// b.iter(|| { +// let data = black_box(&vec[..]); +// nums.par_iter().for_each(|offset| { +// let _: Result = black_box(data.pread_with(*offset, LE)); +// }); +// }); +// b.bytes = vec.len() as u64; +// } + +// #[bench] +// fn bench_byteorder_vec(b: &mut test::Bencher) { +// use byteorder::ReadBytesExt; +// let vec = vec![0u8; 1_000_000]; +// b.iter(|| { +// let data = black_box(&vec[..]); +// for mut val in data.chunks(2) { +// let _: Result = black_box(val.read_u16::()); +// } +// }); +// b.bytes = vec.len() as u64; +// } + +// #[bench] +// fn bench_byteorder(b: &mut test::Bencher) { +// use byteorder::ByteOrder; +// const NITER: i32 = 100_000; +// b.iter(|| { +// for _ in 1..NITER { +// let data = black_box([1, 2]); +// let _: u16 = black_box(byteorder::LittleEndian::read_u16(&data)); +// } +// }); +// b.bytes = 2 * NITER as u64; +// }