Struct LowPassFilterBlock

Source
pub struct LowPassFilterBlock<S>
where S: Sample,
{ pub cutoff: Parameter<S>, pub resonance: Parameter<S>, /* private fields */ }
Expand description

SVF-based low-pass filter for efficient, stable filtering.

Uses the TPT (Topology Preserving Transform) SVF algorithm which is:

  • Stable at all cutoff frequencies
  • Has no delay-free loops
  • Maintains consistent behavior regardless of sample rate

Output is scaled by a compensation factor based on Q and cutoff frequency to preserve passband gain while limiting the resonance peak (target ≤ 2.0).

Fields§

§cutoff: Parameter<S>

Cutoff frequency in Hz (20-20000).

§resonance: Parameter<S>

Resonance (Q factor, 0.5-10.0, default 0.707 = Butterworth).

Implementations§

Source§

impl<S> LowPassFilterBlock<S>
where S: Sample,

Source

pub fn new(cutoff: f64, resonance: f64) -> LowPassFilterBlock<S>

Create a new low-pass filter with the given cutoff and resonance.

Source

pub fn set_sample_rate(&mut self, sample_rate: f64)

Set the sample rate for coefficient calculation.

Source

pub fn reset(&mut self)

Reset filter state (clear delay lines).

Trait Implementations§

Source§

impl<S> Block<S> for LowPassFilterBlock<S>
where S: Sample,

Source§

fn process( &mut self, inputs: &[&[S]], outputs: &mut [&mut [S]], modulation_values: &[S], context: &DspContext, )

Process audio through this block. Read more
Source§

fn input_count(&self) -> usize

Returns the number of input ports this block accepts.
Source§

fn output_count(&self) -> usize

Returns the number of output ports this block produces.
Source§

fn modulation_outputs(&self) -> &[ModulationOutput]

Returns the modulation outputs this block provides. Read more
Source§

fn channel_config(&self) -> ChannelConfig

Returns how this block handles multi-channel audio. Read more
Source§

fn set_smoothing(&mut self, _sample_rate: f64, _ramp_time_ms: f64)

Configure smoothing time for parameter changes. Read more
Source§

impl<S> From<LowPassFilterBlock<S>> for BlockType<S>
where S: Sample,

Source§

fn from(block: LowPassFilterBlock<S>) -> BlockType<S>

Converts to this type from the input type.

Auto Trait Implementations§

§

impl<S> Freeze for LowPassFilterBlock<S>
where S: Freeze,

§

impl<S> RefUnwindSafe for LowPassFilterBlock<S>
where S: RefUnwindSafe,

§

impl<S> Send for LowPassFilterBlock<S>

§

impl<S> Sync for LowPassFilterBlock<S>

§

impl<S> Unpin for LowPassFilterBlock<S>
where S: Unpin,

§

impl<S> UnwindSafe for LowPassFilterBlock<S>
where S: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.