cic-fixed 0.5.1

CIC filter implementation for fixed point numbers
Documentation
//! Differentiator  
//!
//! A simple differentiator for use in cic filters.  

/// Differentiator
#[derive(Default, Clone, Copy)]
pub(crate) struct Differentiator {
    last_input: i32,
}

impl Differentiator {
    pub(crate) const fn new() -> Self {
        Self { last_input: 0 }
    }

    /// Differentiate the input and return the output.
    ///
    /// # Arguments
    ///
    /// * `input` - The input to differentiate.
    ///
    /// # Returns
    ///
    /// The output of the differentiator.
    #[inline]
    pub(crate) fn differentiate(&mut self, input: i32) -> i32 {
        let output = input.wrapping_sub(self.last_input);
        self.last_input = input;
        output
    }
}

#[cfg(test)]
mod tests {
    use super::*;

    #[test]
    fn differentiate_test() {
        let mut differentiator = Differentiator::new();
        let result = differentiator.differentiate(2);
        assert_eq!(result, 2);
        let result = differentiator.differentiate(5);
        assert_eq!(result, 3);
        let result = differentiator.differentiate(-1);
        assert_eq!(result, -6);
    }
}