diff options
author | Corey Richardson <corey@octayn.net> | 2017-09-24 08:59:43 -0400 |
---|---|---|
committer | Graham Northup <grahamnorthup@yahoo.com> | 2017-09-24 19:01:22 -0400 |
commit | 5f1e73ab5bd0709dd408064c06f2717182777537 (patch) | |
tree | bc66a94450cc3ab7312f73df404463d44f1c1290 | |
parent | f4c1ee3bbd1d548ce9c0c4cf15e9bd867adca421 (diff) |
Clean up some sub-optimal slice handling
Clippy noticed that update_from looked like a manual copy_from_slice,
which alerted me to sum_into and mul_into also being suboptimal. With
the new changes, the generated code is much cleaner: it lacks an extra
"unnecessary" branch and is about 30% shorter (for those methods).
I also think the code is a bit easier to read :)
-rw-r--r-- | src/synth/mod.rs | 45 |
1 files changed, 24 insertions, 21 deletions
diff --git a/src/synth/mod.rs b/src/synth/mod.rs index 6ec55f1..fb9714b 100644 --- a/src/synth/mod.rs +++ b/src/synth/mod.rs @@ -80,9 +80,8 @@ impl SampleBuffer { self.rate = other.rate; match self.rate { Rate::Sample => { - for i in 0..cmp::min(self.len(), other.len()) { - self.samples[i] = other.samples[i]; - } + let len = cmp::min(self.len(), other.len()); + self.samples[..len].clone_from_slice(&other.samples[..len]); }, Rate::Control => { self.samples[0] = other.samples[0]; @@ -93,16 +92,18 @@ impl SampleBuffer { pub fn sum_into(&mut self, other: &SampleBuffer) { match self.rate { Rate::Sample => { - let bound = match other.rate { - Rate::Sample => cmp::min(self.len(), other.len()), - Rate::Control => self.len(), + match other.rate { + Rate::Sample => { + for (elt, oelt) in self.samples.iter_mut().zip(other.samples.iter()) { + *elt += *oelt; + } + } + Rate::Control => { + for elt in &mut self.samples { + *elt += other.samples[0]; + } + } }; - for i in 0..bound { - self.samples[i] += match other.rate { - Rate::Sample => other.samples[i], - Rate::Control => other.samples[0], - }; - } }, Rate::Control => { self.samples[0] += other.samples[0]; @@ -113,16 +114,18 @@ impl SampleBuffer { pub fn mul_into(&mut self, other: &SampleBuffer) { match self.rate { Rate::Sample => { - let bound = match other.rate { - Rate::Sample => cmp::min(self.len(), other.len()), - Rate::Control => self.len(), + match other.rate { + Rate::Sample => { + for (elt, oelt) in self.samples.iter_mut().zip(other.samples.iter()) { + *elt *= *oelt; + } + } + Rate::Control => { + for elt in &mut self.samples { + *elt *= other.samples[0]; + } + } }; - for i in 0..bound { - self.samples[i] *= match other.rate { - Rate::Sample => other.samples[i], - Rate::Control => other.samples[0], - }; - } }, Rate::Control => { self.samples[0] *= other.samples[0]; |