fparkan/vendor/exr/benches/read.rs
Valentin Popov 1b6a04ca55
Initial vendor packages
Signed-off-by: Valentin Popov <valentin@popov.link>
2024-01-08 01:21:28 +04:00

172 lines
5.5 KiB
Rust

#[macro_use]
extern crate bencher;
extern crate exr;
use exr::prelude::*;
use bencher::Bencher;
use std::fs;
use std::io::Cursor;
use exr::image::pixel_vec::PixelVec;
/// Read uncompressed (always single core)
fn read_single_image_uncompressed_non_parallel_rgba(bench: &mut Bencher) {
let mut file = fs::read("tests/images/valid/custom/crowskull/crow_uncompressed.exr").unwrap();
bench.iter(||{
bencher::black_box(&mut file);
let image = exr::prelude::read()
.no_deep_data().largest_resolution_level()
.rgba_channels(PixelVec::<(f32,f32,f32,f32)>::constructor, PixelVec::set_pixel)
.all_layers().all_attributes()
.non_parallel()
.from_buffered(Cursor::new(file.as_slice())).unwrap();
bencher::black_box(image);
})
}
/// Read from in-memory in parallel
fn read_single_image_uncompressed_rgba(bench: &mut Bencher) {
let mut file = fs::read("tests/images/valid/custom/crowskull/crow_uncompressed.exr").unwrap();
bench.iter(||{
bencher::black_box(&mut file);
let image = exr::prelude::read()
.no_deep_data().largest_resolution_level()
.rgba_channels(PixelVec::<(f32,f32,f32,f32)>::constructor, PixelVec::set_pixel)
.all_layers().all_attributes()
.from_buffered(Cursor::new(file.as_slice())).unwrap();
bencher::black_box(image);
})
}
/// Read with multi-core RLE decompression
fn read_single_image_rle_all_channels(bench: &mut Bencher) {
let mut file = fs::read("tests/images/valid/custom/crowskull/crow_rle.exr").unwrap();
bench.iter(||{
bencher::black_box(&mut file);
let image = exr::prelude::read()
.no_deep_data()
.largest_resolution_level()
.all_channels()
.all_layers()
.all_attributes()
.from_buffered(Cursor::new(file.as_slice())).unwrap();
bencher::black_box(image);
})
}
/// Read without multi-core RLE decompression
fn read_single_image_rle_non_parallel_all_channels(bench: &mut Bencher) {
let mut file = fs::read("tests/images/valid/custom/crowskull/crow_rle.exr").unwrap();
bench.iter(||{
bencher::black_box(&mut file);
// copied from `read_all_flat_layers_from_file` and added `.non_parallel()`
let image = exr::prelude::read()
.no_deep_data()
.largest_resolution_level()
.all_channels()
.all_layers()
.all_attributes()
.non_parallel()
.from_buffered(Cursor::new(file.as_slice())).unwrap();
bencher::black_box(image);
})
}
/// Read with multi-core RLE decompression
fn read_single_image_rle_rgba(bench: &mut Bencher) {
let mut file = fs::read("tests/images/valid/custom/crowskull/crow_rle.exr").unwrap();
bench.iter(||{
bencher::black_box(&mut file);
let image = exr::prelude::read()
.no_deep_data()
.largest_resolution_level()
.rgba_channels(PixelVec::<(f32,f32,f32,f32)>::constructor, PixelVec::set_pixel)
.all_layers()
.all_attributes()
.from_buffered(Cursor::new(file.as_slice())).unwrap();
bencher::black_box(image);
})
}
/// Read without multi-core RLE decompression
fn read_single_image_rle_non_parallel_rgba(bench: &mut Bencher) {
let mut file = fs::read("tests/images/valid/custom/crowskull/crow_rle.exr").unwrap();
bench.iter(||{
bencher::black_box(&mut file);
// copied from `read_all_flat_layers_from_file` and added `.non_parallel()`
let image = exr::prelude::read()
.no_deep_data()
.largest_resolution_level()
.rgba_channels(PixelVec::<(f32,f32,f32,f32)>::constructor, PixelVec::set_pixel)
.all_layers()
.all_attributes()
.non_parallel()
.from_buffered(Cursor::new(file.as_slice())).unwrap();
bencher::black_box(image);
})
}
/// Read with multi-core zip decompression
fn read_single_image_zips_rgba(bench: &mut Bencher) {
let mut file = fs::read("tests/images/valid/custom/crowskull/crow_zips.exr").unwrap();
bench.iter(||{
bencher::black_box(&mut file);
let image = exr::prelude::read()
.no_deep_data().largest_resolution_level()
.rgba_channels(PixelVec::<(f32,f32,f32,f32)>::constructor, PixelVec::set_pixel)
.all_layers().all_attributes()
.from_buffered(Cursor::new(file.as_slice())).unwrap();
bencher::black_box(image);
})
}
/// Read without multi-core ZIP decompression
fn read_single_image_zips_non_parallel_rgba(bench: &mut Bencher) {
let mut file = fs::read("tests/images/valid/custom/crowskull/crow_zips.exr").unwrap();
bench.iter(||{
bencher::black_box(&mut file);
let image = exr::prelude::read()
.no_deep_data().largest_resolution_level()
.rgba_channels(PixelVec::<(f32,f32,f32,f32)>::constructor, PixelVec::set_pixel)
.all_layers().all_attributes()
.non_parallel()
.from_buffered(Cursor::new(file.as_slice())).unwrap();
bencher::black_box(image);
})
}
benchmark_group!(read,
read_single_image_uncompressed_rgba,
read_single_image_uncompressed_non_parallel_rgba,
read_single_image_rle_rgba,
read_single_image_rle_non_parallel_rgba,
read_single_image_rle_all_channels,
read_single_image_rle_non_parallel_all_channels,
read_single_image_zips_rgba,
read_single_image_zips_non_parallel_rgba,
);
benchmark_main!(read);