From eaedf7477e84ba6ebf440936919c71daecfc15db Mon Sep 17 00:00:00 2001 From: Ritchie Vink Date: Mon, 10 Jun 2024 15:34:45 +0200 Subject: [PATCH] perf: Don't rechunk in `align_` if arrays are aligned (#16850) --- crates/polars-core/src/utils/mod.rs | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/crates/polars-core/src/utils/mod.rs b/crates/polars-core/src/utils/mod.rs index c187c81d7131..313fb55b1b50 100644 --- a/crates/polars-core/src/utils/mod.rs +++ b/crates/polars-core/src/utils/mod.rs @@ -783,7 +783,18 @@ where ) }; match (left.chunks.len(), right.chunks.len()) { + // All chunks are equal length (1, 1) => (Cow::Borrowed(left), Cow::Borrowed(right)), + // All chunks are equal length + (a, b) + if a == b + && left + .chunk_lengths() + .zip(right.chunk_lengths()) + .all(|(l, r)| l == r) => + { + (Cow::Borrowed(left), Cow::Borrowed(right)) + }, (_, 1) => { assert(); ( @@ -902,6 +913,16 @@ where Cow::Owned(c.match_chunks(a.chunk_lengths())), ) }, + (len_a, len_b, len_c) + if len_a == len_b + && len_b == len_c + && a.chunk_lengths() + .zip(b.chunk_lengths()) + .zip(c.chunk_lengths()) + .all(|((a, b), c)| a == b && b == c) => + { + (Cow::Borrowed(a), Cow::Borrowed(b), Cow::Borrowed(c)) + }, _ => { // could optimize to choose to rechunk a primitive and not a string or list type let a = a.rechunk();