about summary refs log tree commit diff
diff options
context:
space:
mode:
authorDylan DPC <99973273+Dylan-DPC@users.noreply.github.com>2023-02-13 11:12:49 +0530
committerGitHub <noreply@github.com>2023-02-13 11:12:49 +0530
commitc0d1e324d554a3799b95723a4d9c558405c4779f (patch)
treea946b2d18bb881a700ed61ef082bd405fda9c4d7
parent47358298f6069dc7bb6bb11674bf46433ae52bc1 (diff)
parentcbd1b81bd2a308b0f8a1734daf3eb30b56c7537c (diff)
downloadrust-c0d1e324d554a3799b95723a4d9c558405c4779f.tar.gz
rust-c0d1e324d554a3799b95723a4d9c558405c4779f.zip
Rollup merge of #107915 - JulianKnodt:array_benches, r=Mark-Simulacrum
Add `array::map` benchmarks

Since there were no previous benchmarks for `array::map`, and it is known to have mediocre/poor performance, add some simple benchmarks. These benchmarks vary the length of the array and size of each item.
-rw-r--r--library/core/benches/array.rs19
-rw-r--r--library/core/benches/lib.rs1
2 files changed, 20 insertions, 0 deletions
diff --git a/library/core/benches/array.rs b/library/core/benches/array.rs
new file mode 100644
index 00000000000..845c6076294
--- /dev/null
+++ b/library/core/benches/array.rs
@@ -0,0 +1,19 @@
+use test::black_box;
+use test::Bencher;
+
+macro_rules! map_array {
+    ($func_name:ident, $start_item: expr, $map_item: expr, $arr_size: expr) => {
+        #[bench]
+        fn $func_name(b: &mut Bencher) {
+            let arr = [$start_item; $arr_size];
+            b.iter(|| black_box(arr).map(|_| black_box($map_item)));
+        }
+    };
+}
+
+map_array!(map_8byte_8byte_8, 0u64, 1u64, 800);
+map_array!(map_8byte_8byte_64, 0u64, 1u64, 6400);
+map_array!(map_8byte_8byte_256, 0u64, 1u64, 25600);
+
+map_array!(map_8byte_256byte_256, 0u64, [0u64; 4], 25600);
+map_array!(map_256byte_8byte_256, [0u64; 4], 0u64, 25600);
diff --git a/library/core/benches/lib.rs b/library/core/benches/lib.rs
index f1244d93285..e4100120d82 100644
--- a/library/core/benches/lib.rs
+++ b/library/core/benches/lib.rs
@@ -9,6 +9,7 @@
 extern crate test;
 
 mod any;
+mod array;
 mod ascii;
 mod char;
 mod fmt;