pub struct DirectForm<T, const N: usize = 1, const M: usize = 2> {
pub x: [T; M],
pub y: [[T; M]; N],
}Expand description
Direct Form biquad/SOS state
Fields§
§x: [T; M]Input delay line
[x0, x1]
y: [[T; M]; N]Intermediate and output delay lines
[[y0, y1]]
Implementations§
Trait Implementations§
Source§impl<T: Clone, const N: usize, const M: usize> Clone for DirectForm<T, N, M>
impl<T: Clone, const N: usize, const M: usize> Clone for DirectForm<T, N, M>
Source§fn clone(&self) -> DirectForm<T, N, M>
fn clone(&self) -> DirectForm<T, N, M>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<T: Copy + Add<Output = T>, const N: usize> Process<T> for DirectForm<T, N, 1>
N Poles at DC, N zeros at Nyquist
impl<T: Copy + Add<Output = T>, const N: usize> Process<T> for DirectForm<T, N, 1>
N Poles at DC, N zeros at Nyquist
Source§impl<C, T: Copy> SplitInplace<T, DirectForm<T>> for Normal<C>where
Self: SplitProcess<T, T, DirectForm1<T>>,
impl<C, T: Copy> SplitInplace<T, DirectForm<T>> for Normal<C>where
Self: SplitProcess<T, T, DirectForm1<T>>,
Source§impl<T: 'static + Copy + Add<Output = T> + PartialOrd, C: Copy + Mul<T, Output = A>, A: Add<Output = A> + AsPrimitive<T>> SplitProcess<T, T, DirectForm<T>> for Biquad<C>
impl<T: 'static + Copy + Add<Output = T> + PartialOrd, C: Copy + Mul<T, Output = A>, A: Add<Output = A> + AsPrimitive<T>> SplitProcess<T, T, DirectForm<T>> for Biquad<C>
Source§impl<T: Copy + Add<Output = T> + PartialOrd, C> SplitProcess<T, T, DirectForm<T>> for BiquadClamp<C, T>where
Biquad<C>: SplitProcess<T, T, DirectForm1<T>>,
use dsp_process::SplitProcess;
use idsp::iir::*;
let biquad = BiquadClamp::<f32, f32>::from(Biquad::IDENTITY);
let mut state = DirectForm2Transposed::default();
let x = 3.0f32;
let y = biquad.process(&mut state, x);
assert_eq!(x, y);
impl<T: Copy + Add<Output = T> + PartialOrd, C> SplitProcess<T, T, DirectForm<T>> for BiquadClamp<C, T>where
Biquad<C>: SplitProcess<T, T, DirectForm1<T>>,
use dsp_process::SplitProcess;
use idsp::iir::*;
let biquad = BiquadClamp::<f32, f32>::from(Biquad::IDENTITY);
let mut state = DirectForm2Transposed::default();
let x = 3.0f32;
let y = biquad.process(&mut state, x);
assert_eq!(x, y);Source§impl<C: Copy + Mul<T, Output = A> + Neg<Output = C>, A: Add<Output = A> + AsPrimitive<T>, T: 'static + Copy> SplitProcess<T, T, DirectForm<T>> for Normal<C>
The y1, y2 aren’t DF1 but y1.re() and y1.im()
impl<C: Copy + Mul<T, Output = A> + Neg<Output = C>, A: Add<Output = A> + AsPrimitive<T>, T: 'static + Copy> SplitProcess<T, T, DirectForm<T>> for Normal<C>
The y1, y2 aren’t DF1 but y1.re() and y1.im()
Source§impl<T: Copy + Mul<Output = T> + Add<Output = T>> SplitProcess<T, T, DirectForm<T, 0>> for Biquad<T>
use dsp_process::SplitProcess;
use idsp::iir::*;
let biquad = Biquad::<f32>::IDENTITY;
let mut state = DirectForm2Transposed::default();
let x = 3.0f32;
let y = biquad.process(&mut state, x);
assert_eq!(x, y);
impl<T: Copy + Mul<Output = T> + Add<Output = T>> SplitProcess<T, T, DirectForm<T, 0>> for Biquad<T>
use dsp_process::SplitProcess;
use idsp::iir::*;
let biquad = Biquad::<f32>::IDENTITY;
let mut state = DirectForm2Transposed::default();
let x = 3.0f32;
let y = biquad.process(&mut state, x);
assert_eq!(x, y);Source§impl<T: Copy + Add<Output = T> + Mul<Output = T> + PartialOrd> SplitProcess<T, T, DirectForm<T, 0>> for BiquadClamp<T, T>
impl<T: Copy + Add<Output = T> + Mul<Output = T> + PartialOrd> SplitProcess<T, T, DirectForm<T, 0>> for BiquadClamp<T, T>
Source§impl<const N: usize, T: 'static + Copy, C: Copy + Mul<T, Output = A>, A: Add<Output = A> + AsPrimitive<T>> SplitProcess<T, T, DirectForm<T, N>> for Cascade<[Biquad<C>; N]>
let mut state = DirectForm1 {
x: [0.0, 1.0],
y: [[2.0, 3.0]],
};
let x0 = 4.0;
let y0 = Biquad::<f32>::IDENTITY.process(&mut state, x0);
assert_eq!(y0, x0);
assert_eq!(state.x, [x0, 0.0]);
assert_eq!(state.y[0], [y0, 2.0]);
impl<const N: usize, T: 'static + Copy, C: Copy + Mul<T, Output = A>, A: Add<Output = A> + AsPrimitive<T>> SplitProcess<T, T, DirectForm<T, N>> for Cascade<[Biquad<C>; N]>
let mut state = DirectForm1 {
x: [0.0, 1.0],
y: [[2.0, 3.0]],
};
let x0 = 4.0;
let y0 = Biquad::<f32>::IDENTITY.process(&mut state, x0);
assert_eq!(y0, x0);
assert_eq!(state.x, [x0, 0.0]);
assert_eq!(state.y[0], [y0, 2.0]);Auto Trait Implementations§
impl<T, const N: usize, const M: usize> Freeze for DirectForm<T, N, M>where
T: Freeze,
impl<T, const N: usize, const M: usize> RefUnwindSafe for DirectForm<T, N, M>where
T: RefUnwindSafe,
impl<T, const N: usize, const M: usize> Send for DirectForm<T, N, M>where
T: Send,
impl<T, const N: usize, const M: usize> Sync for DirectForm<T, N, M>where
T: Sync,
impl<T, const N: usize, const M: usize> Unpin for DirectForm<T, N, M>where
T: Unpin,
impl<T, const N: usize, const M: usize> UnwindSafe for DirectForm<T, N, M>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more