Rollup merge of #107598 - chenyukang:yukang/fix-core-bench, r=thomcc

Fix benchmarks in library/core with black_box

Fixes #107590
This commit is contained in:
Matthias Krüger 2023-02-03 06:30:24 +01:00 committed by GitHub
commit 86015515b5
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 44 additions and 32 deletions

View file

@ -1,26 +1,26 @@
use test::Bencher; use test::{black_box, Bencher};
const CHARS: [char; 9] = ['0', 'x', '2', '5', 'A', 'f', '7', '8', '9']; const CHARS: [char; 9] = ['0', 'x', '2', '5', 'A', 'f', '7', '8', '9'];
const RADIX: [u32; 5] = [2, 8, 10, 16, 32]; const RADIX: [u32; 5] = [2, 8, 10, 16, 32];
#[bench] #[bench]
fn bench_to_digit_radix_2(b: &mut Bencher) { fn bench_to_digit_radix_2(b: &mut Bencher) {
b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| c.to_digit(2)).min()) b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| black_box(c).to_digit(2)).min())
} }
#[bench] #[bench]
fn bench_to_digit_radix_10(b: &mut Bencher) { fn bench_to_digit_radix_10(b: &mut Bencher) {
b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| c.to_digit(10)).min()) b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| black_box(c).to_digit(10)).min())
} }
#[bench] #[bench]
fn bench_to_digit_radix_16(b: &mut Bencher) { fn bench_to_digit_radix_16(b: &mut Bencher) {
b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| c.to_digit(16)).min()) b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| black_box(c).to_digit(16)).min())
} }
#[bench] #[bench]
fn bench_to_digit_radix_36(b: &mut Bencher) { fn bench_to_digit_radix_36(b: &mut Bencher) {
b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| c.to_digit(36)).min()) b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| black_box(c).to_digit(36)).min())
} }
#[bench] #[bench]
@ -31,47 +31,59 @@ fn bench_to_digit_radix_var(b: &mut Bencher) {
.cycle() .cycle()
.zip(RADIX.iter().cycle()) .zip(RADIX.iter().cycle())
.take(10_000) .take(10_000)
.map(|(c, radix)| c.to_digit(*radix)) .map(|(c, radix)| black_box(c).to_digit(*radix))
.min() .min()
}) })
} }
#[bench] #[bench]
fn bench_to_ascii_uppercase(b: &mut Bencher) { fn bench_to_ascii_uppercase(b: &mut Bencher) {
b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| c.to_ascii_uppercase()).min()) b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| black_box(c).to_ascii_uppercase()).min())
} }
#[bench] #[bench]
fn bench_to_ascii_lowercase(b: &mut Bencher) { fn bench_to_ascii_lowercase(b: &mut Bencher) {
b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| c.to_ascii_lowercase()).min()) b.iter(|| CHARS.iter().cycle().take(10_000).map(|c| black_box(c).to_ascii_lowercase()).min())
} }
#[bench] #[bench]
fn bench_ascii_mix_to_uppercase(b: &mut Bencher) { fn bench_ascii_mix_to_uppercase(b: &mut Bencher) {
b.iter(|| (0..=255).cycle().take(10_000).map(|b| char::from(b).to_uppercase()).count()) b.iter(|| {
(0..=255).cycle().take(10_000).map(|b| black_box(char::from(b)).to_uppercase()).count()
})
} }
#[bench] #[bench]
fn bench_ascii_mix_to_lowercase(b: &mut Bencher) { fn bench_ascii_mix_to_lowercase(b: &mut Bencher) {
b.iter(|| (0..=255).cycle().take(10_000).map(|b| char::from(b).to_lowercase()).count()) b.iter(|| {
(0..=255).cycle().take(10_000).map(|b| black_box(char::from(b)).to_lowercase()).count()
})
} }
#[bench] #[bench]
fn bench_ascii_char_to_uppercase(b: &mut Bencher) { fn bench_ascii_char_to_uppercase(b: &mut Bencher) {
b.iter(|| (0..=127).cycle().take(10_000).map(|b| char::from(b).to_uppercase()).count()) b.iter(|| {
(0..=127).cycle().take(10_000).map(|b| black_box(char::from(b)).to_uppercase()).count()
})
} }
#[bench] #[bench]
fn bench_ascii_char_to_lowercase(b: &mut Bencher) { fn bench_ascii_char_to_lowercase(b: &mut Bencher) {
b.iter(|| (0..=127).cycle().take(10_000).map(|b| char::from(b).to_lowercase()).count()) b.iter(|| {
(0..=127).cycle().take(10_000).map(|b| black_box(char::from(b)).to_lowercase()).count()
})
} }
#[bench] #[bench]
fn bench_non_ascii_char_to_uppercase(b: &mut Bencher) { fn bench_non_ascii_char_to_uppercase(b: &mut Bencher) {
b.iter(|| (128..=255).cycle().take(10_000).map(|b| char::from(b).to_uppercase()).count()) b.iter(|| {
(128..=255).cycle().take(10_000).map(|b| black_box(char::from(b)).to_uppercase()).count()
})
} }
#[bench] #[bench]
fn bench_non_ascii_char_to_lowercase(b: &mut Bencher) { fn bench_non_ascii_char_to_lowercase(b: &mut Bencher) {
b.iter(|| (128..=255).cycle().take(10_000).map(|b| char::from(b).to_lowercase()).count()) b.iter(|| {
(128..=255).cycle().take(10_000).map(|b| black_box(char::from(b)).to_lowercase()).count()
})
} }

View file

@ -1,14 +1,14 @@
use super::super::*; use super::super::*;
use core::num::flt2dec::strategy::dragon::*; use core::num::flt2dec::strategy::dragon::*;
use std::mem::MaybeUninit; use std::mem::MaybeUninit;
use test::Bencher; use test::{black_box, Bencher};
#[bench] #[bench]
fn bench_small_shortest(b: &mut Bencher) { fn bench_small_shortest(b: &mut Bencher) {
let decoded = decode_finite(3.141592f64); let decoded = decode_finite(3.141592f64);
let mut buf = [MaybeUninit::new(0); MAX_SIG_DIGITS]; let mut buf = [MaybeUninit::new(0); MAX_SIG_DIGITS];
b.iter(|| { b.iter(|| {
format_shortest(&decoded, &mut buf); format_shortest(black_box(&decoded), &mut buf);
}); });
} }
@ -17,7 +17,7 @@ fn bench_big_shortest(b: &mut Bencher) {
let decoded = decode_finite(f64::MAX); let decoded = decode_finite(f64::MAX);
let mut buf = [MaybeUninit::new(0); MAX_SIG_DIGITS]; let mut buf = [MaybeUninit::new(0); MAX_SIG_DIGITS];
b.iter(|| { b.iter(|| {
format_shortest(&decoded, &mut buf); format_shortest(black_box(&decoded), &mut buf);
}); });
} }
@ -26,7 +26,7 @@ fn bench_small_exact_3(b: &mut Bencher) {
let decoded = decode_finite(3.141592f64); let decoded = decode_finite(3.141592f64);
let mut buf = [MaybeUninit::new(0); 3]; let mut buf = [MaybeUninit::new(0); 3];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -35,7 +35,7 @@ fn bench_big_exact_3(b: &mut Bencher) {
let decoded = decode_finite(f64::MAX); let decoded = decode_finite(f64::MAX);
let mut buf = [MaybeUninit::new(0); 3]; let mut buf = [MaybeUninit::new(0); 3];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -44,7 +44,7 @@ fn bench_small_exact_12(b: &mut Bencher) {
let decoded = decode_finite(3.141592f64); let decoded = decode_finite(3.141592f64);
let mut buf = [MaybeUninit::new(0); 12]; let mut buf = [MaybeUninit::new(0); 12];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -53,7 +53,7 @@ fn bench_big_exact_12(b: &mut Bencher) {
let decoded = decode_finite(f64::MAX); let decoded = decode_finite(f64::MAX);
let mut buf = [MaybeUninit::new(0); 12]; let mut buf = [MaybeUninit::new(0); 12];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -62,7 +62,7 @@ fn bench_small_exact_inf(b: &mut Bencher) {
let decoded = decode_finite(3.141592f64); let decoded = decode_finite(3.141592f64);
let mut buf = [MaybeUninit::new(0); 1024]; let mut buf = [MaybeUninit::new(0); 1024];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -71,6 +71,6 @@ fn bench_big_exact_inf(b: &mut Bencher) {
let decoded = decode_finite(f64::MAX); let decoded = decode_finite(f64::MAX);
let mut buf = [MaybeUninit::new(0); 1024]; let mut buf = [MaybeUninit::new(0); 1024];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }

View file

@ -1,7 +1,7 @@
use super::super::*; use super::super::*;
use core::num::flt2dec::strategy::grisu::*; use core::num::flt2dec::strategy::grisu::*;
use std::mem::MaybeUninit; use std::mem::MaybeUninit;
use test::Bencher; use test::{black_box, Bencher};
pub fn decode_finite<T: DecodableFloat>(v: T) -> Decoded { pub fn decode_finite<T: DecodableFloat>(v: T) -> Decoded {
match decode(v).1 { match decode(v).1 {
@ -15,7 +15,7 @@ fn bench_small_shortest(b: &mut Bencher) {
let decoded = decode_finite(3.141592f64); let decoded = decode_finite(3.141592f64);
let mut buf = [MaybeUninit::new(0); MAX_SIG_DIGITS]; let mut buf = [MaybeUninit::new(0); MAX_SIG_DIGITS];
b.iter(|| { b.iter(|| {
format_shortest(&decoded, &mut buf); format_shortest(black_box(&decoded), &mut buf);
}); });
} }
@ -24,7 +24,7 @@ fn bench_big_shortest(b: &mut Bencher) {
let decoded = decode_finite(f64::MAX); let decoded = decode_finite(f64::MAX);
let mut buf = [MaybeUninit::new(0); MAX_SIG_DIGITS]; let mut buf = [MaybeUninit::new(0); MAX_SIG_DIGITS];
b.iter(|| { b.iter(|| {
format_shortest(&decoded, &mut buf); format_shortest(black_box(&decoded), &mut buf);
}); });
} }
@ -33,7 +33,7 @@ fn bench_small_exact_3(b: &mut Bencher) {
let decoded = decode_finite(3.141592f64); let decoded = decode_finite(3.141592f64);
let mut buf = [MaybeUninit::new(0); 3]; let mut buf = [MaybeUninit::new(0); 3];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -42,7 +42,7 @@ fn bench_big_exact_3(b: &mut Bencher) {
let decoded = decode_finite(f64::MAX); let decoded = decode_finite(f64::MAX);
let mut buf = [MaybeUninit::new(0); 3]; let mut buf = [MaybeUninit::new(0); 3];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -51,7 +51,7 @@ fn bench_small_exact_12(b: &mut Bencher) {
let decoded = decode_finite(3.141592f64); let decoded = decode_finite(3.141592f64);
let mut buf = [MaybeUninit::new(0); 12]; let mut buf = [MaybeUninit::new(0); 12];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -60,7 +60,7 @@ fn bench_big_exact_12(b: &mut Bencher) {
let decoded = decode_finite(f64::MAX); let decoded = decode_finite(f64::MAX);
let mut buf = [MaybeUninit::new(0); 12]; let mut buf = [MaybeUninit::new(0); 12];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -69,7 +69,7 @@ fn bench_small_exact_inf(b: &mut Bencher) {
let decoded = decode_finite(3.141592f64); let decoded = decode_finite(3.141592f64);
let mut buf = [MaybeUninit::new(0); 1024]; let mut buf = [MaybeUninit::new(0); 1024];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }
@ -78,6 +78,6 @@ fn bench_big_exact_inf(b: &mut Bencher) {
let decoded = decode_finite(f64::MAX); let decoded = decode_finite(f64::MAX);
let mut buf = [MaybeUninit::new(0); 1024]; let mut buf = [MaybeUninit::new(0); 1024];
b.iter(|| { b.iter(|| {
format_exact(&decoded, &mut buf, i16::MIN); format_exact(black_box(&decoded), &mut buf, i16::MIN);
}); });
} }