From ad9f89860eb886b536ff2f02c2ec5d897ca6bf63 Mon Sep 17 00:00:00 2001 From: Palash Tyagi <23239946+Magnus167@users.noreply.github.com> Date: Sun, 6 Jul 2025 00:23:03 +0100 Subject: [PATCH] Add benchmarks for matrix and frame operations including multiplication, summation, product, application along axes, and transposition --- benches/benchmarks.rs | 57 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) diff --git a/benches/benchmarks.rs b/benches/benchmarks.rs index e8954c8..eb8b174 100644 --- a/benches/benchmarks.rs +++ b/benches/benchmarks.rs @@ -109,6 +109,47 @@ fn matrix_operations_benchmark(c: &mut Criterion, sizes: &[usize]) { let _result = &ma / 2.0; }); }); + c.bench_function( + &format!("matrix matrix_multiply ({}x{})", size, size), + |b| { + b.iter(|| { + let _result = ma.matrix_mul(&ma); + }); + }, + ); + c.bench_function(&format!("matrix sum_horizontal ({}x{})", size, size), |b| { + b.iter(|| { + let _result = ma.sum_horizontal(); + }); + }); + c.bench_function(&format!("matrix sum_vertical ({}x{})", size, size), |b| { + b.iter(|| { + let _result = ma.sum_vertical(); + }); + }); + c.bench_function( + &format!("matrix prod_horizontal ({}x{})", size, size), + |b| { + b.iter(|| { + let _result = ma.prod_horizontal(); + }); + }, + ); + c.bench_function(&format!("matrix prod_vertical ({}x{})", size, size), |b| { + b.iter(|| { + let _result = ma.prod_vertical(); + }); + }); + c.bench_function(&format!("matrix apply_axis ({}x{})", size, size), |b| { + b.iter(|| { + let _result = ma.apply_axis(0, |col| col.iter().sum::()); + }); + }); + c.bench_function(&format!("matrix transpose ({}x{})", size, size), |b| { + b.iter(|| { + let _result = ma.transpose(); + }); + }); } for &size in sizes { @@ -187,6 +228,12 @@ fn benchmark_frame_operations(c: &mut Criterion, sizes: &[usize]) { }); }); + c.bench_function(&format!("frame matrix_multiply ({}x{})", size, size), |b| { + b.iter(|| { + let _result = fa.matrix_mul(&fb); + }); + }); + c.bench_function(&format!("frame sum_horizontal ({}x{})", size, size), |b| { b.iter(|| { let _result = fa.sum_horizontal(); @@ -207,6 +254,16 @@ fn benchmark_frame_operations(c: &mut Criterion, sizes: &[usize]) { let _result = fa.prod_vertical(); }); }); + c.bench_function(&format!("frame apply_axis ({}x{})", size, size), |b| { + b.iter(|| { + let _result = fa.apply_axis(0, |col| col.iter().sum::()); + }); + }); + c.bench_function(&format!("frame transpose ({}x{})", size, size), |b| { + b.iter(|| { + let _result = fa.transpose(); + }); + }); } }