From f7d557d5c78c7bd8f65d43ffeaf65452d2da3f53 Mon Sep 17 00:00:00 2001 From: kinto-b Date: Wed, 17 Apr 2024 16:37:38 +1000 Subject: [PATCH] Implement helper on LazyBuffer for getting multiple elements by index --- src/combinations.rs | 8 ++------ src/combinations_with_replacement.rs | 15 ++------------- src/lazy_buffer.rs | 10 ++++++++++ src/permutations.rs | 4 ++-- 4 files changed, 16 insertions(+), 21 deletions(-) diff --git a/src/combinations.rs b/src/combinations.rs index b8cae5e97..e254fee7e 100644 --- a/src/combinations.rs +++ b/src/combinations.rs @@ -162,14 +162,10 @@ where return None; } - Some(self.indices.iter().map(|i| self.pool[*i].clone()).collect()) + Some(self.pool.get_at(&self.indices)) } fn nth(&mut self, n: usize) -> Option { - if n == 0 { - return self.next(); - } - let done = if self.first { self.init() } else { @@ -186,7 +182,7 @@ where } } - Some(self.indices.iter().map(|i| self.pool[*i].clone()).collect()) + Some(self.pool.get_at(&self.indices)) } fn size_hint(&self) -> (usize, Option) { diff --git a/src/combinations_with_replacement.rs b/src/combinations_with_replacement.rs index ee3497849..4043678c1 100644 --- a/src/combinations_with_replacement.rs +++ b/src/combinations_with_replacement.rs @@ -30,17 +30,6 @@ where debug_fmt_fields!(CombinationsWithReplacement, indices, pool, first); } -impl CombinationsWithReplacement -where - I: Iterator, - I::Item: Clone, -{ - /// Map the current mask over the pool to get an output combination - fn current(&self) -> Vec { - self.indices.iter().map(|i| self.pool[*i].clone()).collect() - } -} - /// Create a new `CombinationsWithReplacement` from a clonable iterator. pub fn combinations_with_replacement(iter: I, k: usize) -> CombinationsWithReplacement where @@ -72,7 +61,7 @@ where // Otherwise, yield the initial state } else { self.first = false; - Some(self.current()) + Some(self.pool.get_at(&self.indices)) }; } @@ -97,7 +86,7 @@ where for indices_index in increment_from..self.indices.len() { self.indices[indices_index] = increment_value; } - Some(self.current()) + Some(self.pool.get_at(&self.indices)) } // Otherwise, we're done None => None, diff --git a/src/lazy_buffer.rs b/src/lazy_buffer.rs index 5cb039a63..fefcff8f5 100644 --- a/src/lazy_buffer.rs +++ b/src/lazy_buffer.rs @@ -51,6 +51,16 @@ where } } +impl LazyBuffer +where + I: Iterator, + I::Item: Clone, +{ + pub fn get_at(&self, indices: &[usize]) -> Vec { + indices.iter().map(|i| self.buffer[*i].clone()).collect() + } +} + impl Index for LazyBuffer where I: Iterator, diff --git a/src/permutations.rs b/src/permutations.rs index cf5973c8c..91389a73a 100644 --- a/src/permutations.rs +++ b/src/permutations.rs @@ -99,7 +99,7 @@ where return None; } } - let item = indices[0..*k].iter().map(|&i| vals[i].clone()).collect(); + let item = vals.get_at(&indices[0..*k]); *state = PermutationState::Loaded { indices, cycles }; Some(item) } @@ -110,7 +110,7 @@ where return None; } let k = cycles.len(); - Some(indices[0..k].iter().map(|&i| vals[i].clone()).collect()) + Some(vals.get_at(&indices[0..k])) } PermutationState::End => None, }