From 227bda25cfc69cb50f60d2ac735e0eebaf177eaf Mon Sep 17 00:00:00 2001 From: Dimitri Sabadie Date: Wed, 28 Aug 2024 22:11:33 +0200 Subject: [PATCH] Revert "Make `Spline` rely on `VecDeque` instead of `Vec`" --- src/iter.rs | 2 +- src/spline.rs | 51 +++++++++++++++++++++------------------------------ 2 files changed, 22 insertions(+), 31 deletions(-) diff --git a/src/iter.rs b/src/iter.rs index 54d68bf..c01f437 100644 --- a/src/iter.rs +++ b/src/iter.rs @@ -26,7 +26,7 @@ impl<'a, T, V> Iterator for Iter<'a, T, V> { fn next(&mut self) -> Option { let r = self.spline.0.get(self.i); - if r.is_some() { + if let Some(_) = r { self.i += 1; } diff --git a/src/spline.rs b/src/spline.rs index 1ffc2e0..e91abc0 100644 --- a/src/spline.rs +++ b/src/spline.rs @@ -5,7 +5,7 @@ use crate::interpolate::{Interpolate, Interpolator}; use crate::interpolation::Interpolation; use crate::key::Key; #[cfg(not(feature = "std"))] -use alloc::collections::VecDeque; +use alloc::vec::Vec; #[cfg(not(feature = "std"))] use core::cmp::Ordering; #[cfg(not(feature = "std"))] @@ -14,8 +14,6 @@ use core::ops::{Div, Mul}; use serde::{Deserialize, Serialize}; #[cfg(feature = "std")] use std::cmp::Ordering; -#[cfg(feature = "std")] -use std::collections::VecDeque; /// Spline curve used to provide interpolation between control points (keys). /// @@ -34,7 +32,7 @@ use std::collections::VecDeque; any(feature = "serialization", feature = "serde"), derive(Deserialize, Serialize) )] -pub struct Spline(pub(crate) VecDeque>); +pub struct Spline(pub(crate) Vec>); impl Spline { /// Internal sort to ensure invariant of sorting keys is valid. @@ -44,18 +42,16 @@ impl Spline { { self .0 - .make_contiguous() .sort_by(|k0, k1| k0.t.partial_cmp(&k1.t).unwrap_or(Ordering::Less)); } /// Create a new spline out of keys. The keys don’t have to be sorted even though it’s recommended /// to provide ascending sorted ones (for performance purposes). - pub fn from_vec(keys: K) -> Self + pub fn from_vec(keys: Vec>) -> Self where - K: Into>>, T: PartialOrd, { - let mut spline = Spline(keys.into()); + let mut spline = Spline(keys); spline.internal_sort(); spline } @@ -64,7 +60,7 @@ impl Spline { /// new keys should be faster than creating a new [`Spline`] #[inline] pub fn clear(&mut self) { - self.0.clear(); + self.0.clear() } /// Create a new spline by consuming an `Iterater>`. They keys don’t have to be @@ -79,12 +75,12 @@ impl Spline { I: Iterator>, T: PartialOrd, { - Self::from_vec(iter.collect::>>()) + Self::from_vec(iter.collect()) } /// Retrieve the keys of a spline. pub fn keys(&self) -> &[Key] { - self.0.as_slices().0 + &self.0 } /// Number of keys. @@ -119,8 +115,8 @@ impl Spline { T: Interpolator, V: Interpolate, { - let keys = self.keys(); - let i = search_lower_cp(keys, &t)?; + let keys = &self.0; + let i = search_lower_cp(keys, t)?; let cp0 = &keys[i]; let value = match cp0.interpolation { @@ -221,7 +217,7 @@ impl Spline { } self.sample_with_key(t).or_else(move || { - let first = self.0.front().unwrap(); + let first = self.0.first().unwrap(); if t <= first.t { let sampled = SampledWithKey { @@ -230,7 +226,7 @@ impl Spline { }; Some(sampled) } else { - let last = self.0.back().unwrap(); + let last = self.0.last().unwrap(); if t >= last.t { let sampled = SampledWithKey { @@ -259,22 +255,17 @@ impl Spline { where T: PartialOrd, { - let is_sort_required = if let Some(old_max) = self.0.back() { - old_max.t > key.t - } else { - false - }; - - self.0.push_back(key); - - if is_sort_required { - self.internal_sort(); - } + self.0.push(key); + self.internal_sort(); } /// Remove a key from the spline. pub fn remove(&mut self, index: usize) -> Option> { - self.0.remove(index) + if index >= self.0.len() { + None + } else { + Some(self.0.remove(index)) + } } /// Update a key and return the key already present. @@ -335,7 +326,7 @@ pub struct KeyMut<'a, T, V> { // Find the lower control point corresponding to a given time. // It has the property to have a timestamp smaller or equal to t -fn search_lower_cp(cps: &[Key], t: &T) -> Option +fn search_lower_cp(cps: &[Key], t: T) -> Option where T: PartialOrd, { @@ -343,9 +334,9 @@ where if len < 2 { return None; } - match cps.binary_search_by(|key| key.t.partial_cmp(t).unwrap()) { + match cps.binary_search_by(|key| key.t.partial_cmp(&t).unwrap()) { Err(i) if i >= len => None, - Err(0) => None, + Err(i) if i == 0 => None, Err(i) => Some(i - 1), Ok(i) if i == len - 1 => None, Ok(i) => Some(i),